码迷,mamicode.com
首页 > 其他好文 > 详细

生成树形选项

时间:2016-03-04 00:15:23      阅读:237      评论:0      收藏:0      [点我收藏+]

标签:

@{
Layout = null;
}

<!DOCTYPE html>

<html>
<head>
<meta name="viewport" content="width=device-width" />
<title>index_default</title>
<link href="~/Areas/Admin/css/bootstrap.min.css" rel="stylesheet" />
<link href="~/Areas/Admin/css/bootstrap-table.css" rel="stylesheet" />
<link href="~/Areas/Admin/bootstrapTreeView/css/bootstrap-treeview.css" rel="stylesheet" />
<link href="~/Areas/Admin/css/styles.css" rel="stylesheet" />
<link href="~/Areas/Admin/css/ui-dialog.css" rel="stylesheet" />
<script src="~/Areas/Admin/js/jquery-1.11.1.min.js"></script>
<script src="~/Areas/Admin/js/bootstrap.min.js"></script>
<script src="~/Areas/Admin/js/bootstrap-table.js"></script>
@*<script src="~/Areas/Admin/js/bootstrap-table-zh-CN.js"></script>*@
<script src="~/Areas/Admin/js/dialog-min.js"></script>
<script src="~/Areas/Admin/bootstrapTreeView/js/bootstrap-treeview.js"></script>
</head>
<body>

<div class="row">
<div class="col-lg-12">
<div class="panel panel-default">
<div class="panel-heading">角色管理</div>
<div class="panel-body">
<div id="toolbar">
<button type="button" class="btn btn-default" id="add">
<span class="glyphicon glyphicon-plus"></span>&nbsp;新增
</button>

</div>
<table data-toggle="table" id="table" data-toolbar="#toolbar" data-url="/Admin/System/GetRoleList" data-show-refresh="true" data-show-toggle="true" data-show-columns="true" data-search="true" data-pagination="true" data-sort-name="name" data-sort-order="desc">
<thead>
<tr>
<th data-field="state" data-checkbox="true"></th>
<th data-field="ID" hidden="hidden" data-visible="false">ID</th>
<th data-field="Name" data-sortable="true" class="col-sm-4">名称</th>
@*<th data-field="PrivilegeID" data-sortable="true">权限</th>*@
<th data-field="Note" data-sortable="true" class="col-sm-4">备注</th>
<th data-field="Operation" data-formatter="actionFormatter" data-events="actionEvents" class="col-sm-4">操作</th>
</tr>
</thead>
</table>
</div>
</div>
</div>
</div>

<!-- Modal -->
<div class="modal fade" id="saveModal" tabindex="-1" role="dialog" aria-labelledby="saveModalLabel">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 class="modal-title" id="myModalLabel">新增</h4>
</div>
<div class="modal-body">
<form class="form-horizontal">
<div class="form-group">
<label for="Name" class="col-sm-2 control-label">名称</label>
<div class="col-sm-10">
<input type="text" class="form-control" id="Name" placeholder="名称" name="Name">
</div>
</div>
<div class="form-group">
@*<label for="PrivilegeID" class="col-sm-2 control-label">权限</label>*@
<div class="col-sm-10">
@* <select id="PrivilegeID" name="PrivilegeID" class="form-control">*@
@*<option value="1">超级管理员</option>
<option value="2">文章管理员</option>
<option value="3">论坛管理员</option>*@
@*</select>*@
</div>
</div>
<div class="form-group">
<label for="Note" class="col-sm-2 control-label">备注</label>
<div class="col-sm-10">
<input type="text" class="form-control" name="Note" id="Note" placeholder="备注" />
</div>
</div>
</form>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" id="save">保存</button>
<button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>
</div>
</div>
</div>
</div>
<!-- Modal -->
<div class="modal fade" id="setPrivilegeModal" tabindex="-1" role="dialog" aria-labelledby="setPrivilegeLabel">
<div class="modal-dialog" role="document">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close"><span aria-hidden="true">&times;</span></button>
<h4 class="modal-title" id="myModalLabel">分配角色</h4>
</div>
<div class="modal-body">
@*<form class="form-horizontal">*@
<input type="hidden" name="RoleID" id="RoleID" value="" />

<!--栏目树-->
<div id="tree"></div>
<div id="treeview-checkable" class=""></div>
@*</form>*@
</div>
<div class="modal-footer">
<button type="button" class="btn btn-primary" id="savePrivilege">保存</button>
<button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>
</div>
</div>
</div>
</div>
<script>
//全局变量
var ID = "";

//保存成功提示框
function toMsg(msg) {
var d1 = dialog({
title: ‘提示‘,
content: msg,
height: "50",
width: "320",
});
d1.show();
setTimeout(function () {
d1.close().remove();
}, 2000);
};


function edit(row) {
$.get("/Admin/System/EditRole", "ID=" + row.ID, function (data) {
if (data.Statu == "ok") {
ID = data.Data.ID;
$("#Name").val(data.Data.Name);
$("#PrivilegeID").val(data.Data.PrivilegeID);
$("#Note").val(data.Data.Note);
} else {

}
}, "Json");
$(‘#saveModal‘).modal(‘show‘);//打开模态框

}
//新增
$("#add").unbind("click").bind("click", function () {
$(‘#saveModal‘).modal(‘show‘);//打开模态框
});

//分配权限
function setPrivilege(row) {
$("#RoleID").val(row.ID);
$("#setPrivilegeModal").modal(‘show‘);
$(‘#treeview-checkable‘).treeview(‘uncheckAll‘, { silent: true });
//获取该用户的权限
$.get("/Admin/System/GetPrivilegeByRoleId?roleID=" + row.ID, "", function (data) {

var PrivilegeID = "";
if (data.length > 0) {
var nodes = $(‘#treeview-checkable‘).treeview(‘getEnabled‘);
for (var i = 0; i < data.length; i++)
{
PrivilegeID = data[i].PrivilegeID;
for (var j = 0; j < nodes.length; j++)
{
if (nodes[j].id.trim() == data[i].PrivilegeID.trim())
{
$(‘#treeview-checkable‘).treeview(‘checkNode‘, [nodes[j], { silent: true }]);
}
}
}
}
});
}
//删除
function del(row) {
//alert(row.ID);
var d = dialog({
title: ‘提示‘,
content: ‘是否删除‘,
cancelValue: ‘取消‘,
okValue: ‘确定‘,
height: "50",
width: "320",
ok: function () {
$.get("/Admin/System/RoleDel", "ID=" + row.ID, function (data) {
if (data.Statu == "ok") {
toMsg("删除成功");
window.location.href = data.BackUrl;
// alert(data.BackUrl);
}
}, "Json");
},
cancel: function () {

}
});
d.show();
}

 

//创建子树
function BindChildNode(source, parcode) {
var result = "";
for (var i = 0; i < source.length; i++) {
if ((source[i].PID == null ? "" : source[i].PID.trim()) == (parcode == null ? "" : parcode.trim())) {
if (result == "") {
result = ",\"nodes\":[";
result += "{\"id\":\" " + source[i].ID + " \",\"text\":\" " + source[i].Name + " \",\"href\": \"#parent2\", \"tags\": \"[‘0‘]\"" + BindChildNode(source, source[i].ID) + "}";
}
else {
result += ",{\"id\":\" " + source[i].ID + " \",\"text\":\" " + source[i].Name + " \",\"href\": \"#parent2\", \"tags\": \"[‘0‘]\"" + BindChildNode(source, source[i].ID) + "}";
}
}
}
if (result != "")
result += "]";
return result;
}

$(function () {

//权限树
$.get("/Admin/System/GetPrivilegeHelper", "", function (data) {
if (data.Statu == "ok") {
var pPrivilege = "[";
for (var i = 0; i < data.Data.length; i++) {
if (data.Data[i].PID == null || data.Data[i].PID.trim() == "" || data.Data[i].PID.trim() == "null") {
//生成父权限
if (pPrivilege == "[") {
pPrivilege += "{\"id\":\" " + data.Data[i].ID + " \",\"text\":\" " + data.Data[i].Name + " \",\"href\": \"#parent2\", \"tags\": \"[‘0‘]\"" + BindChildNode(data.Data, data.Data[i].ID) + "}";
} else {
pPrivilege += ",{\"id\":\" " + data.Data[i].ID + " \",\"text\":\" " + data.Data[i].Name + " \",\"href\": \"#parent2\", \"tags\": \"[‘0‘]\"" + BindChildNode(data.Data, data.Data[i].ID) + "}";

}
}
}

pPrivilege += "]";
$.parseJSON(pPrivilege)
//权限树
var $checkableTree = $(‘#treeview-checkable‘).treeview({
data: pPrivilege,
showIcon: false,
showCheckbox: true,
onNodeChecked: function (event, node) {

},
onNodeUnchecked: function (event, node) {

}
});

//保存分配权限
$("#savePrivilege").unbind("click").bind("click", function () {
var AllPrivilege = new Array();
var nodeList = $(‘#treeview-checkable‘).treeview(‘getChecked‘);
for (var i = 0; i < nodeList.length; i++) {
AllPrivilege[i] = nodeList[i].id;
}

var RoleID = $("#RoleID").val();
$.post("/Admin/System/SetRolePrivilege?AllPrivilege=" + AllPrivilege + "&RoleID=" + RoleID, "", function (data) {
if (data.Statu == "ok") {
$("#setPrivilegeModal").modal(‘hide‘);
toMsg("设置成功");
}
});
});
}
});

//保存
$("#save").unbind("click").bind("click", function () {
$(‘#saveModal‘).modal(‘hide‘)
var params = "ID=" + ID
+ "&Name=" + $("#Name").val()
+ "&PrivilegeID=" + $("#PrivilegeID").val()
+ "&Note=" + $("#Note").val();

$.post("/Admin/System/RoleSave", params, function (data) {
if (data.Statu == "ok") {
window.location.href = data.BackUrl;
toMsg("保存成功");
} else {

toMsg("保存失败");
}
});

});


//===============================
var $table = $(‘#table‘);
//获取选中行数据
$table.on(‘click-row.bs.table‘, function (e, row, $element) {
$(‘.success‘).removeClass(‘success‘);
$($element).addClass(‘success‘);
});
$(‘#get‘).click(function () {
alert(‘Selected name: ‘ + getSelectedRow().name);
});

//下拉框
$(‘#toolbar‘).find(‘select‘).change(function () {
$table.bootstrapTable(‘refreshOptions‘, {
exportDataType: $(this).val()
});
});


});

function getSelectedRow() {
var index = $table.find(‘tr.success‘).data(‘index‘);
return $table.bootstrapTable(‘getData‘)[index];
}
//操作
function actionFormatter(value, row, index) {
return [
‘<a class="edit ml10" href="javascript:void(0)" title="Edit">‘,
‘<i class="glyphicon glyphicon-edit"></i>编辑‘,
‘</a>&nbsp;&nbsp;&nbsp;‘,
‘<a class="setPrivilege ml10" href="javascript:void(0)" title="setPrivilege">‘,
‘<i class="glyphicon glyphicon-cog">分配权限</i>‘,
‘</a>&nbsp;&nbsp;&nbsp;‘,
‘<a class="remove ml10" href="javascript:void(0)" title="Remove">‘,
‘<i class="glyphicon glyphicon-remove">删除</i>‘,
‘</a>‘
].join(‘‘);
}
window.actionEvents = {
‘click .edit‘: function (e, value, row, index) {
edit(row);
console.log(value, row, index);
},
‘click .setPrivilege‘: function (e, value, row, index) {
setPrivilege(row);
console.log(value, row, index);
},
‘click .remove‘: function (e, value, row, index) {
del(row);
console.log(value, row, index);
}
};

</script>
</body>
</html>

生成树形选项

标签:

原文地址:http://www.cnblogs.com/mfc-itblog/p/5240394.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!