博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
layui问题之模拟select点击事件
阅读量:4553 次
发布时间:2019-06-08

本文共 1151 字,大约阅读时间需要 3 分钟。

一、问题

不操作页面,实现模拟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点击事件。
源码:

// 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);

 

转载于:https://www.cnblogs.com/jiangxiaobo/p/10818436.html

你可能感兴趣的文章
max9526——PAL/NTSC解码芯片
查看>>
基于opencv和mfc的摄像头采集代码(GOMFCTemplate2)持续更新
查看>>
android开发_LayerlistDrawable(层叠图片)在进度条中的应用
查看>>
Deep Learning阅读资料
查看>>
跟着underscore学防抖
查看>>
SQL语句练习手册--第三篇
查看>>
js函数表达式和函数声明的区别
查看>>
几个简单的例子让你读懂什么是JAVA的堆栈跟踪
查看>>
Jam的计数法
查看>>
Java equals 方法与hashcode 方法的深入解析
查看>>
package ‘CancerSubtypes’ is not available
查看>>
C# 安装部署
查看>>
js,jquery点击复制到剪贴板插件clipboard.js的使用
查看>>
jupyter notebook 目录配置、导出 tex 和 pdf 及中文支持
查看>>
JVM CMS 常用参数配置(修订)
查看>>
线程池
查看>>
SpringBoot之旅第四篇-web开发
查看>>
iOS开发之下拉刷新和上拉加载更多
查看>>
包装类
查看>>
对于范式的理解
查看>>