aceAdmin fuelux tree 从后台获取数据,并设置节点ID等属性

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

  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
}

时间: 2024-10-12 09:20:35

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

ajax从asp后台获取数据

1.前台 $.ajax({ //url: "demo/data/taskTree.txt", url: "GanttChart.aspx?taskList=1" , cache: false, success: function (text) { var data = mini.decode(text); gantt.loadTasks(data); gantt.unmask(); //折叠全部 //gantt.collapseAll(); } }); 2.后台 ?

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

前面讲了如何让程序申请后台短时运行.但这个额外延长的时间毕竟有限.所以从iOS7起又引入两种在后台运行任务的方式:后台获取和后台通知. 1,后台获取介绍 后台获取(Background Fetch)是为了那些需要定期更新的应用程序设计的,比如天气应用,新闻客户端,社交网络应用程序等.在启动后台获取之后,应用程序可以在后台被唤醒,在后台获取最新信息,以便在用户将应用程序转到前台时能够立即显示这些信息. 2,后台获取功能开启 首先在选中项目,在Capabilities(功能)选项卡,启用Backgr

jsTree通过AJAX从后台获取数据

页面代码: <div id="MenuTree"></div> javascript代码: $(document).ready(function ($) { InitMenuTree(); }); function InitMenuTree() { $('#MenuTree').data('jstree', false); $.getJSON('@Url.Action("GetMenuTree", "AdminMenu")

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

在Vue中使用了Swiper ,动态从后台获取数据的之后,swiper滑动失效?? 是因为swiper提前初始化了,那时候数据还没有完全出来.这里有两种解决办法 1. 使用vue提供的$nextTick()方法 当Vue构造器里的data值被修改完成后会调用这个方法,也相当于一个钩子函数吧,和构造器里的updated生命周期很像. 在数据初始化完毕之后,再初始化swiper就不会出现问题了 this.$nextTick(function () { var swiper = new Swiper(

下拉插件 (带搜索) Bootstrap-select 从后台获取数据填充到select的 option中 用法详解

今天收到了客户的需求,要求在新增停车场ID的时候要从数据库查出来对应的停车场名称然后显示在界面上.保存的时候按照停车场ID进行保存. 自己首先把后台的部分写完了,测试了接口数据.成功的拿到了ajax数据. 接下来,自己用了select下拉标签和js函数进行填充后台传过来的数据. 经过自己的不断百度和参考别人的博客,试了很多次终于成功的调试出了想要的结果. 特来博客记录一下,也分享一下开心的心情. (一)首先引入样式和JS文件 样式文件和JS下载放到本地最好,因为放到本地自己可以修改一些东西. 在

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

el-tree 的 this.$refs.tree.getCheckedKeys() 只可以获取选中的id 无法获取选中的父节点ID想要获取选中父节点的id;需要如下操作1. 找到工程下的node_modules文件夹 然后查找 element-ui.common.js文件 node_modules\element-ui\lib\element-ui.common.js2. 按Ctrl+F搜索TreeStore.prototype.getCheckedKeys这个方法3. 把// if (chi

后台获取数据实现实时折线图

折线图用的是echarts的折线图.框架用的ssm,连接oracle数据库,将数据实时显示在折线图上. <div id="main" style="width: 95%; height: 60%; margin: auto;"></div> <script> function showEcharts() { require( [ 'echarts', 'echarts/chart/line' ], function(ec) { /

vue+vuex+axios从后台获取数据存入vuex,组件之间共享数据

在vue项目中组件间相互传值或者后台获取的数据需要供多个组件使用的情况很多的话,有必要考虑引入vuex来管理这些凌乱的状态,今天这边博文用来记录这一整个的过程,后台api接口是使用webpack-server模拟的接口,这个前面的文章中有提到,需要的可以去翻阅. 整个的流程是在组件的created中提交dispatch,然后通过action调用一个封装好的axios然后再触发mutation来提交状态改变state中的数据,然后在组件的计算属性中获取state的数据并渲染在页面上 首先新需要在项

从后台获取数据导出excel文件

做oa系统的都会有这个要求:根据数据导入excel文件.只需要点击一下,你所需要的数据就直接生成一个excel文件了,是不是很方便? 是的没错,很方便,但是对于我们来说是一件很痛苦的事情,所以说一下我的经历.因为是第一次写excel文件导出,所以代码可能写的很烂,不喜勿喷. 有什么意见也可以直接留言哦,希望与大家一起交流 第一步,先在pom.xml文件依赖jar包: <!-- https://mvnrepository.com/artifact/org.apache.poi/poi --> &