jQuery插件扩展extend的简单实现原理

 更新时间:2016年06月24日 10:52:56   投稿:jingxian  
下面小编就为大家带来一篇jQuery插件扩展extend的简单实现原理。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

相信每位前端的小伙伴对jQuery都不陌生吧,它最大的魅力之一就是有大量的插件,去帮助我们更轻松的实现各种功能。

前几天晚上,闲来无事,就自己动手写了个简单的jQuery插件,功能很简单,只是让选定的元素高亮,但是其中的一些思想,还是很值得学习的,可以戳这里查看代码。

本文不聊怎么写jQuery插件,我们聊聊怎么去实现jQuery的插件扩展功能,extend是怎么实现把我们写的插件挂载到jQuery上的。(大牛可以出门右拐......)

我们可以模拟创建一个迷你jQuery。

var $ = {};

好的,就这么简单......

下面我们要在这个对象上挂载一个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的简单实现原理全部内容了,希望大家多多支持脚本之家~

相关文章

  • jquery实现移动端悬浮拖拽框

    jquery实现移动端悬浮拖拽框

    这篇文章主要为大家详细介绍了jquery实现移动端悬浮拖拽框,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • AJAX分页的代码(后台asp.net)

    AJAX分页的代码(后台asp.net)

    查询功能是开发中最重要的一个功能,大量数据的显示,我们用的最多的就是分页。
    2011-02-02
  • Javascript中封装window.open解决不兼容问题

    Javascript中封装window.open解决不兼容问题

    window.open不兼容,其实不是, 因为不能直接执行, 必须通过用户手动触发才行,下面有个实例,大家可以看看
    2014-09-09
  • 10款非常有用的 Ajax 插件分享

    10款非常有用的 Ajax 插件分享

    这篇文章与大家分享的是10款非常有用的 Ajax 插件,有用于图片的,用于分页的,还有用于导航的。这些作者的想法特别新颖,希望你能从中找到自己需要的插件
    2012-03-03
  • Easyui使用Dialog行内按钮布局的实例

    Easyui使用Dialog行内按钮布局的实例

    下面小编就为大家带来一篇Easyui使用Dialog行内按钮布局的实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-07-07
  • easyui Droppable组件实现放置特效

    easyui Droppable组件实现放置特效

    droppable和draggable有类似的地方,不过区别点在于前者着重于将元素放进某个容器中,而后者则着重于可拖拽(虽然可能一些效果两者都可以实现)。而且通过查看easyloader源码可知道,droppable并不依赖于draggable。
    2015-08-08
  • jQuery Autocomplete简介_动力节点Java学院整理

    jQuery Autocomplete简介_动力节点Java学院整理

    这篇文章主要介绍了jQuery Autocomplete简介,jQuery UI Autocomplete是jQuery UI的自动完成组件,是我用过的最强大、最灵活的Autocomplete,它支持本地的Array/JSON数组、通过ajax请求的Array/JSON数组、JSONP、以及Function(最灵活)等方式来获取数据
    2017-07-07
  • JQuery 弹出框定位实现方法

    JQuery 弹出框定位实现方法

    这几天一直在研究JQuery,确实很好用,有很多需求都是要弹出框,并且要定位,我这写个简单的例子,希望能分享给大家.
    2010-12-12
  • jQuery dateRangePicker插件使用方法详解

    jQuery dateRangePicker插件使用方法详解

    这篇文章主要为大家详细介绍了jQuery dateRangePicker插件的使用方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • jQuery使用ajaxSubmit()提交表单示例

    jQuery使用ajaxSubmit()提交表单示例

    这篇文章主要介绍了jQuery使用ajaxSubmit()提交表单示例,使用延第三方插件jquery.form实现,需要的朋友可以参考下
    2014-04-04

最新评论