表格内可编辑下拉框扩展自别人的表格内下拉框

一、列模板,这是列配置的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表格内可编辑下拉框的更多相关文章

  1. jquery.editable-select 可编辑下拉框之获取select值和input值

    使用jquery.editable-select可以实现可编辑下拉框的功能,但需要先导入jquery.js,jquery.editable-select.css,jquery.editable-sel ...

  2. bootstrap 的可编辑下拉框 jquery.editable-select

    搜了半天发现在某处下载jquery.editable-select需要积分,于是整理出来方便 其他人. 先上下载链接:http://pan.baidu.com/s/1kUXvwlL      pass ...

  3. bootstrap可编辑下拉框jquery.editable-select

    搜了半天发现在某处下载jquery.editable-select需要积分,于是整理出来方便 其他人. 先上下载链接: http://pan.baidu.com/s/1kUXvwlL      pas ...

  4. jQuery打造智能提示插件二(可编辑下拉框)

    在上一篇 jQuery打造智能提示插件 上改进,增加下拉按钮,修复点击下拉区域外不隐藏BUG 效果 下拉按钮素材: js封装,注意红色部分为BUG修复,然后传入boxwidth不带px: /* /// ...

  5. HTML可编辑下拉框

    <div style="position:relative;">   <select style="width:120px;" onchang ...

  6. layui修改数据的时候下拉框和选择框默认选中

    // 获取需求类型function getType() { var typeHtml = ''; $.ajax({ url: pUrl + 'back_findTypeList.do', type: ...

  7. 【Layui】Layui模板引擎生成下拉框不显示

    首先让我震惊了一下,layui引擎模板居然是支持ajax操作的 博主的需求是需要在数据表格内放入下拉框而下拉框的数据是数据库内查出来的(详见上一篇博客),但是下拉框怎么也显示不出来 找了四个小时的问题 ...

  8. layui下拉框渲染问题,以及回显问题

    最近实习公司给的新人练手项目用的layui,layui之前自己也接触过但是也就是用了用table组件,没有用过layer弹层这些东西,所以就了解了一下. 首先遇到的一个问题就是下拉框没有样式,然后加样 ...

  9. LayuI 动态下拉框和动态设置选中

    动态下拉框 //下拉框异步加载 function asyncSelect(thisId, grade, selectNodeName) { $("#" + selectNodeNa ...

  10. html 可编辑的下拉框

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

随机推荐

  1. 记录C++,base64解码写PDF文件遇到的坑

    不得不bb一下, 场景:用户传base64数据,我生成PDF文件保存到指定路径下 背景:在前人写好的工程上增加这个功能,工程中有base64的.h, .cpp 文件,我试了base64编码没有问题,所 ...

  2. vs报错:RC1004 unexpected end of file found

    如图,在编译代码时,出现报错:RC1004  unexpected end of file found 原因是,cpp最后要多一行才行,不然就会报这个错误 错误示例: int main() { ret ...

  3. Linux-主机之间创建免密

    一.四台主机进行免密 192.168.10.6 192.168.10.11 192.168.10.12 192.168.10.13 二.192.168.10.6主机生成密钥对,并将公钥传输到其它所有主 ...

  4. 一个简单的开源消息中间件 FolkMQ v1.4.2 发布

    功能简表 角色 功能 生产者(客户端) 发布消息.定时消息(或叫延时).顺序消息.可过期消息.事务消息.支持 Qos0.Qos1 消费者(客户端) 订阅.取消订阅.消费-ACK(自动.手动) 服务端 ...

  5. szfpga Lattice高速下载器HW-USBN-2B 常见问题解答

    .产品特点 1). 支持windows7,Windows10 操作系统,两个操作系统非常稳定不断线. 2). 支持JTAG 模式,速度快,最高30Mb/s,调试serdes core,不会像hw-us ...

  6. 最简编译CockroachDB 21.2

    编译CockroachDB比较麻烦,尤其是从git下载代码编译还需要关联项目的下载,本文整理从官网下载代码的编译过程,非常简单,几乎没有异常,供大家参考. 编译CockroachDB 21.2 1.安 ...

  7. WebRTC获取IP地址问题,Uncaught TypeError: Cannot read property '1' of null

    WebRTC获取IP地址问题,Uncaught TypeError: Cannot read property '1' of null 临时接了个任务,客户要求某个账号只能在某个ip或者mac上登录, ...

  8. 【笔记】go语言--(Slice)切片的概念

    go--(Slice)切片的概念 //切片是什么,定义一个arr,定义一个s为arr中的2到6,这个s就是一个切片 arr := [...]int{0,1,2,3,4,5,6,7} s := arr[ ...

  9. 牛客网-SQL专项训练16

    ①在book表中,将工具书类型(tool)的书的书架序号都减少2,下列语句正确的是(C) 解析: 题目要求的批量更改,insert 是更改数据,排除B,update与set搭配使用,排除选项D,whe ...

  10. 第3章 python 爬虫抓包与数据解析

    第 3章 Python 爬虫抓包与数据解析 3.1 抓包进阶 目前,我们已经会使用 Chrome 浏览器自带的开发者工具来抓取访问网页的数据包,但是这种抓包方法有局限性,比如只能监听一个浏览器选项卡, ...