首页 > 开发 > JS > 正文

layui问题之模拟select点击事件的实例讲解

2024-05-06 16:45:41
字体:
来源:转载
供稿:网友

一、问题

不操作页面,实现模拟select的事件,即,自动出现下拉框,自动点击下拉框的值,select文本框的值随之改变

二、经过

刚开始查看layui官方文档,发现仅仅只是有select监听事件,即:

form.on('select(filter)', function(data){ console.log(data.elem); //得到select原始DOM对象 console.log(data.value); //得到被选中的值});

但是,这个事件需要操作页面,不可取。

三、结果

查看layui源码,关于select事件的实现,在form.js中,看实现的原理。自动触发select点击原理就是:

1、找到当前select的下一个div.layui-select-title节点的子元素,即input或者i,实现点击事件。

2、上一步骤完了之后,出现下拉框,但是下拉框还没有点击事件;需要再实现你想让下拉框里面的哪个值有点击事件。此时,需要通过select找到下拉框dl里面的dd的具体的值,然后实现点击事件。

这样就完整的实现了模拟select点击事件。

源码:

<!-- HTML --><select name="modules" lay-verify="required" lay-search="">            <option value="">直接选择或搜索选择</option>            <option value="1">layer</option>            <option value="2">form</option>            <option value="3">layim</option>          </select>
// JS:$('select[name="modules"]').next().find('.layui-select-title input').click();$('select[name="modules"]').next().find('.layui-anim').children('dd[lay-value="20"]').click();

虽然实现了效果,实际上看不出来效果,加一个延迟就可以了:

// 优化后的js$('select[name="modules"]').next().find('.layui-select-title input').click();// 延迟3s再实现自动点击下拉框事件setTimeout(function () {          $('select[name="modules"]').next().find('.layui-anim').children('dd[lay-value="20"]').click();},3000);

以上这篇layui问题之模拟select点击事件的实例讲解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持VeVb武林网。


注:相关教程知识阅读请移步到JavaScript/Ajax教程频道。
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表