php ztree新增,Ztree新增角色和编辑角色回显问题的解决

最近在项目中使用到了ztree,在回显时候费了点时间,特记录下来供下次参考。

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

效果图:

299928162f566fe27c5b2eb99f758f6b.png

具体涉及ztree代码:

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

页面加入

js代码(此js中加入了layer弹框效果):

$(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

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 ;

}

权限中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代码:

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

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 ;

}

java后台:

controller:/**

* 编辑角色,回显角色权限

* @param roleId

* @return

*/

@RequestMapping(value = "queryFunByRoleId", method = RequestMethod.POST)

public ResponseEntity>> 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> queryFunByRoleId(String roleId) {

//查询所有权限

List functions = queryAllAuthFunction();

//查询指定角色的权限

List functionsByRoleId = findFunctionByRoleId(roleId);

//包装zTree

List> list =new ArrayList>();

Mapmap=null;

for(int i=0;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 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;

}

相关标签:Ztree

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值