首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

学习zepto.js(原型方法)

学习zepto.js(原型方法)[2] 接着昨天的来,继续说原型方法,昨天的传送阵(昨天出了点小意外,博文经过WP手机的UC浏览器进行编辑后标签就露出来了- -,现已修复);...//jQuery1.x的版本是做了兼容的处理,2.x以后也是直接调用的indexOf方法. $.isArray(): 该方法只接收一个参数,一个对象,用来判断该对象是否为Array,返回一个boolean...$.isFunction(): 方法只接收一个参数,一个对象,判断是否为function对象,别看这方法只是用来检查参数是否为function,里边衍生出的几个变量和方法还是挺有意思的....首先判断传入参数为一个对象,并且不是一个window对象,getPrototypeOf方法返回参数的构造方法的prototype.有兴趣的可以移步MDN $.map(): 该函数返回一个数组,传入两个参数...今天先说到了这里,zepto里边的原型方法出了ajax模块的就都已经说完了- -,读源码真的是最快的学习方式.

1.4K50
您找到你想要的搜索结果了吗?
是的
没有找到

学习zepto.js(原型方法)

学习zepto.js(原型方法)[1] 新的一周,新的开始,今天来学习一下zepto里边的原型方法,就是通过$.进行调用的方法,也是可以通过$.fn进行扩展的方法: $.camelCase...(本人发现zepto中的原型方法都是通过将匿名函数赋值给变量的方式来进行声明的,而直接使用function声明的函数在外部是获取不到的)解释的不详细,是因为原型方法都有一个原型的引用,而那些普通函数没有做这个引用...,也是扩展插件所需的方法,方法有效执行须接收两个以上的参数,第一个参数为目标对象,第二个以后的为来源,来源会覆盖目标的原有属性,默认为浅复制,如果想要深度复制,则将第一个参数设为true,然后是目标对象...- -方法返回目标对象的原因是为了链式操作,经过extend以后直接使用即可. $.fn: 这个不是一个方法,而是一个对象,指向Zepto对象的prototype,所以说,使用$.extend来使$.fn...,扩展的方法最好将this返回; 因为是个对象,所以就不贴码了.

2K90

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.3K20

对象原型上添加方法

本文除了讨论“在对象原型上添加方法”好还是坏之外,也会为大家分享一个干货,是利利自己写的“复制”变量的方法。一起来看吧~!...本文主要内容 1 “复制”/“克隆”数组的功能需求 2 在对象原型上添加方法是否合理?...在对象原型上添加方法是否合理? 仔细思考之后,并查阅了一些相关资料,利利最终还是放弃了将方法添加到对象原型上,为什么呢?...1 防止冲突 我们可以想象,如果仅仅由我们一个人开发项目时,是不会出现什么冲突问题的,但是,如果参与项目的人不止一个,那么我在对象上定义一个方法,别人是不是也可以在对象上定义一个方法呢?...2 不易定位错误位置 我们自己书写的代码,有时可能会有一些考虑不周,必然会产生或多或少的bug,如果这些方法是正常存在于window的全局作用域下,也可以通过JS文件寻找到相应内容时,那么,我们就可以比较快速的进行错误定位

95650

深入理解javascript中的原型原型的概念使用原型对象添加方法和属性使用原型对象的属性和方法原型的陷阱小结

---- 使用原型对象添加方法和属性 不使用原型,使用构造函数给对象添加属性和方法的是通过this,像下面这样。...,我们可以给构造函数的原型对象添加属性和方法来。...Paste_Image.png ---- 使用原型对象的属性和方法 我们使用原型对象方法不会在直接在构造函数上使用,而是通过构造函数new出一个对象,那么new出来的对象就会有构造函数原型里的属性和方法...isPrototypeOf() Object的原型里还有这样一个方法isPrototypeOf(),这个方法可以返回一个特定的对象是不是另一个对象原型,实际这里不准确,因为我们知道只有函数对象原型属性...主要有以下几方面: 所有函数都有一个属性prototype,这就是我们指的原型,他的初始值是一个空的对象 你可以原型对象添加属性和方法,甚至直接用另一个对象替换他 当你用构造函数new出一个对象之后,这个对象可以访问构造函数的原型对象的属性和方法

4.2K30

js对象原型原型链的关系

JS原型原型链一直是比较难理解的内容,不少初学者甚至有一定经验的老鸟都不一定能完全说清楚,更多的"很可能"是一知半解,而这部分内容又是JS的核心内容,想要技术进阶的话肯定不能对这个概念一知半解,碰到问题靠...有时候需要在两个对象之间共享属性,由于JS在设计之初没有类的概念,所以JS使用函数的prototype来处理这部分需要被共享的属性,通过函数的prototype来模拟类:当创建一个函数时,JS会自动为函数添加...是原型链的终点,所有对象都是从它继承了方法和属性。...准确的说:这些属性和方法是定义在String这个全局对象/函数上的。字符串的原型指向了String函数的prototype。...之后通过查找原型链,在String函数的prototype中找到这些属性和方法

1.4K20

学习zepto.js(对象方法)

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

2.5K60

学习zepto.js(对象方法)

学习zepto.js(对象方法)[2] 今天来说下zepto那一套dom操作方法, ['prepend', 'append', 'prependTo', 'appendTo',...prependTo(): 将对象插入到参数内部的头部(可以理解为将prepend的参数变为调用方法对象,将对象变为方法的参数); ? appendTo(): 将对象插入到参数内部的尾部; ?...上边那个数组是储存的几个操作的名称,下边的forEach循环是在zepto自执行函数中执行的,就是说,在构件zepto原型的是否就创建了这几个方法; forEach方法回调返回的参数,第一个是值,第二个是值的下标...; 跳过map方法中的处理,不多做解释,因为这个是转换参数为DOm节点的; 在方法返回时执行的each方法, 方法首先会判断该方法是否为对象内部的操作,如果是,将parent变量赋值为当前对象,如果不是...来实现插入到某对象的后边,我们需要三个对象,一个是当前对象,还有要插入的对象,以及当前对象的容器,也就是他的parent; 在进入方法时,我们通过inside变量获取到了该方法是否为内部插入,然后通过inside

2.6K60

学习zepto.js(对象方法)

学习zepto.js(对象方法)[1] zepto也是使用的链式操作,链式操作:函数返回调用函数的对象....但并不是所有的对象方法都可以进行链式操作,举几个例子:.size(),.html()|.text()//不传参数的情况下; 若非特殊说明,下边介绍的方法都会返回zepto对象; add(): 支持一到二个参数...add函数本身无任何亮点- -,将两个参数原封不动的传入$()然后返回一个Zepto对象,执行concat函数,该函数会将所有参数添加至调用函数对象的末尾, toArray方法会调用get方法,当get...方法执行时而没有传入参数,会将该对象所有的匹配元素以数组的形式返回; uniq方法是一个数组去重的方法,返回的还是一个数组,然后回到add方法再次通过$()构造一个zepto对象并返回; addClass...通过each方法循环遍历对象,each方法会返回一个zepto对象.首先会判断元素是否存在className属性, 通过className方法获取到当前元素的所有className信息的字符串; ?

2.6K80

学习zepto.js(对象方法)

学习zepto.js(对象方法)[6] first: 获取当前对象集合中的第一个dom元素。...$("div").last();// 返回最后一个div对象(zepto对象) //相当于 $("div").eq(-1); 两方法不接收任何参数。 ?...(dom对象,不是zepto对象) $("div").get();      //所有div对象组成的一个数组 该方法与eq方法的区别在于,eq返回的是zepto对象,而get返回的是dom对象,$()...否则通过当前对象来调用find方法并将selector传入,并调用size方法获取count(filter会自动将返回值转换为bool类型)。 parent: 获取对象集合所有的直接父节点。...pluck方法返回一个数组,参数是一个字符串,为属性名,返回的值是调用对象所对应的属性的值; 然后传入uniq方法方法做了一个去重处理; 最外层的方法filtered,如果第二个参数selector不为空

2.6K80

学习zepto.js(对象方法)

学习zepto.js(对象方法)[3] 继续说zepto里attributes的相关操作. attr,removeAttr,prop这三个方法....那是zepto.js中文api中所说的.本人认为,在判断有关交互的属性时,应优先使用prop,比如checked和selected; ? ? 之所以为出现差异,是因为两者底层实现的区别. ?...—-如果对象不是一个节点对象,则直接跳过本次循环; —-如果name为一个object,就是说我们一次性更改多个属性值.这时就循环object对象,来调用setAttribute方法 —-剩下的条件就是给单个属性赋值...执行过程与attr的类似,但是attr赋值是通过setAttribute()方法,取值是getAttribute()与对象属性取值的结合.而prop完全操作的是对象的属性; 再来点吧.说说data方法与...一个来自prototype.js大表哥中的方法; 传入一个属性名,将调用者集合中所有的该属性的值作为一个数组返回; 其余的没什么了. 如果有什么疑惑的地方还请留言问我.大家共同学习

2.6K90

学习zepto.js(对象方法)

学习zepto.js(对象方法)[5] clone: 该方法不接收任何参数,会返回对象中的所有元素集合,但不会对象绑定的事件. var $temp =$("div").clone...方法的实现就是循环调用方法对象.然后将所有的dom元素克隆并返回 ? 而且使用的深度克隆,就是说,会将节点下方的子节点统统克隆过来....> hello world <script type="text/javascript" src="<em>js</em>...与get<em>方法</em>的区别是,get返回一个dom<em>对象</em>,eq返回一个zepto<em>对象</em>。...<em>方法</em>的<em>对象</em>为一个单一的<em>对象</em>,则直接用过qsa<em>方法</em>(前几篇说过qsa<em>方法</em>),将选择器作为一个选择器,并将<em>对象</em>作为上下文传入; 否则循环zepto<em>对象</em>重复上边那一条; (find<em>方法</em>可能说的不太细。

2.7K110
领券