首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    【前端篇】对象强制性绑定事件

    在写js代码时,常常需要给某些对象绑定事件,但是前提是,对象绑定事件时,该对象必须已经渲染出来了,否则绑定事件肯定是无效的,但是在实际开发时,比如用到一些内部框架进行开发时,绑定事件在渲染之前就已经执行了...,且不方便修改,此时使用如下写法:保证绑定事件一定可以绑定到指定对象,不用考虑渲染先后: $document.on({},对象) 指的是将事件直接绑定在document上,每次document有点击动作...,浏览器都会判断当前点击的对象,如果匹配就执行。...如上在绑定三个事件时,class为yifang的对象还没有渲染出来,就无法绑定成功,使用上面方法将事件直接绑定到document上面,就可以实现class为yifang绑定上如上三个事件了。

    5810

    js对象拷贝方法

    ; 它不会拷贝对象的不可枚举的属性; 不可以拷贝对象中的对象; 可以拷贝 Symbol 类型的属性; 无法正确拷贝属性和属性 可以拷贝undefined/boolean/null/function/Date.../RegExp/array/array中的对象; 参考阮一峰文档: https://es6.ruanyifeng.com/#docs/object-methods#Object-assign 扩展运算符...这几种类型,经过 JSON.stringify 序列化之后的字符串中这个键值对会消失; 拷贝 Date 引用类型会变成字符串; 无法拷贝不可枚举的属性; 无法拷贝对象的原型链; 拷贝 RegExp 引用类型会变成空对象...; 对象中含有 NaN、Infinity 以及 -Infinity,JSON 序列化的结果会变成 null; 无法拷贝对象的循环引用,如果对象中有循环引用,会报错: Uncaught TypeError...JavaScript内置对象的复制: Set、Map、Date、RegExp等 * 2.

    2.4K20

    学习zepto.js(对象方法)

    学习zepto.js(对象方法)[4] 今天说说那一套获取元素集合的一些方法: ["children", "clone", "closest", "contents", "empty...上边那个过滤方法用的地方比较多,所以给它放在上边; children方法调用的filtered传入的是两个参数,第一个是一个集合,将所有对象的所有的子节点取出,并放入一个集合;children方法内部调用的...我们调用的是对象方法,而对象方法调用的那个就是一个普通的内部私有函数- -(望理解它们之间的区别); 返回的是做一个兼容处理的获取子元素的实现,如果节点存在children属性就直接取出,不存在的话,就循环...如果不是一个字符串,就判断是否是一个类数组,并且对象的item是一个方法,(是的,变相的判断为一个zepto对象.) 其余的情况,直接通过参数构建一个zepto对象....以上操作均为excludes变量赋值; 在最后,通过循环对象.将对象中不存在于excludes变量中的所有元素取出.并构件为一个zepto对象.

    2.5K60

    学习zepto.js(对象方法)

    学习zepto.js(对象方法)[1] zepto也是使用的链式操作,链式操作:函数返回调用函数的对象....方法执行时而没有传入参数,会将该对象所有的匹配元素以数组的形式返回; uniq方法是一个数组去重的方法,返回的还是一个数组,然后回到add方法再次通过$()构造一个zepto对象并返回; addClass...,该方法就是获取到传入的第一个参数的className属性,如果第二个参数不存在,则返回node的className信息,如果存在值,就将值赋node的className属性; 再回到addClass...大体相同,唯有在forEach循环中,addClass是集合push值,而removeClass是从一个字符串中replace掉值; toggleClass(): 方法使用与前两个类似,只不过多了第二个参数...关于class的几个方法算是说完了.个人认为,这是用的比较多的一套方法了.比如结合交互时做一个动画效果,在CSS无法实现的情况下,就可以将animation写到一个class中,触发某个事件时元素add

    2.6K80

    学习zepto.js(对象方法)

    学习zepto.js(对象方法)[2] 今天来说下zepto那一套dom操作方法, ['prepend', 'append', 'prependTo', 'appendTo',...prependTo(): 将对象插入到参数内部的头部(可以理解为将prepend的参数变为调用方法对象,将对象变为方法的参数); ? appendTo(): 将对象插入到参数内部的尾部; ?...; 跳过map方法中的处理,不多做解释,因为这个是转换参数为DOm节点的; 在方法返回时执行的each方法, 方法首先会判断该方法是否为对象内部的操作,如果是,将parent变量赋值为当前对象,如果不是...来实现插入到某对象的后边,我们需要三个对象,一个是当前对象,还有要插入的对象,以及当前对象的容器,也就是他的parent; 在进入方法时,我们通过inside变量获取到了该方法是否为内部插入,然后通过inside...,当前对象的后一个节点);一个dom树中同一个dom节点不会出现两次,就是说,移动对象属于剪切操作,而不是复制操作, 这也是为什么方法内不会进行判断调用方法对象是否为多个,如果是多个,则需要将对象进行

    2.6K60

    学习zepto.js(对象方法)

    学习zepto.js(对象方法)[5] clone: 该方法不接收任何参数,会返回对象中的所有元素集合,但不会对象绑定的事件. var $temp =$("div").clone...方法首先取出当前dom对象作为基点并赋值node.collection默认的为false.如果传入的selector参数为一个object,则认为选择器是一个zepto对象,或者是一个dom对象(集合...),并将转换为zepto对象的值赋collection; 下边是循环,循环判断的条件为node存在,并且collection中不存在node(selector为object的情况下)或者node不匹配...$("#temp").empty();//该方法将清除#temp的innerHTML ? 代码也只是简单的遍历并innerHTML赋值而已。 题外话:map方法与each方法的区别。...方法对象为一个单一的对象,则直接用过qsa方法(前几篇说过qsa方法),将选择器作为一个选择器,并将对象作为上下文传入; 否则循环zepto对象重复上边那一条; (find方法可能说的不太细。

    2.7K110
    领券