layui表格内可编辑下拉框
表格内可编辑下拉框扩展自别人的表格内下拉框
一、列模板,这是列配置的templet字段需要使用的。
1.inputdiv,输入框覆盖在下拉框上面左半部。这个样式用来调整输入框和下拉框不会超出单元格。
2.method,和该列字段名一致
3.z-filter,只要有这个属性就够了,没有判断值
4.tb,layui表格的名字,和表格lay-filter一致
<script type="text/html" id="selectTpl">
<div class="inputdiv">
<input class="layui-input" name="method" z-filter="input" data-tableName="tb" style="position:absolute;z-index:2;width:calc(100% - 30px);" />
<select name="mehtod" lay-filter="select" data-tableName="tb" class="layui-border">
<option value=""></option>
<option value="更换">更换</option>
<option value="维修">维修</option>
</select>
</div>
</script>
二、样式。主要是别人写的,由于我在select外有加了一层div,因此这两个元素样式有所改动
/* 防止下拉框的下拉列表被隐藏*/
.layui-table-cell {
/*overflow: visible !important;*/
} .layui-table-box {
overflow: visible;
} .layui-table-body {
overflow: auto;
} /* 使得下拉框与单元格刚好合适 */
td .layui-form-select {
margin-top: -10px;
margin-left: -15px;
margin-right: -15px;
}
td .inputdiv>input {
margin-left: -15px;
} .layui-form-selected .layui-anim {
bottom: auto;
}
三、表格列配置
{
field: 'method', title: '类别', templet: (d) => {
var temp = $($("#selectTpl").html());
temp.find("select").attr("data-value", d.method)//给下拉框赋值
temp.find("input").attr("value", d.method);//给输入框赋值
return temp[0].outerHTML;
}
}
三、回调。第一个回调时layui的select的回调,第二个是我自定义的输入框回调,在回调中更新表格缓存数据。这些代码与具体表格无关,没有其他要求不需要更改。
//选择下拉框
form.on("select(select)", function (obj) {
var elem = $(obj.elem);
var trElem = elem.parents('tr');
var tableName = elem.attr("data-tableName");
var tableData = table.cache[tableName];
$(elem.prev("input")).val(obj.value)
tableData[trElem.data('index')][elem.attr('name')] = obj.value;
console.log(table.cache);
})
//通过事件冒泡监听z-filter元素的change事件
document.onchange = function (e) {
if (e.target.getAttribute("z-filter") == null) {
return;
}
var tableName = e.target.getAttribute("data-tableName");//使用触发元素判断所属表格
var elem = $(e.target);
var trElem = elem.parents('tr');
var tableData = table.cache[tableName];
tableData[trElem.data('index')][elem.attr('name')] = elem.val();//使用触发元素的name属性判断字段
console.log(table.cache);
};
layui表格内可编辑下拉框的更多相关文章
- jquery.editable-select 可编辑下拉框之获取select值和input值
使用jquery.editable-select可以实现可编辑下拉框的功能,但需要先导入jquery.js,jquery.editable-select.css,jquery.editable-sel ...
- bootstrap 的可编辑下拉框 jquery.editable-select
搜了半天发现在某处下载jquery.editable-select需要积分,于是整理出来方便 其他人. 先上下载链接:http://pan.baidu.com/s/1kUXvwlL pass ...
- bootstrap可编辑下拉框jquery.editable-select
搜了半天发现在某处下载jquery.editable-select需要积分,于是整理出来方便 其他人. 先上下载链接: http://pan.baidu.com/s/1kUXvwlL pas ...
- jQuery打造智能提示插件二(可编辑下拉框)
在上一篇 jQuery打造智能提示插件 上改进,增加下拉按钮,修复点击下拉区域外不隐藏BUG 效果 下拉按钮素材: js封装,注意红色部分为BUG修复,然后传入boxwidth不带px: /* /// ...
- HTML可编辑下拉框
<div style="position:relative;"> <select style="width:120px;" onchang ...
- layui修改数据的时候下拉框和选择框默认选中
// 获取需求类型function getType() { var typeHtml = ''; $.ajax({ url: pUrl + 'back_findTypeList.do', type: ...
- 【Layui】Layui模板引擎生成下拉框不显示
首先让我震惊了一下,layui引擎模板居然是支持ajax操作的 博主的需求是需要在数据表格内放入下拉框而下拉框的数据是数据库内查出来的(详见上一篇博客),但是下拉框怎么也显示不出来 找了四个小时的问题 ...
- layui下拉框渲染问题,以及回显问题
最近实习公司给的新人练手项目用的layui,layui之前自己也接触过但是也就是用了用table组件,没有用过layer弹层这些东西,所以就了解了一下. 首先遇到的一个问题就是下拉框没有样式,然后加样 ...
- LayuI 动态下拉框和动态设置选中
动态下拉框 //下拉框异步加载 function asyncSelect(thisId, grade, selectNodeName) { $("#" + selectNodeNa ...
- html 可编辑的下拉框
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
随机推荐
- 【FAQ】关于无法判断和区分用户与地图交互手势类型的解决办法
一. 问题描述 当用户通过缩放手势.平移手势.倾斜手势和旋转手势与地图交互,控制地图移动改变其可见区域时,华为地图SDK没有提供直接获取用户手势类型的API. 二. 解决方案 华为地图SDK的地图相机 ...
- Qt 设置图标的三种方式
Qt 设置软件窗口图标有三种方式: 一.通过资源文件,设置图标 this->setWindowIcon(QIcon(":/logo.ico")); 二.通过 pro 文件,设 ...
- js复制文字到剪切板
此方法仅适用于 IE demo <!DOCTYPE html> <html lang="en"> <head> <meta charset ...
- HDC2021技术分论坛:HarmonyOS本地模拟器重磅来袭!
作者:longjiangyun,模拟器开发工程师 HarmonyOS模拟器是应用开发者使用IDE进行代码开发.调试.测试等活动中必不可少的工具,它分为本地模拟器和远程模拟器,其中远程模拟器又分为单设备 ...
- 结构化数据上的 TopN 运算
1. 最大值 / 最小值 最大值 / 最小值可以理解为 TopN 查询中,N 等于 1 时的情况,因为很常用所以单独拿出来讲一下.取最大值 / 最小值是很常见的需求,例如一班数学最高分是多少, ...
- mysql 悲观锁和乐观锁(二)
前言 简单介绍一下,在mysql 优化系列中会重新介绍,仅仅是留个印象. 悲观锁和乐观锁其实都是概念性问题. 正文 悲观锁: 悲观锁,正如其名,具有强烈的独占和排他特性. 它指的是对数据被外界(包括本 ...
- 一个.NET内置依赖注入的小型强化版
前言 .NET生态中有许多依赖注入容器.在大多数情况下,微软提供的内置容器在易用性和性能方面都非常优秀.外加ASP.NET Core默认使用内置容器,使用很方便. 但是笔者在使用中一直有一个头疼的问题 ...
- 解决跨域问题之fetch的使用
一.介绍 fetch 提供了一个获取资源的接口 (包括跨域). fetch 的核心主要包括:Request , Response , Header , Body 利用了请求的异步特性 --- 它是基于 ...
- 【Oracle】year must be between -4713 and +9999,and not be 0
[Oracle]year must be between -4713 and +9999,and not be 0 year must be between -4713 and +9999,and n ...
- 龙蜥开源Plugsched:首次实现 Linux kernel 调度器热升级 | 龙蜥技术
简介:对于plugsched而言,无论是 bugfix,还是性能优化,甚至是特性的增.删.改,都可胜任. 文/龙蜥社区内核开发人员 陈善佩.吴一昊.邓二伟 Plugsched 是 Linux 内 ...