Layui弹框中数据表格中可双击选择一条数据的实现


Posted in Javascript onMay 06, 2020

Layui提供的功能如下(预览)

可自行查看:layui官网此模块的链接
着急看双击选中 直接看标黄色部分

Layui弹框中数据表格中可双击选择一条数据的实现

假设这是个弹窗里的表格和数据点击圆圈,圆圈变绿则为选中,选中后点击上方查看数据按钮(实际中是确认按钮,实际中点击确认按钮后会关闭弹窗并把json串带到原本页面中)

Layui提供的代码如下(查看代码)

<body>
<!-- 表格空架子 -->
<table class="layui-hide" id="test" lay-filter="test"></table>
<!-- 确认(查看数据按钮) -->
<script type="text/html" id="toolbarDemo">
 <div class="layui-btn-container">
  <button class="layui-btn layui-btn-sm" lay-event="getCheckData">获取选中行数据</button>
 </div>
</script> 
<script src="//res.layui.com/layui/dist/layui.js" charset="utf-8"></script>
<!-- 注意:如果你直接复制所有代码到本地,上述js路径需要改成你本地的 --> 
<script>
	layui.use('table', function(){
	 var table = layui.table;
	 table.render({
	  elem: '#test'
	  ,url:'/demo/table/user/'
	  ,toolbar: '#toolbarDemo'
	  ,cols: [[
	   {type:'radio'}
	   ,{field:'id', width:80, title: 'ID', sort: true}
	   ,{field:'username', width:80, title: '用户名'}
	   ,{field:'sex', width:80, title: '性别', sort: true}
	   ,{field:'city', width:80, title: '城市'}
	   ,{field:'sign', title: '签名', minWidth: 100}
	   ,{field:'experience', width:80, title: '积分', sort: true}
	   ,{field:'score', width:80, title: '评分', sort: true}
	   ,{field:'classify', width:80, title: '职业'}
	   ,{field:'wealth', width:135, title: '财富', sort: true}
	  ]]
	  ,page: true
	 });
	 
	 //头工具栏事件
	 table.on('toolbar(test)', function(obj){
	  var checkStatus = table.checkStatus(obj.config.id); //获取选中行状态
	  switch(obj.event){
	   case 'getCheckData':
	    var data = checkStatus.data; //获取选中行数据
	    layer.alert(JSON.stringify(data));
	   break;
	  };
	 });
	});
</script>
</body>

实际需求实例

Layui弹框中数据表格中可双击选择一条数据的实现

  • 点击 【选择】 按钮,出现弹框
  • 弹框里有数据表格
  • 点击圆圈为选中当前条数据
  • 点击弹框中【确认】把选中条数据带到主页面

实际代码实例

主页面代码(底,都为自动带出的输入框)

静态部分

<div>
	<div>
		<span>客户姓名:</span>
			<form:input path="customerName" readonly="true"/>
		<span onclick="onclick()" title="选择">
			<input id="selectCustomer"	class="btn" type="button" value="选择" /></span>
	</div>
	<div>
		<span>客户性别:</span>
		<form:input path="customerSex" readonly="true"/>
	</div>
	<div>
		<span>客户年龄:</span>
		<form:input path="customerYears" readonly="true"/>
	</div>
</div>

【选择】按钮的弹窗事件

function onclick(){
 var width = window.screen.availWidth*0.8;
 var height = window.screen.availHeight*0.65;
 var iTop=(window.screen.availHeight-30-height)/2;
 var iLeft=(window.screen.availWidth-30-width)/2;
 var url="${xxx}/vvvv/rrrrr/getCustomerList"; //后端代码就不介绍了
 window.open(url,'客户信息','height='+height+',width='+width+',top='+iTop+',left='+iLeft+',
 toolbar=no,menubar=no,scrollbars=yes, resizable=yes,location=no, status=no')
}

弹窗页面代码

弹窗页面中?静态部分

<table id="contentTable" class="layui-table">
 	<thead>
 		<tr>
 			<th></th>
 			<th>客户姓名</th>
 			<th>客户性别</th>
 			<th>客户年龄</th>
 			<th>...</th>
 		</tr>
 	</thead>
 	<tbody>
 		<c:forEach items="${page.list}" var="customerMain">
 			<tr>
 				<td align="center"><input name="customerId" type="radio" value="${customerMain.id}"></td>
 				<td>${customerMain.customerName}</td>
 				<td>${customerMain.customerSex}</td>
 				<td>${customerMain.customerYears}</td>
 				<td class="hide" >${customerMain.....}</td>
 			</tr>
 		</c:forEach>
 	</tbody>
</table>

弹框页面上-- == 单击单选圆圈的事件+双击行选中 ==

$(document).ready(function() {
 	//双击行 即可执行函数(行数据被选中:radio为checked)
  	$("table tbody tr").dblclick(function(i) {
  		$(this).find("input[type='radio']").prop("checked", true)
  	});
  	//圆圈改变状态即可执行函数
  	$("#contentTable tbody tr input").change(function () {
    var ischecked = $(this).prop("checked");
    var index=$(this).parent().parent().index()
    var tr=$("#contentTable tbody tr")
    if(ischecked){
      for(var i=0;i<tr.length;i++){
        if(i!=index){
          $("#contentTable tbody tr:eq("+i+") input").prop("checked",!ischecked);
        }
      }
    }
  })
});

弹框页面上?选择好数据后带回主页面的函数

<script>
	//给弹框中【确认】按钮绑定事件
	function toSubmit(){
		//此方法在下方
		var data=getRowData();
		if(data==null){
			layer.alert("请先选择一位客户")
			return ;
		}
		window.opener.getCustomerData(data);//调用主页面上的方法,给主页面赋值,最下方有具体方法过程
		window.close();//关闭弹窗
	}
	//给弹框中【返回】按钮绑定事件
	function closed(){
		window.close();
	}

	//获取行对象
	function getRowData(){
		var row = null;
		//锁定行(循环遍历找到被选中的行)
		$("table tbody tr").each(function(){
			var radio = $(this).find("td").eq(0).find("input[type='radio']:checked").val();
			if(radio){
				row = $(this) ;
			}
		});
		//如果此行有数据则拼接
		if(row){
			var customerId = row.find("td").eq(0).find("input[type='radio']:checked").val();
			var customerName = row.find("td").eq(1).text();
			var customerSex = row.find("td").eq(2).text();
			var customerYears = row.find("td").eq(3).text();
			//拼接模板 $.trim() jQuery.trim()函数用于去除字符串两端的空白字符。该函数可以去除字符串开始和末尾两端的空白字符(直到遇到第一个非空白字符串为止)。它会清除包括换行符、空格、制表符等常见的空白字符。
			var data = "[{\"customerId\":\""+$.trim(customerId)
					  +"\",\"customerName\":\""+$.trim(customerName)
				    +"\",\"customerSex\":\""+$.trim(customerSex)
				    +"\",\"customerYears\":\""+$.trim(customerYears)
					  +"\"}]";
		}
		return data ;
	}
	
</script>

调用主页面上的给主页面赋值的方法

<script>
	function getCustomerData(data){
		var json = JSON.parse(data);
		$("#customerId").val(json[0].customerId);
	  $("#customerName").val(json[0].customerName);
	  $("#customerSex").val(json[0].customerSex);
	  $("#customerYears").val(json[0].customerYears);
	  ....
	}
</script>

到此这篇关于Layui弹框中数据表格中可双击选择一条数据的实现的文章就介绍到这了,更多相关Layui弹框双击数据内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Javascript 相关文章推荐
jQuery 自定义函数写法分享
Mar 30 Javascript
基于jquery创建的一个图片、视频缓冲的效果样式插件
Aug 28 Javascript
jQuery 绑定事件到动态创建的元素上的方法实例
Aug 18 Javascript
FireBug 调试JS入门教程 如何调试JS
Dec 23 Javascript
js由下向上不断上升冒气泡效果实例
May 07 Javascript
jquery图片轮播特效代码分享
Apr 20 Javascript
基于Bootstrap实现Material Design风格表单插件 附源码下载
Apr 18 Javascript
js实现颜色阶梯渐变效果(Gradient算法)
Mar 21 Javascript
利用node.js制作命令行工具方法教程(一)
Jun 22 Javascript
webpack结合express实现自动刷新的方法
May 07 Javascript
解决vue项目input输入框双向绑定数据不实时生效问题
Aug 05 Javascript
vue2实现provide inject传递响应式
May 21 Vue.js
Vue SSR 即时编译技术的实现
May 06 #Javascript
深入webpack打包原理及loader和plugin的实现
May 06 #Javascript
将Vue组件库更换为按需加载的方法步骤
May 06 #Javascript
让IDE识别webpack的别名alias的实现方法
May 06 #Javascript
JS 设计模式之:工厂模式定义与实现方法浅析
May 06 #Javascript
JS 设计模式之:单例模式定义与实现方法浅析
May 06 #Javascript
基于vue3.0.1beta搭建仿京东的电商H5项目
May 06 #Javascript
You might like
一个没有MYSQL数据库支持的简易留言本的编写
2006/10/09 PHP
快速开发一个PHP扩展图文教程
2008/12/12 PHP
PHP+SQL 注入攻击的技术实现以及预防办法
2010/12/29 PHP
Centos7 Yum安装PHP7.2流程教程详解
2019/07/02 PHP
PHP vsprintf()函数格式化字符串操作原理解析
2020/07/14 PHP
JavaScript语句可以不以;结尾的烦恼
2007/03/08 Javascript
jQuery动态添加的元素绑定事件处理函数代码
2011/08/02 Javascript
js语法学习之判断一个对象是否为数组
2014/05/13 Javascript
JS数组的常见用法实例
2015/02/10 Javascript
提交按钮的name='submit'引起的js失效问题及原因
2015/02/25 Javascript
微信小程序 弹幕功能简单实例
2017/02/14 Javascript
JavaScript canvas动画实现时钟效果
2020/02/10 Javascript
微信小程序淘宝首页双排图片布局排版代码(推荐)
2020/10/29 Javascript
[04:28]DOTA2亚洲邀请赛小组赛第五日 TOP10精彩集锦
2015/02/03 DOTA
[01:17:47]TNC vs VGJ.S 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
从零学python系列之教你如何根据图片生成字符画
2014/05/23 Python
Python random模块常用方法
2014/11/03 Python
Python HTMLParser模块解析html获取url实例
2015/04/08 Python
一些Python中的二维数组的操作方法
2015/05/02 Python
python中文件变化监控示例(watchdog)
2017/10/16 Python
用Python写王者荣耀刷金币脚本
2017/12/21 Python
Python生成器定义与简单用法实例分析
2018/04/30 Python
pandas.DataFrame选取/排除特定行的方法
2018/07/03 Python
基于python if 判断选择结构的实例详解
2019/05/06 Python
Python 实现加密过的PDF文件转WORD格式
2020/02/04 Python
用python写爬虫简单吗
2020/07/28 Python
CSS3中新增的对文本和字体的设置
2020/02/03 HTML / CSS
战友聚会策划方案
2014/06/13 职场文书
人力资源职位说明书
2014/07/29 职场文书
邀请函样本
2015/02/02 职场文书
2015年教师自我评价范文
2015/03/04 职场文书
2015年党员创先争优公开承诺书
2015/04/27 职场文书
2015年艾滋病防治工作总结
2015/05/22 职场文书
Windows环境下实现批量执行Sql文件
2021/10/05 SQL Server
Python学习之迭代器详解
2022/04/01 Python
Django + Taro 前后端分离项目实现企业微信登录功能
2022/04/07 Python