layui动态绑定事件的方法


Posted in Javascript onSeptember 20, 2019

Tips:很多前端新手会遇到动态创建DOM(html片段)的场景,原来的点击事件无法生效。以及成熟的layui框架动态创建DOM(html片段)不知道如何解决,接下来为大家解释其实现的原理,是主要是通过es6的写法。

一、常规动态创建DOM(html片段)

<!--.html代码片段-->
<!--按钮-->
<button class="data-set" type="button">添加</button>
<!--动态创建的位置-->
<div class="setBox" data-uid="setBox"></div>

<!--jQ代码片段-->
 $(function(){//初始化
  var setBox=$('.setBox');//获取动态添加对象
  $('.data-set').on('click',function () {

    var _html3=`
    <div class="info"> <admin:text  value=""     class="timeInterval" /> <span class="del"> 删除</span> </div>
    `;//此处用es6的方式拼接需要动态创建的代码(模板)
    setBox.append(_html3);//append方法将_html3动态添加到setBox内
    //$('.timeInterval').focus();//聚焦(如果是layui框架会有小bug,用户要先失去焦点再点一次才能调用layui方法)
   });

  $('body').on('click','.del',function () {//事件委托,请看下方注释
    $(this).parents('.info').hide();//模拟前端删除按钮
   });
 })

Tips:事件委托就是利用事件冒泡,只指定一个事件处理程序,就可以管理某一类型的所有事件。这也是解决动态创建HTML片段点击事件无法生效的原因。body是父级,即DOM本就存在的对象,但是考虑到兼容性,移动端IOS不支持body作为事件绑定的对象,本文的解决方案是将body改为.setBox即可完美实现事件委托。

效果图如下:

layui动态绑定事件的方法

Tips:绿色框内为初始状态,红色框内为点击添加后实现的模型

二、layui动态绑定事件

1.框架的引入和实例化

自行引入layui.css和layui.js,初始化或者实例化laydate,如果没有这些操作可是会报错的哦。

layui.use('laydate', function(){
  var laydate = layui.laydate;
})

2.html代码片段

<b>禁止交易时间点击日历增加</b>
<!--按钮-->
<p class="data-stop">添加</p>
<!--动态创建的位置-->
<div class="stopBox"></div>

tips:此处的p标签为按钮,样式自行修改

3.js代码片段

var stopBox=$('.stopBox');
  var test=0;//定义一个变量,用于动态创建类名
  $('.data-stop').on('click',function () {
   test=test+1;//防止类名重复
   var _html2=`<div class="info"><admin:text value="" len="250" class="stop${test}"/> <span class="del"> 删除</span></div>`;//(关键)此处用es6的方式拼接需要动态创建的代码(模板),若不是es6的写法$(test)无法识别,需要用“+test+”的方式去拼接。
 stopBox.append(_html2);//实现代码片段动态添加
  //(关键)执行一个laydate实例,如果不执行实例化,无法给动态添加的DOM节点绑定方法
  laydate.render({
   elem: '.stop'+test //指定元素,test为变量
  });
  //$('.stop'+test).focus();//建议不使用聚焦,否则用户体验感不佳
 });

  //交易时间删除按钮
  $('body').on('click','.del',function () {
   $(this).parents('.info').hide();//模拟删除
  });

效果图如下:

layui动态绑定事件的方法

layui动态绑定事件的方法

以上这篇layui动态绑定事件的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery each()小议
Mar 18 Javascript
js实现杯子倒水问题自动求解程序
Mar 25 Javascript
javascript自启动函数的问题探讨
Oct 05 Javascript
js中判断变量类型函数typeof的用法总结
Aug 09 Javascript
javascript实现复选框全选或反选
Feb 04 Javascript
[原创]js实现保存文本框内容为本地文件兼容IE,chrome,火狐浏览器
Feb 14 Javascript
vue源码学习之Object.defineProperty对象属性监听
May 30 Javascript
JS与jQuery实现ListBox上移,下移,左移,右移操作功能示例
May 31 jQuery
vue-cli3.0 脚手架搭建项目的过程详解
Oct 19 Javascript
微信小程序CSS3动画下拉菜单效果
Nov 04 Javascript
移动端滑动切换组件封装 vue-swiper-router实例详解
Nov 25 Javascript
在React中写一个Animation组件为组件进入和离开加上动画/过度效果
Jun 24 Javascript
利用JS代码自动删除稿件的普通弹幕功能
Sep 20 #Javascript
基于layui table返回的值的多级嵌套的解决方法
Sep 19 #Javascript
layui默认选中table的CheckBox复选框方法
Sep 19 #Javascript
layui 数据表格复选框实现单选功能的例子
Sep 19 #Javascript
基于layui的table插件进行复选框联动功能的实现方法
Sep 19 #Javascript
解决layui的table插件无法多层级获取json数据的问题
Sep 19 #Javascript
Layui数据表格 前后端json数据接收的方法
Sep 19 #Javascript
You might like
PHP5多态性与动态绑定介绍
2015/04/03 PHP
JavaScript的Cookies
2008/01/16 Javascript
javascript+xml技术实现分页浏览
2008/07/27 Javascript
效率高的Javscript字符串替换函数的benchmark
2008/08/02 Javascript
jquery下异步提交表单 异步跨域提交表单
2010/11/17 Javascript
JavaScript高级程序设计 阅读笔记(十七) js事件
2012/08/14 Javascript
JS 如何获取radio选中后的值及不选择取radio的值
2013/10/28 Javascript
深入分析原生JavaScript事件
2014/12/29 Javascript
你所不了解的javascript操作DOM的细节知识点(一)
2015/06/17 Javascript
javascript实现跨域的方法汇总
2015/06/25 Javascript
获取jqGrid中选择的行的数据
2016/11/30 Javascript
移动端脚本框架Hammer.js
2016/12/15 Javascript
详解win7 cmd执行vue不是内部命令的解决方法
2017/07/27 Javascript
深入理解React中何时使用箭头函数
2017/08/23 Javascript
深入浅析angular和vue还有jquery的区别
2018/08/13 jQuery
详解vue中的computed的this指向问题
2018/12/05 Javascript
node.js微信小程序配置消息推送的实现
2019/02/13 Javascript
JS在Array数组中按指定位置删除或添加元素对象方法示例
2019/11/19 Javascript
微信小程序实现日历签到
2020/09/21 Javascript
动感网页相册 python编写简单文件夹内图片浏览工具
2016/08/17 Python
linux安装python修改默认python版本方法
2019/03/31 Python
Tornado实现多进程/多线程的HTTP服务详解
2019/07/25 Python
PyTorch预训练的实现
2019/09/18 Python
详解通过HTML5 Canvas实现图片的平移及旋转变化的方法
2016/03/22 HTML / CSS
西班牙手机之家:Phone House
2018/10/18 全球购物
DeinDesign德国:设计自己的手机壳
2019/12/14 全球购物
EJB发布WEB服务一般步骤
2012/10/31 面试题
三好学生自我鉴定
2013/12/17 职场文书
企业项目策划书
2014/01/11 职场文书
员工拓展培训方案
2014/02/15 职场文书
贷款担保书范文
2014/05/13 职场文书
学校做一个有道德的人活动方案
2014/08/23 职场文书
2014年领班工作总结
2014/11/25 职场文书
员工辞职信范文大全
2015/05/12 职场文书
大国崛起英国观后感
2015/06/02 职场文书
范文之农村基层党建工作报告
2019/10/24 职场文书