时间:2021-05-26
相信每位前端的小伙伴对jQuery都不陌生吧,它最大的魅力之一就是有大量的插件,去帮助我们更轻松的实现各种功能。
前几天晚上,闲来无事,就自己动手写了个简单的jQuery插件,功能很简单,只是让选定的元素高亮,但是其中的一些思想,还是很值得学习的,可以戳这里查看代码。
本文不聊怎么写jQuery插件,我们聊聊怎么去实现jQuery的插件扩展功能,extend是怎么实现把我们写的插件挂载到jQuery上的。(大牛可以出门右拐......)
我们可以模拟创建一个迷你jQuery。
好的,就这么简单......
下面我们要在这个对象上挂载一个extend方法,用于让开发者为我这个对象添加功能和方法。
var $ = { extend:function(ob){ /**暂时不管里面写什么**/ } }现在,我们就在$这个对象上添加了一个extend方法,外部可以通过$.extend(obj)的方法去调用它。
假设现在我们要往$上面添加一个方法,也就是添加一个插件,我们只需要:
$.extend({ myFunction:function(obj){ //do something.... } })现在只需要$.myFunction(obj);就可以实现方法内所要做的事了。
问题的关键来了,我们明明是把方法挂载在$.extend上,为什么可以直接用$去调用?这里就要看看extend内部是怎么处理传入的obj了。
var $ = { extend:function(obj){ for(var key in obj){ this.__proto__[key]=obj[key]; } }}原来,extend把传入的obj遍历,然后挂到$的__proto__上了,这样,$随时都能够调用原型上的方法。
当然,实际上jQuery的extend实现比这个复杂的多,这里只是介绍了jQuery插件底层实现的基本思想,把公共的方法挂载到对象的原型上。
具体的插件编写可以看看文章开头的链接,我把插件编写的每个细节都做了注释,大家相互学习!
以上就是小编为大家带来的jQuery插件扩展extend的简单实现原理全部内容了,希望大家多多支持~
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
extend()是jQuery中一个重要的函数,作用是实现对对象的扩展,它经常用于jQuery插件的开发,jQuery内部也使用它来扩展属性方法,如上篇文章中讲
本文实例讲述了jQuery插件简单实现方法。分享给大家供大家参考。具体如下:(function($){$.fn.extend({myFunk:function(
基础1、jQuery插件开发主要使用如下两个方法:1.1、添加静态方法jQuery.extend(object);为扩展jQuery本身,为类添加新的方法,可以
缘起我们知道在JQ中,是允许我们自定义一些插件与扩展的。定义的方式也比较简单,采用$.extend就行,那么下面就来看看在JQ中自定义一个插件的实例JQuery
1.jquery.extend(object);为扩展jQuery类本身.为类添加新的方法。jquery.fn.extend(object);给jQuery对象