如题,从后台封装数据,有两种方式渲染节点的数据:

  1.全部节点加载

  2.根据父节点加载子节点

首先,先介绍下第一种渲染方式:

  后台返回数据格式(所有的附加属性,都可放在additionalParameters下):

前端页面html:

<div class="widget-body">
  <div class="widget-main padding-8">
    <div id="treeview" class="tree"></div>
    <div class="hr"></div>
   </div>
</div>

前端js渲染:

var remoteUrl = '/business/function/getFuncsTreeAll';

var remoteDateSource = function(options, callback) {
  var self = this;
  var $data = null;

  if(!("name" in options) && !("type" in options)){
    $.ajax({
      url: remoteUrl,
      data: 'parent_id=0000',
      type: 'POST',
      dataType: 'json',
      success : function(response) {
          if(response.status == "OK")
            callback({ data: response.data })
          },
      error: function(response) {
      //console.log(response);
      }
    });
    return;
  }
  else if("type" in options && options.type == "folder") {
    if("additionalParameters" in options && "children" in options.additionalParameters)
      $data = options.additionalParameters.children;//点击父节点,加载子节点
    else $data = {}//no data
  }

  if($data != null)//this setTimeout is only for mimicking some random delay
    setTimeout(function(){callback({ data: $data });} , parseInt(Math.random() * 500) + 200);

};

$('#treeview').ace_tree({
  dataSource: remoteDateSource ,
  multiSelect:true,
  loadingHTML:'<div class="tree-loading"><i class="ace-icon fa fa-refresh fa-spin blue"></i></div>',
  'open-icon' : 'ace-icon tree-minus',
  'close-icon' : 'ace-icon tree-plus',
  'selectable' : true,
  'selected-icon' : 'ace-icon fa fa-check',
  'unselected-icon' : 'ace-icon fa fa-times'
});

//show selected items inside a modal
$('#submit-button').on('click', function() {
  var output = '';
  var items = $('#treeview').tree('selectedItemsAndParents');//这个是我自己扩展的方法,框架应是selectedItems
  for(var i in items) if (items.hasOwnProperty(i)) {
    var item = items[i];
    output += item.additionalParameters['id'] + ":"+ item.name+"\n";//获取附加属性
  }

  $('#modal-tree-items').modal('show');
  $('#tree-value').css({'width':'98%', 'height':'200px'}).val(output);
});

第二种方式渲染(根据父节点加载子节点数据),主要是remoteDateSource 的实现不一样:

var remoteDateSource = function(options, callback) {
  var parent_id = null
  if( !('text' in options || 'type' in options) ){
    parent_id = "0000";//load first level data
  }
  else if('type' in options && options['type'] == 'folder') {//it has children
    if('additionalParameters' in options && 'children' in options.additionalParameters)
      parent_id = options.additionalParameters['id']
    }

    if(parent_id !== null) {//根据父节点id,请求子节点
      $.ajax({
        url: remoteUrl,
        data: 'parent_id='+parent_id,
        type: 'POST',
        dataType: 'json',
        success : function(response) {
          if(response.status == "OK")
            callback({ data: response.data })
        },
        error: function(response) {
          //console.log(response);
        }
      })
    }
  }

附录----

selectedItemsAndParents(返回选中的叶子节点以及父类节点)实现:

selectedItemsAndParents: function() {
  var $sel = this.$element.find(".tree-selected");
  var data = [];
  $.each($sel,
     function(index, value) {
      data.push($(value).data());
      var $parent = $(value).parents("li");
      $.each($parent,function(index_parent,p){
        if(typeof($(p).attr("role"))!="undefined") {
          var result = $.inArray($(p).data(), data);
          if(result==-1){
            data.push($(p).data());
          }
        }
      });
  });
  return data
}

aceAdmin fuelux tree 从后台获取数据,并设置节点ID等属性的更多相关文章

  1. Swift - 后台获取数据(Background Fetch)的实现

    前面讲了如何让程序申请后台短时运行.但这个额外延长的时间毕竟有限.所以从iOS7起又引入两种在后台运行任务的方式:后台获取和后台通知. 1,后台获取介绍 后台获取(Background Fetch)是 ...

  2. ligerUI---下拉菜单(menubar)动态显示(从后台获取数据)

    写在前面: ligerui的下拉菜单是有点丑的,这也是没有办法的事........这里主要记录下,如何从后台获取数据进行菜单显示. 有两种方式:1.使用json数组来动态添加  2.字符串拼接.  其 ...

  3. jsTree通过AJAX从后台获取数据

    页面代码: <div id="MenuTree"></div> javascript代码: $(document).ready(function ($) { ...

  4. Vue---从后台获取数据vue-resource的使用方法

    作为前端人员,在开发过程中,我们大多数情况都需要从后台请求数据,那么在vue中怎样从后台获取数据呢?接下来,我简单介绍一下vue-resource的使用方法,希望对大家有帮助. 一.下载vue-res ...

  5. 在Vue中使用了Swiper ,动态从后台获取数据的之后,swiper滑动失效??

    在Vue中使用了Swiper ,动态从后台获取数据的之后,swiper滑动失效?? 是因为swiper提前初始化了,那时候数据还没有完全出来.这里有两种解决办法 1. 使用vue提供的$nextTic ...

  6. 一、表单和ajax中的post请求&&后台获取数据方法

    一.表单和ajax中的post请求&&后台获取数据方法 最近要做后台数据接收,因为前台传来的数据太过于混乱,所以总结了一下前台数据post请求方法,顺便写了下相对应的后台接收方法. 前 ...

  7. vue_elementUI_ tree树形控件 获取选中的父节点ID

    el-tree 的 this.$refs.tree.getCheckedKeys() 只可以获取选中的id 无法获取选中的父节点ID想要获取选中父节点的id;需要如下操作1. 找到工程下的node_m ...

  8. 在MyBatis中查询数据、涉及多参数的数据访问操作、插入数据时获取数据自增长的id、关联表查询操作、动态SQL、关于配置MyBatis映射没有代码提示的解决方案

    1. 单元测试 在单元测试中,每个测试方法都需要执行相同的前置代码和后置代码,则可以自定义2个方法,分别在这2个方法中执行前置代码和后置代码,并为这2个方法添加@Before和@After注解,然后, ...

  9. MVC后台获取数据和插入数据的三种方式【二】

    MVC模式下,从前端获取数据返回后台,总共有三种形式.下面的代码示例将演示如何将数据返回到后端. 一.首先我们看看表单代码,注意input标签中name的值. <html> <hea ...

随机推荐

  1. DOM节点的修改

    首先,我们将最后段落赋值给变量my: var my = document.getElementById('closer'); 接下来,我们就能够轻松地通过修改对象的innerHTML值来修改段落中的文 ...

  2. .net 使用ffmpeg.exe进行音频转码

    #region 音频转换 private int AudioIntervalTime = 100, iAudio = 0; private string strPath = "D:\\web ...

  3. uboot和内核波特率不同

    uboot和内核波特率不同,在uboot启动后,修改uboot参数: set bootargs 'noinitrd root=/dev/mtdblock3 init=/linuxrc console= ...

  4. linux下的磁盘和文件系统管理

    一.硬盘分区知识 1.分区类型 硬盘分区一共有3种:主分区.扩展分区和逻辑分区.扩展分区只不过是逻辑分区的“容器”,实际上只有主分区和逻辑分区进行数据存储.在一块硬盘上最多只能有4个主分区,可以另外建 ...

  5. html doctype 作用介绍

    文档模式主要有以下两个作用: 1.告诉浏览器使用什么样的html或xhtml规范来解析html文档 2.对浏览器的渲染模式产生影响:不同的渲染模式会影响到浏览器对于 CSS 代码甚至 JavaScri ...

  6. 通过案例对 spark streaming 透彻理解三板斧之三:spark streaming运行机制与架构

    本期内容: 1. Spark Streaming Job架构与运行机制 2. Spark Streaming 容错架构与运行机制 事实上时间是不存在的,是由人的感官系统感觉时间的存在而已,是一种虚幻的 ...

  7. redis 安装使用

    在 centos 7.2 系统上,安装使用redis.了解学习redis功能及特性. 版本: 3.2.4 1.安装: # yum install redis 2.配置: /etc/logrotate. ...

  8. 【转载】C++ function、bind和lambda表达式

    本篇随笔为转载,原贴地址:C++ function.bind和lambda表达式. 本文是C++0x系列的第四篇,主要是内容是C++0x中新增的lambda表达式, function对象和bind机制 ...

  9. c# & Fizzler to crawl web page in a certain website domain

    使用fizzler [HtmlAgilityPackExtension]和c#进行网页数据提取:fizzler是HtmlAgilityPack的一个扩展,支持jQuery Selector: 提取数据 ...

  10. mysql分区查询

    SELECT *FROM INFORMATION_SCHEMA.partitions WHERE table_name='表名' and table_schema='数据库名'