亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Ztree新增角色和編輯角色回顯問題的解決

2019-11-20 08:39:59
字體:
來源:轉載
供稿:網友

最近在項目中使用到了ztree,在回顯時候費了點時間,特記錄下來供下次參考。

1、新增角色使用ztree加載權限,由于權限不多,所以使用直接全部加載。

效果圖:

具體涉及ztree代碼:

jsp中導入:/js/ztree/zTreeStyle.css和js/ztree/jquery.ztree.all-3.5.js

頁面加入

<ul id="functionTree" class="ztree"></ul>

js代碼(此js中加入了layer彈框效果):

<script>    $(function() {      // 授權樹初始化      var setting = {        data : {          key : {            title : "t"          },          simpleData : {            enable : true          }        },        check : {//使用ztree選中效果          enable : true,        }      };      $.ajax({        url : '${pageContext.request.contextPath}/rest/sys/getAllFunction',//發送ajax請求加載權限數據        type : 'get',        dataType : 'json',        success : function(data) {//data就是服務端返回的權限數據          //var zNodes = eval("(" + data + ")");          //使用權限數據初始化ztree          $.fn.zTree.init($("#functionTree"), setting, data);        },        error : function(msg) {          alert('樹加載異常!');        }      });              //確定添加按鈕      $("#btn_submit").click(function() {        if(checkHousetype()){          //獲得ztree對象          var treeObj = $.fn.zTree.getZTreeObj("functionTree");          //獲得當前ztree對象選中的節點數組          var nodes = treeObj.getCheckedNodes(true);//在提交表單之前將選中的checkbox收集          //循環數組,獲得節點的ID,拼接成字符串使用逗號分隔          var array = new Array();          for(var i=0;i<nodes.length;i++){            array.push(nodes[i].id);          }          var ids = array.join(",");          $("input[name=funcitonIds]").val(ids);           var formData = new FormData($("#formproject")[0]);            $.ajax({            type : "POST",            url : "${pageContext.request.contextPath }/rest/sys/addRole",//           data : $("#formproject").serialize(),            data:formData,            contentType: false,             processData: false,            statusCode : {              201 : function() {                layer.msg('新增角色成功!', {icon: 6,time:1500},function(){                  location.href = "${pageContext.request.contextPath }/rest/sys/page/rolelist";                })              },              400 : function() {                layer.msg('提交的參數不合法', {time:1500});              },              500 : function() {                layer.msg('網絡異常,請稍候再試!', {time:1500});              }            }          });        }      });    });                   //校驗    function checkHousetype(){      var flag = true ;      //關鍵字      if($("#code").val()==''){        flag = false ;        layer.msg('請輸入關鍵字', {time:1500});        return flag ;      }      //名稱      if($("#name").val()==''){        flag = false ;        layer.msg('請輸入角色名稱', {time:1500});        return flag ;      }             return flag ;    }  </script>

權限中Ztree格式: 

private String id; private String name;private String code;private String description; // private String page; //private String generatemenu; //private String zindex; private String pid; private boolean isParent; //ztree組件需要格式public String getpId() {   return this.pid==null?"0":this.pid; }  ......  

2、編輯角色回顯Ztree

js代碼:

<script>   var zNodes;    var setting = {        check: {          enable: true        },        data: {          simpleData: {            enable: true          }        }      };    //當頁面加載完畢,向后臺發送ajax請求,獲取用戶id為1的用戶所擁有的權限    //(這里要顯示所有權限,該id用戶的權限回顯時,被自動選中),這里的用戶id為1僅做測試使用,實際開發中會傳值    function loadPower(roleId){          $.ajax({            type:"post",            url:"${pageContext.request.contextPath }/rest/sys/queryFunByRoleId",            data:{"roleId":roleId},            async:false,            dataType:"json",            success:function(data){              zNodes=data;            }          })    }    $(function() {      // 授權樹初始化      var setting = {        data : {          key : {            title : "t"          },          simpleData : {            enable : true          }        },        check : {//使用ztree選中效果          enable : true,        }      };      //頁面加載完畢時加載此方法      $(document).ready(function(){        var id = $("#roleId").val();        loadPower(id);        $.fn.zTree.init($("#functionTree"), setting, zNodes);      });             //確定添加按鈕      $("#btn_submit").click(function() {        if(checkHousetype()){          //獲得ztree對象          var treeObj = $.fn.zTree.getZTreeObj("functionTree");          //獲得當前ztree對象選中的節點數組          var nodes = treeObj.getCheckedNodes(true);//在提交表單之前將選中的checkbox收集          //循環數組,獲得節點的ID,拼接成字符串使用逗號分隔          var array = new Array();          for(var i=0;i<nodes.length;i++){            array.push(nodes[i].id);          }          var ids = array.join(",");          $("input[name=funcitonIds]").val(ids);           var formData = new FormData($("#formproject")[0]);            $.ajax({            type : "POST",            url : "${pageContext.request.contextPath }/rest/sys/eidtRole",//           data : $("#formproject").serialize(),            data:formData,            contentType: false,             processData: false,            statusCode : {              201 : function() {                layer.msg('編輯角色成功!', {icon: 6,time:1500},function(){                  location.href = "${pageContext.request.contextPath }/rest/sys/page/rolelist";                })              },              400 : function() {                layer.msg('提交的參數不合法', {time:1500});              },              500 : function() {                layer.msg('網絡異常,請稍候再試!', {time:1500});              }            }          });        }      });    });                   //校驗    function checkHousetype(){      var flag = true ;      //關鍵字      if($("#code").val()==''){        flag = false ;        layer.msg('請輸入關鍵字', {time:1500});        return flag ;      }      //名稱      if($("#name").val()==''){        flag = false ;        layer.msg('請輸入角色名稱', {time:1500});        return flag ;      }             return flag ;    }  </script>

java后臺:

controller:

/**   * 編輯角色,回顯角色權限   * @param roleId   * @return   */  @RequestMapping(value = "queryFunByRoleId", method = RequestMethod.POST)  public ResponseEntity<List<Map<String, Object>>> queryFunByRoleId(String roleId) {    try {      if(StringUtils.isBlank(roleId)){        // 返回400        return ResponseEntity.status(HttpStatus.BAD_REQUEST).body(null);      }      return ResponseEntity.ok(sysService.queryFunByRoleId(roleId));    } catch (Exception e) {      e.printStackTrace();    }    // 出錯 500    return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body(null);  }

service:

由于List中的contains方法校驗老是失敗,也沒糾結什么原因,自己寫的根據id校驗

/**   * zTree v3回顯   * 初始化化權限樹   * 拼接treeNode屬性   */  @Transactional(readOnly=true)  public List<Map<String, Object>> queryFunByRoleId(String roleId) {    //查詢所有權限    List<AuthFunction> functions = queryAllAuthFunction();    //查詢指定角色的權限    List<AuthFunction> functionsByRoleId = findFunctionByRoleId(roleId);    //包裝zTree         List<Map<String, Object>> list =new ArrayList<Map<String, Object>>();    Map<String, Object>map=null;    for(int i=0;i<functions.size();i++){      map=new HashMap<>();      //Role role=functions.get(i);      AuthFunction fun = functions.get(i);      map.put("id", fun.getId());      map.put("pId", fun.getpId());      map.put("name", fun.getName());      map.put("isParent", fun.getIsParent());      //判斷指定用戶的角色是否在所有角色中包含,有則設置checked=true.      if(functionsByRoleId != null && functionsByRoleId.size()>0 && ListIsContainsObj(functionsByRoleId,fun)){        map.put("checked",true);      }else {        map.put("checked",false);      }      list.add(map);    }    return list;  }     //校驗全部權限中是否有某個權限,有返回true  private boolean ListIsContainsObj(List<AuthFunction> functions, AuthFunction fun) {    if(fun == null || functions == null || functions.size()<=0){      return false;    }    for (AuthFunction authFunction : functions) {      if(fun.getId().equals(authFunction.getId())){        return true;      }    }    return false;  }

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美xxxx做受欧美| 国产精品a久久久久久| 亚洲欧美综合精品久久成人| 亚洲**2019国产| 欧美极品美女电影一区| 中文字幕久热精品在线视频| 国产亚洲精品久久久久动| 亚洲最新av网址| 亚洲精品国产电影| 欧美极度另类性三渗透| 在线观看日韩av| 中文字幕欧美日韩精品| 97**国产露脸精品国产| 国产精品第三页| 亚洲夜晚福利在线观看| 成人信息集中地欧美| 91手机视频在线观看| 日韩精品福利网站| 日韩av最新在线| 亚洲欧美在线第一页| 国产成人精品a视频一区www| 亚洲国产欧美一区二区三区久久| 国内精品视频久久| 一区二区欧美久久| 91豆花精品一区| 亚洲男人天天操| 色偷偷亚洲男人天堂| 一区二区三区亚洲| 久久久久久久久久久91| 欧美日韩国产专区| 亚洲香蕉av在线一区二区三区| 国产成人高潮免费观看精品| 亚洲成年人影院在线| 日韩精品免费在线观看| 国产精品美女久久久久久免费| 国产美女91呻吟求| 97久久超碰福利国产精品…| 国产精品扒开腿做| www.国产一区| 69**夜色精品国产69乱| 日韩美女免费线视频| 国产91网红主播在线观看| 欧美日韩亚洲精品一区二区三区| 亚洲人成在线观看| 久久全球大尺度高清视频| 日韩精品中文字幕视频在线| 亚洲性猛交xxxxwww| 久久精品中文字幕免费mv| 国产成人亚洲综合91精品| 欧美激情精品久久久久久久变态| 亚洲欧美中文在线视频| 欧美在线视频导航| 自拍偷拍亚洲区| 亚洲最大福利网| 久久精品久久久久电影| 国产亚洲福利一区| 亚洲欧美日韩国产中文专区| 久久精品国产一区二区三区| 5278欧美一区二区三区| 中文字幕免费精品一区高清| 热re99久久精品国产66热| 国产欧美一区二区三区久久| 亚洲日本成人网| 68精品国产免费久久久久久婷婷| 主播福利视频一区| 91久久国产婷婷一区二区| 欧美高清一级大片| 国产精品久久久久aaaa九色| 欧美日韩一区二区三区| 成人免费视频网| 日韩一区二区欧美| 亚洲成人xxx| 久久久精品国产| 精品视频在线导航| 国产免费一区二区三区香蕉精| 中文字幕av一区中文字幕天堂| 国产精品久久久久久久av大片| 国产精品久久久久久久久久免费| 亚洲香蕉成人av网站在线观看| 欧美日韩亚洲精品一区二区三区| 欧美高清视频在线| 欧美性猛交xxxx乱大交3| 成人精品视频在线| 538国产精品视频一区二区| 琪琪第一精品导航| 久久久久久久久久久免费精品| 日韩禁在线播放| 色先锋久久影院av| 国产成人精品久久二区二区91| 色哟哟网站入口亚洲精品| 在线一区二区日韩| 国产精品色午夜在线观看| 富二代精品短视频| 国产精品久久久久久久av大片| 久久精品国产亚洲一区二区| 国内久久久精品| 欧美大尺度电影在线观看| 国产精品一区二区久久久| 久久久久久91香蕉国产| 欧美黑人巨大xxx极品| 这里精品视频免费| 这里只有精品丝袜| 国产精品免费小视频| 久久精品视频中文字幕| 久久久中文字幕| 欧美成aaa人片在线观看蜜臀| 69久久夜色精品国产69| 欧美激情xxxx| 亚洲电影免费观看高清| 伊人久久大香线蕉av一区二区| 亚洲精品在线91| 色噜噜国产精品视频一区二区| 久久夜精品va视频免费观看| 国产成人精品最新| 在线观看日韩欧美| 亚洲视频在线播放| 亚洲成人精品视频在线观看| 国产精品高精视频免费| 久久6免费高清热精品| 琪琪亚洲精品午夜在线| 精品视频www| 日韩中文字幕在线视频播放| 日韩亚洲国产中文字幕| 亚洲女人被黑人巨大进入| 亚洲自拍高清视频网站| 国产在线拍偷自揄拍精品| 国内精品久久久久影院 日本资源| 亚洲性生活视频在线观看| 色爱精品视频一区| 亚洲福利影片在线| 韩国19禁主播vip福利视频| 久久视频免费在线播放| 丁香五六月婷婷久久激情| 国产免费一区二区三区在线观看| 国产精品jvid在线观看蜜臀| 成人精品福利视频| 国内精品视频一区| 日韩成人在线视频观看| 国产一区二区三区日韩欧美| 精品亚洲男同gayvideo网站| 国产成人中文字幕| 国产精品美女久久久久久免费| 欧美激情按摩在线| 日韩在线观看免费高清完整版| 夜夜躁日日躁狠狠久久88av| 久久久久成人网| 久久国产精品免费视频| 日韩在线精品一区| 亚洲国产精品va在看黑人| 97久久精品人搡人人玩| 精品视频久久久久久| 亚洲摸下面视频| 久久久久久久久久久91| 国产成人亚洲精品| 亚洲成人久久网| 亚洲国产精品小视频| 亚洲精品久久久久久久久久久久久| 国产成人精品久久亚洲高清不卡| 亚洲美女在线视频| 欧美在线激情网| 久久精视频免费在线久久完整在线看| 国产一区二区三区在线播放免费观看| 亚洲a在线播放| 伊人久久五月天|