MVC bootstrap 实现 bootstrap table 左右传递数据
源码:
@{
ViewBag.Title = "Index";
}
@using BC.Platform.UPMS.Models; <!DOCTYPE html> <html lang="zh-CN">
<head>
<meta name="viewport" content="width=device-width" />
<title>用户管理</title>
<!--[if lt IE 9]>
<meta http-equiv="refresh" content="0;ie.html" />
<![endif]-->
@Styles.Render("~/Bootstrap/css/bootstrap-theme.css")
@Styles.Render("~/Bootstrap/css/bootstrap.min.css") @Styles.Render("~/Bootstrap/css/plugins/bootstrap-datetimepicker/bootstrap-datetimepicker.css")
@Styles.Render("~/Bootstrap/css/plugins/bootstrap-validator/bootstrap-validator.css")
@Styles.Render("~/Bootstrap/css/plugins/bootstrap-treeview/bootstrap-treeview.css")
@Styles.Render("~/Bootstrap/css/plugins/bootstrap-table/bootstrap-table.min.css")
@Styles.Render("~/Bootstrap/css/plugins/bootstrap-jquery-confirm/jquery-confirm.css")
@Styles.Render("~/Bootstrap/css/plugins/bootstrap-treeview/bootstrap-treeview.min.css")
@Styles.Render("~/Bootstrap/css/plugins/bootstrap-layer/layer.css")
@Styles.Render("~/Bootstrap/css/plugins/bootstrap-validator/bootstrap-validator.css")
@Styles.Render("~/Bootstrap/css/plugins/bootstrap-bc-platform/style.min.css")
@Styles.Render("~/Bootstrap/css/font-awesome.min.css") </head> <body class="gray-bg"> <div style="margin: 0px 5px 0px 5px; "> <div class="col-sm-12" style="padding-left: 0px; padding-right: 0px;">
@*这里是tree 开始*@
<div class="col-sm-3" style="padding-left: 0px; padding-right: 5px;">
<div class="ibox-title"><i class="fa fa-table"></i> 分组角色列表<div class="ibox-title-div-right"> <i class="fa fa-refresh"><a id="btnRefresh" class="ibox-title-href" href="#">刷新</a></i></div></div> <div class="alert alert-info" style="margin-top:10px;margin-bottom:10px">
<strong>当前角色:</strong><label id="lblRoleName" style="margin-bottom: 0px;">您还没有选择</label>
</div> <div class="ibox-content">
<label for="treeGroupRole"></label>
<div id="treeGroupRole" />
</div>
</div>
@*这里是tree 结束*@ </div> <div class="col-sm-9" style="padding-left: 0px; padding-right: 0px;"> <div class=" col-sm-5" style="padding-left: 0px; padding-right: 0px;"> <div class="ibox-title">
<i class="fa fa-table"></i> 当前用户<div class="ibox-title-div-right">
<i class="fa fa-remove"><a id="btn_delete_L" class="ibox-title-href" href="#">删除</a></i>
<i class="fa fa-search"><a id="btn_search_L" class="ibox-title-href" href="#">查找</a></i>
<i class="fa fa-save"><a id="btn_save_L" class="ibox-title-href" href="#">保存</a></i>
</div>
</div> <div class="alert alert-info" style="margin-top:10px;margin-bottom:10px">
<strong>温馨提示:</strong>记得选择左边角色
</div>
<div class="ibox-content">
<div class="row">
<div class="col-sm-12">
<input id="txt_UserName_L" name="txt_UserName_L" class="form-control" type="text" placeholder="用户名">
</div>
</div>
<!--主列表信息 开始-->
<div class="ibox-content-details"> <table id="tableRoleUser_L" class="table table-bordered table-striped table-hover" cellspacing="0" width="100%"></table>
</div>
<!--主列表信息 结束-->
</div>
</div>
<div class=" col-sm-1" style="margin-top: 20% ;padding-left: 5px; padding-right: 5px;"> <button id="btnRight" data-method="append" class="btn btn-info btn-large btn-block " type="button">
<i class="fa fa-angle-double-right"></i>
</button>
<button id="btnLeft" data-method="append" class="btn btn-info btn-large btn-block " type="button">
<i class="fa fa-angle-double-left"></i>
</button>
</div> <div class=" col-sm-6" style="padding-left: 0px; padding-right: 0px;"> <div class="ibox-title">
<i class="fa fa-table"></i> 全部用户<div class="ibox-title-div-right">
<i class="fa fa-search"><a id="btn_search_R" class="ibox-title-href" href="#">查找</a></i>
</div>
</div> <div class="alert alert-info" style="margin-top:10px;margin-bottom:10px">
<strong>温馨提示:</strong>选中以下用户可添加到左边
</div> <div class="ibox-content"> <div class="row">
<div class="col-sm-12">
<input id="txt_UserName_R" name="txt_UserName_R" class="form-control" type="text" placeholder="用户名">
</div>
</div>
<!--主列表信息 开始-->
<div class="ibox-content-details">
<table id="tableRoleUser_R" class="table table-bordered table-striped table-hover" cellspacing="0" width="100%"></table>
</div>
<!--主列表信息 结束-->
</div>
</div>
</div> </div>
@Scripts.Render("~/jQuery/jquery-2.1.1.min.js")
@Scripts.Render("~/Bootstrap/js/bootstrap.min.js")
@Scripts.Render("~/Bootstrap/js/plugins/bootstrap-datetimepicker/bootstrap-datetimepicker.js")
@Scripts.Render("~/Bootstrap/js/plugins/bootstrap-datetimepicker/locales/bootstrap-datetimepicker.zh-CN.js")
@Scripts.Render("~/Bootstrap/js/plugins/bootstrap-validator/bootstrap-validator.js")
@Scripts.Render("~/Bootstrap/js/plugins/bootstrap-treeview/bootstrap-treeview.js")
@Scripts.Render("~/Bootstrap/js/plugins/bootstrap-table/bootstrap-table.min.js")
@Scripts.Render("~/Bootstrap/js/plugins/bootstrap-table/locale/bootstrap-table-zh-CN.min.js")
@Scripts.Render("~/Bootstrap/js/plugins/bootstrap-jquery-confirm/jquery-confirm.js")
@Scripts.Render("~/Bootstrap/js/plugins/bootstrap-layer/2.1/layer.js")
@Scripts.Render("~/Bootstrap/js/bc.platform.js") <script type="text/javascript"> var RoleName; var GroupId = 0; var RoleId = 0;
//加载树数据
function LoadingTreeGroupRole() {
//"[{\"id\":\"1\",\"text\":\"北京angbcc公司\",\"href\":\"北京angbcc公司\",\"tags\":\"0\"},{\"id\":\"9\",\"text\":\"北京bngbcc公司\",\"href\":\"北京bngbcc公司\",\"tags\":\"0\"}]"
//同步获取
$.ajax({
type: 'GET',
url: '/RoleUser/GetGroupRoleTreeList',
async: false,//同步
dataType: 'json',
success: function (json) { data = eval('(' + json + ')'); $('#treeGroupRole').treeview({
data: data,
onNodeSelected: function (event, node) {
$('#selectable-output').prepend('<p>' + node.href + "-" + node.text + ' was selected</p>'); var strhref = node.href;
GroupId = strhref.split('-')[0];
RoleId = strhref.split('-')[1];
RoleName = node.text;
$("#lblRoleName").html(RoleName);
$('#tableRoleUser_L').bootstrapTable('refresh'); },
onNodeUnselected: function (event, node) {
// $('#selectable-output').prepend('<p>' + node.text + ' was unselected</p>');
}
}); },
error: function (xhr, status, error) {
alert("操作失败"); //xhr.responseText
}
});
} function LoadingDataList_L() {
$('#tableRoleUser_L').bootstrapTable({
url: '/RoleUser/GetRoleUserList',
method: 'get', //默认是post,不允许对静态文件访问
cache: false,
striped: true, // 隔行加亮
pagination: true, // 开启分页功能
pageSize: 20, // 设置默认分页为 20
pageNumber: 1,
pageList: [10, 25, 50, 100, 200], // 自定义分页列表
//contentType: "application/x-www-form-urlencoded",//如果想用request.form 方式,设置 contentType: "application/x-www-form-urlencoded",
search: false,//开启搜索功能
sidePagination: 'server',//设置为服务器端分页
queryParamsType: "",
queryParams: queryParams_L,//参数
showColumns: false, // 开启自定义列显示功能
showRefresh: false, // 开启刷新功能
minimumCountColumns: 2,// 设置最少显示列个数
clickToSelect: true,
smartDisplay: true,
clickToSelect: true, // 单击行即可以选中
sortName: 'Row_NumberId', // 设置默认排序为 name
sortOrder: 'desc', // 设置排序为反序 desc
smartDisplay: true, // 智能显示 pagination 和 cardview 等
dataType: "json",
columns: [{
field: 'checked',
checkbox: true,
formatter: stateFormatter_L,
align: 'left',
}, {
field: 'Row_NumberId',
title: '序号',
align: 'left',
}, {
field: 'UserName',
title: '账户',
align: 'left',
}, {
field: 'FullName_C',
title: '姓名',
align: 'left',
},{
field: 'RoleName',
title: '角色',
align: 'left',
}
]
});
}
//设置传入参数
function queryParams_L(params) {
var temp = { //这里的键的名字和控制器的变量名必须一直,这边改动,控制器也需要改成一样的
limit: params.pageSize,
page: params.pageNumber,
RoleId: RoleId,
GroupId: GroupId,
};
return temp;
} /**
* 复选按钮默认选中 格式化
*/
function stateFormatter_L(value, row, index) {
if (row.state == true)
return {
disabled: true,//设置是否可用
checked: true//设置选中
};
return value;
} function LoadingDataList_R() {
$('#tableRoleUser_R').bootstrapTable({
url: '/Users/GetUsersList',
method: 'get', //默认是post,不允许对静态文件访问
cache: false,
striped: true, // 隔行加亮
pagination: true, // 开启分页功能
pageSize: 20, // 设置默认分页为 20
pageNumber: 1,
pageList: [10, 25, 50, 100, 200], // 自定义分页列表
//contentType: "application/x-www-form-urlencoded",//如果想用request.form 方式,设置 contentType: "application/x-www-form-urlencoded",
search: false,//开启搜索功能
sidePagination: 'server',//设置为服务器端分页
queryParamsType: "",
queryParams: queryParams_L,//参数
showColumns: false, // 开启自定义列显示功能
showRefresh: false, // 开启刷新功能
minimumCountColumns: 2,// 设置最少显示列个数
clickToSelect: true,
smartDisplay: true,
clickToSelect: true, // 单击行即可以选中
sortName: 'Row_NumberId', // 设置默认排序为 name
sortOrder: 'desc', // 设置排序为反序 desc
smartDisplay: true, // 智能显示 pagination 和 cardview 等
dataType: "json",
columns: [{
field: 'checked',
checkbox: true,
formatter: stateFormatter_R,
align: 'left',
}, {
field: 'Row_NumberId',
title: '序号',
align: 'left',
}, {
field: 'UserName',
title: '账户',
align: 'left',
}, {
field: 'FullName_C',
title: '姓名',
align: 'left',
}, {
field: 'OrganizationName',
title: '结构名称',
align: 'left',
}]
});
} //设置传入参数
function queryParams_R(params) {
var temp = { //这里的键的名字和控制器的变量名必须一直,这边改动,控制器也需要改成一样的 limit: params.pageSize,
page: params.pageNumber, UserName: $("#txt_UserName_R").val()
};
return temp;
}
/**
* 复选按钮默认选中 格式化
*/
function stateFormatter_R(value, row, index) {
if (row.state == true)
return {
disabled: true,//设置是否可用
checked: true//设置选中
};
return value;
} </script> <script type="text/javascript"> $(function () {
LoadingTreeGroupRole(); LoadingDataList_L(); LoadingDataList_R();
$('#btnRefresh').click(function () {
LoadingTreeGroupRole();
}) //查询
$('#btn_search_L').click(function () {
$('#tableRoleUser_L').bootstrapTable('refresh')
}); $('#txt_UserName_L').keyup(function (e) {
if (e.keyCode === 13) {
$('#tableRoleUser_L').bootstrapTable('refresh')
}
}); //查询
$('#btn_search_R').click(function () {
$('#tableRoleUser_R').bootstrapTable('refresh')
}); $('#txt_UserName_R').keyup(function (e) {
if (e.keyCode === 13) {
$('#tableRoleUser_R').bootstrapTable('refresh')
}
});
}); </script> <script type="text/javascript"> //将右边的数据移动到左边
$('#btnLeft').click(function () {
var selectContent = $('#tableRoleUser_R').bootstrapTable('getSelections');
$('#tableRoleUser_L').bootstrapTable("append", selectContent);
var selects = $('#tableRoleUser_R').bootstrapTable('getSelections'); UserId = $.map(selects, function (row) {
return row.UserId;
}); UserName = $.map(selects, function (row) {
return row.UserName;
}); FullName_C = $.map(selects, function (row) {
return row.FullName_C;
});
$('#tableRoleUser_R').bootstrapTable('remove', {
field: 'UserId',
values: UserId
}, { field: 'UserName',
values: UserName
}, { field: 'FullName_C',
values: FullName_C
});
}); //将左边的数据移动到右边
$('#btnRight').click(function () {
var selectContent = $('#tableRoleUser_L').bootstrapTable('getSelections');
$('#tableRoleUser_R').bootstrapTable("append", selectContent);
var selects = $('#tableRoleUser_L').bootstrapTable('getSelections'); UserId = $.map(selects, function (row) {
return row.UserId;
}); UserName = $.map(selects, function (row) {
return row.UserName;
}); FullName_C = $.map(selects, function (row) {
return row.FullName_C;
}); $('#tableRoleUser_L').bootstrapTable('remove', {
field: 'UserId',
values: UserId
}, { field: 'UserName',
values: UserName
}, { field: 'FullName_C',
values: FullName_C
}); $('#tableRoleUser_R').bootstrapTable('refresh')
}); //保存数据
$('#btn_save_L').click(function () {
var selects = $('#tableRoleUser_L').bootstrapTable('getSelections'); UserId = $.map(selects, function (row) {
return row.UserId;
}); FullName_C = $.map(selects, function (row) {
return row.FullName_C;
}); var strUserId = "";
for (var i = 0; i < UserId.length; i++) {
strUserId += UserId[i] + ',';
}
var strFullName_C = "";
for (var i = 0; i < FullName_C.length; i++) {
strFullName_C += FullName_C[i] + ',';
} strUserId = strUserId.substring(0, strUserId.length - 1);
strFullName_C = strFullName_C.substring(0, strFullName_C.length - 1); if (GroupId == 0 && RoleId == 0) { layer.alert('请在左侧选择角色', { icon: 6 }); } else if (UserId == "") {
layer.alert('请在右侧选择用户', { icon: 6 });
}
else {
var _json = jQuery.param({
"GroupId": GroupId,
"RoleId": RoleId,
"UserId": strUserId
});//这是参数 $.confirm({
title: '温馨提示',
content: '确定要将【' + strFullName_C + '】保存到角色【' + $("#lblRoleName").html() + '】吗?',
confirmButton: '确定',
cancelButton: '关闭',
confirm: function () {
$.ajax({
url: '/RoleUser/InsertRoleUser',
type: 'post',
async: false,
data: _json,
dataType: 'json',
cache: false,
success: function (result) {
$('#tableRoleUser_L').bootstrapTable('refresh')
}
})
},
cancel: function () {
}
});
}
}); //删除数据
$('#btn_delete_L').click(function () {
var selects = $('#tableRoleUser_L').bootstrapTable('getSelections'); RoleUserId = $.map(selects, function (row) {
return row.RoleUserId;
}); FullName_C = $.map(selects, function (row) {
return row.FullName_C;
}); var strRoleUserId = "";
for (var i = 0; i < RoleUserId.length; i++) {
strRoleUserId += RoleUserId[i] + ',';
}
var strFullName_C = "";
for (var i = 0; i < FullName_C.length; i++) {
strFullName_C += FullName_C[i] + ',';
} strRoleUserId = strRoleUserId.substring(0, strRoleUserId.length - 1);
strFullName_C = strFullName_C.substring(0, strFullName_C.length - 1); if (GroupId == 0 && RoleId == 0) { layer.alert('请在左侧选择角色', { icon: 6 }); } else if (RoleUserId == "") { layer.alert('请选择要删除用户', { icon: 6 }); } else {
$.confirm({
title: '温馨提示',
content: '确定要将【' + strFullName_C + '】从角色【' + $("#lblRoleName").html() + '】移除吗?',
confirmButton: '确定',
cancelButton: '关闭',
confirm: function () { var _json = jQuery.param({
"GroupId": GroupId,
"RoleId": RoleId,
"RoleUserId": strRoleUserId
});//这是参数 $.ajax({
url: '/RoleUser/DeleteRoleUserByRoleUserId',
type: 'post',
async: false,
data: _json,
dataType: 'json',
cache: false,
success: function (result) {
$('#tableRoleUser_L').bootstrapTable('refresh')
}
})
},
cancel: function () {
}
});
}
}); </script>
</body>
</html>
MVC bootstrap 实现 bootstrap table 左右传递数据的更多相关文章
- ASP.NET MVC 5 学习教程:控制器传递数据给视图
原文 ASP.NET MVC 5 学习教程:控制器传递数据给视图 起飞网 ASP.NET MVC 5 学习教程目录: 添加控制器 添加视图 修改视图和布局页 控制器传递数据给视图 添加模型 创建连接字 ...
- 【ASP.NET MVC】View与Controller之间传递数据
1 概述 本篇文章主要从操作上简要分析Controller<=>View之间相互传值,关于页面之间传值,如果感兴趣,可参考我另外一篇文章ASP.NET 页面之间传值的几种方式 . Co ...
- MVC中前台如何向后台传递数据------$.get(),$post(),$ajax(),$.getJSON()总结
一.引言 MVC中view向controller传递数据的时候真心是一个挺让人头疼的一件事情.因为原理不是很懂只看一写Dome,按葫芦画瓢只能理解三分吧. 二.解读Jquery个Ajax函数 $.ge ...
- ASP.NET MVC 学习2、从Controller传递数据到View
参考:http://www.asp.net/mvc/tutorials/mvc-4/getting-started-with-aspnet-mvc4/adding-a-view 一,Control ...
- 【MVC】MvcPager分页及边界传递数据示例
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.We ...
- MVC Controller向View传递数据
ASP.NET MVC中,Controller向View传递数据的方式有一下6种 ViewData ViewBag PartialView TempData ViewModel Tuple 1.Vie ...
- 在ASP.NET MVC中使用 Bootstrap table插件
Bootstrap table: http://bootstrap-table.wenzhixin.net.cn/zh-cn/getting-started/ 1. 控制器代码: using Syst ...
- 【ASP.NET MVC系列】浅谈ASP.NET MVC 视图与控制器传递数据
ASP.NET MVC系列文章 [01]浅谈Google Chrome浏览器(理论篇) [02]浅谈Google Chrome浏览器(操作篇)(上) [03]浅谈Google Chrome浏览器(操作 ...
- table实现 js数据访问 传递json数据用render_to_response
$(document).ready(function(){ $.ajax({ url:'/query/', dataType:'json', type:'GET', success:function( ...
随机推荐
- SQL Server常用函数汇总
1.day(date) 用途:获取日期是所在月的几号 参数:date是一个可以解析为 time.date.smalldatetime.datetime.datetime2 或 datetime ...
- python基础之类的进阶
一.__setitem__,__getitem,__delitem__ #把对象操作属性模拟成字典的格式 class Foo: def __init__(self,name): self.name=n ...
- Java 连接池的工作原理(转)
原文:Java 连接池的工作原理 什么是连接? 连接,是我们的编程语言与数据库交互的一种方式.我们经常会听到这么一句话“数据库连接很昂贵“. 有人接受这种说法,却不知道它的真正含义.因此,下面我将解释 ...
- Linux运维工程师:30道面试题整理
1.linux 如何挂在 windows 下的共享目录 mount.cifs //192.168.1.3/server /mnt/server -o user=administrator,pass=1 ...
- Android学习八---OpenCV JAVA API
OpenCV java API的文档说明在OpenCV-2.4.10-android-sdk/sdk/java/javadoc/index.html的文件夹下. 想用java API的方式进行Open ...
- mysql-xtrabackup
使用xtrabackup进行MySQL数据库备份 2013年10月04日 ⁄ MySQL ⁄ 共 11306字 ⁄ 使用xtrabackup进行MySQL数据库备份已关闭评论 ⁄ 被围观 34,116 ...
- Hadoop家族学习路线图-张丹老师
前言 使用Hadoop已经有一段时间了,从开始的迷茫,到各种的尝试,到现在组合应用….慢慢地涉及到数据处理的事情,已经离不开hadoop了.Hadoop在大数据领域的成功,更引发了它本身的加速发展.现 ...
- 数据结构&算法(一)_堆、栈(堆栈)、队列、链表
堆: ①堆通常是一个可以被看做一棵树的数组对象.堆总是满足下列性质: ·堆中某个节点的值总是不大于或不小于其父节点的值: ·堆总是一棵完全二叉树.将根节点最大的堆叫做最大堆或大根堆,根节点最小的堆叫做 ...
- HandlerSocket ---MySQL与NoSQL ---SQL与NoSQL的融合(转)
项目地址:https://github.com/ahiguti/HandlerSocket-Plugin-for-MySQL 写这一篇内容的原因是MySQL5.6.2突然推出了memcached的功能 ...
- Python读写改Excel的方法
(注:本文部分内容摘自互联网,由于作者水平有限,不足之处,还望留言指正.) 面对疾风吧. 回首往昔,更进一步. 且随疾风前行,身后一许流星. 正文: 数据处理是Python的一大应用场景,而 Exce ...