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


Posted in Javascript onJune 24, 2016

相信每位前端的小伙伴对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的简单实现原理全部内容了,希望大家多多支持三水点靠木~

Javascript 相关文章推荐
JavaScript的单例模式 (singleton in Javascript)
Jun 11 Javascript
Js+Flash实现访问剪切板操作
Nov 20 Javascript
JavaScript截取字符串的2个函数介绍
Aug 27 Javascript
jQuery 1.9移除了$.browser可以使用$.support来替代
Sep 03 Javascript
js事件监听器用法实例详解
Jun 01 Javascript
一波JavaScript日期判断脚本分享
Mar 06 Javascript
微信小程序 支付简单实例及注意事项
Jan 06 Javascript
深入理解jquery的$.extend()、$.fn和$.fn.extend()
Jul 08 jQuery
浅谈angular.js跨域post解决方案
Aug 30 Javascript
javascript中call,apply,callee,caller用法实例分析
Jul 24 Javascript
浅谈TypeScript的类型保护机制
Feb 23 Javascript
JS数据类型分类及常用判断方法
Nov 19 Javascript
jQuery设置单选按钮radio选中/不可用的实例代码
Jun 24 #Javascript
jQuery给div,Span, a ,button, radio 赋值与取值
Jun 24 #Javascript
jQuery模仿单选按钮选中效果
Jun 24 #Javascript
JS实现iframe编辑器光标位置插入内容的方法(兼容IE和Firefox)
Jun 24 #Javascript
jQuery如何获取动态添加的元素
Jun 24 #Javascript
JS针对浏览器窗口关闭事件的监听方法集锦
Jun 24 #Javascript
JS实现iframe自适应高度的方法(兼容IE与FireFox)
Jun 24 #Javascript
You might like
PHP函数之error_reporting(E_ALL ^ E_NOTICE)详细说明
2011/07/01 PHP
php数组函数序列之array_intersect() 返回两个或多个数组的交集数组
2011/11/10 PHP
PHP用身份证号获取星座和生肖的方法
2013/11/07 PHP
PHP采集静态页面并把页面css,img,js保存的方法
2014/12/23 PHP
PHP动态地创建属性和方法, 对象的复制, 对象的比较,加载指定的文件,自动加载类文件,命名空间
2016/05/06 PHP
CI框架无限级分类+递归的实现代码
2016/11/01 PHP
一个tab标签切换效果代码
2009/03/27 Javascript
jQuery 菜单随滚条改为以定位方式(固定要浏览器顶部)
2012/05/24 Javascript
javascript禁用键盘功能键让右击及其他键无效
2013/10/09 Javascript
js实现回放拖拽轨迹从过程上进行分析
2014/06/26 Javascript
jQuery中animate()方法用法实例
2014/12/24 Javascript
jQuery中 prop() attr()使用详解
2015/05/19 Javascript
js限制文本框的输入内容代码分享(3类)
2015/08/20 Javascript
详解Angular.js指令中scope类型的几种特殊情况
2017/02/21 Javascript
js获取当前周、上一周、下一周日期
2017/03/19 Javascript
在 Angular 中实现搜索关键字高亮示例
2017/03/21 Javascript
vue中实现左右联动的效果
2018/06/22 Javascript
详解使用jest对vue项目进行单元测试
2018/09/07 Javascript
Jquery属性的获取/设置及样式添加/删除操作技巧分析
2019/12/23 jQuery
Python实现简单http服务器
2018/04/12 Python
pandas apply 函数 实现多进程的示例讲解
2018/04/20 Python
python3 读取Excel表格中的数据
2018/10/16 Python
django 做 migrate 时 表已存在的处理方法
2019/08/31 Python
Python Tensor FLow简单使用方法实例详解
2020/01/14 Python
pandas读取csv文件提示不存在的解决方法及原因分析
2020/04/21 Python
对python pandas中 inplace 参数的理解
2020/06/27 Python
SEPHORA丝芙兰德国官方购物网站:化妆品、护肤品和香水
2020/01/21 全球购物
德国W家官网,可直邮中国的母婴商城:Windeln.de
2021/03/03 全球购物
乡下人家教学反思
2014/02/01 职场文书
2014年售后服务工作总结
2014/11/18 职场文书
男方婚前保证书
2015/02/28 职场文书
低端且暴利的线上线下创业项目分享
2019/09/03 职场文书
MySQL之高可用集群部署及故障切换实现
2021/04/22 MySQL
Redis中一个String类型引发的惨案
2021/07/25 Redis
Oracle表空间与权限的深入讲解
2021/11/17 Oracle
sql注入报错之注入原理实例解析
2022/06/10 MySQL