jQuery.extend 与 jQuery.fn.extend的用法及区别实例分析


Posted in jQuery onJuly 25, 2018

本文实例讲述了jQuery.extend 与 jQuery.fn.extend的用法及区别。分享给大家供大家参考,具体如下:

jQuery是一个JavaScript类,如$("#input1") 生成一个 jQuery类的实例。

jQuery为开发插件提拱了两个方法:jQuery.fn.extend()jQuery.extend()

1、jQuery.extend()

(1)扩展 jQuery 类本身,为jQuery类添加类方法(静态方法)

jQuery.extend({
add: function(a, b) { alert(a + b); }
});
jQuery.add(10,20); //30

(2)jQuery.extend(object, object1, [objectN])用一个或多个其他对象来扩展一个对象,返回被扩展的对象

var obj = { name: 'Alice', age: 25, career: "teacher" };
var object = { name: 'Bruce', career: "doctor" };
jQuery.extend(obj, object); //obj = { name: 'Bruce', age: 25, career: "doctor" }

2、jQuery.fn.extend()

把对象挂载到 jQuery 的 prototype 属性,来扩展一个新的 jQuery 实例方法,也就是通过这个 extend 添加的新方法,实例化的 jQuery 对象都能使用,因为它是挂载在 jQuery.fn 上的方法。

查看jQuery源码可发现,jQuery.fn = jQuery.prototype。jQuery.fn挂在原型上,由于对原型的修改会影响所有实例,因此fn上的方法会对每一个jQuery实例有效。

jQuery.fn的扩展,就是为jQuery类添加成员函数,jQuery类的实例可以使用这个成员函数。

jQuery.fn.extend({
   clickFunc: function() {
      $(this).click(function(){
         alert($(this).val());
      });
   }
});
$("#input1").clickFunc(); //输出文本框的文本

3、jQuery.extend()jQuery.fn.extend()的区别

jQuery.extend()是为jQuery类添加类方法(静态方法),需要通过jQuery类来调用(直接使用 $.xxx 调用);

jQuery.fn.extend()是为jQuery类添加成员函数(实例方法),所有jQuery实例都可以直接调用(需要使用 $().xxx 调用)。

希望本文所述对大家jQuery程序设计有所帮助。

jQuery 相关文章推荐
jQuery初级教程之网站品牌列表效果
Aug 02 jQuery
jQuery Layer弹出层传值到父页面的实现代码
Aug 17 jQuery
jQuery实现用户信息表格的添加和删除功能
Sep 12 jQuery
JavaScript实现离开页面前提示功能【附jQuery实现方法】
Sep 26 jQuery
jQuery实现碰到边缘反弹的动画效果
Feb 24 jQuery
jQuery+datatables插件实现ajax加载数据与增删改查功能示例
Apr 17 jQuery
jQuery解析json格式数据示例
Sep 01 jQuery
vue-cli 引入jQuery,Bootstrap,popper的方法
Sep 03 jQuery
jQuery表单元素过滤选择器用法实例分析
Feb 20 jQuery
[jQuery] 事件和动画详解
Mar 05 jQuery
jQuery zTree插件使用简单教程
Aug 16 jQuery
基于jQuery拖拽事件的封装
Nov 29 jQuery
jQuery实现导航样式布局操作示例【可自定义样式布局】
Jul 24 #jQuery
jQuery实现菜单的显示和隐藏功能示例
Jul 24 #jQuery
jQuery实现的监听导航滚动置顶状态功能示例
Jul 23 #jQuery
jquery实现搜索框功能实例详解
Jul 23 #jQuery
jQuery实现的点击按钮改变样式功能示例
Jul 21 #jQuery
jQuery实现输入框的放大和缩小功能示例
Jul 21 #jQuery
jQuery实现table表格信息的展开和缩小功能示例
Jul 21 #jQuery
You might like
yii2中结合gridview如何使用modal弹窗实例代码详解
2016/06/12 PHP
PDO::setAttribute讲解
2019/01/29 PHP
JS如何将UTC格式时间转本地格式
2013/09/04 Javascript
JavaScript两种跨域技术全面介绍
2014/04/16 Javascript
js实现图片上传并正常显示
2015/12/19 Javascript
jquery中键盘事件小结
2016/02/24 Javascript
详解XMLHttpRequest(二)响应属性、二进制数据、监测上传下载进度
2016/09/14 Javascript
jQuery延迟执行的实现方法
2016/12/21 Javascript
JavaScript屏蔽Backspace键的实现代码
2017/11/02 Javascript
利用百度地图API获取当前位置信息的实例
2017/11/06 Javascript
手写Node静态资源服务器的实现方法
2018/03/20 Javascript
element-ui表格数据转换的示例代码
2018/08/24 Javascript
基于JavaScript实现十五拼图代码实例
2020/04/26 Javascript
Vue3新特性之在Composition API中使用CSS Modules
2020/07/13 Javascript
python 快速排序代码
2009/11/23 Python
python中合并两个文本文件并按照姓名首字母排序的例子
2014/04/25 Python
python使用BeautifulSoup分析网页信息的方法
2015/04/04 Python
Python中的rfind()方法使用详解
2015/05/19 Python
Python序列化基础知识(json/pickle)
2017/10/19 Python
python 获取当天每个准点时间戳的实例
2018/05/22 Python
python实现画一颗树和一片森林
2018/06/25 Python
Python3使用PySynth制作音乐的方法
2019/09/09 Python
python类共享变量操作
2020/09/03 Python
pandas抽取行列数据的几种方法
2020/12/13 Python
前端使用canvas生成盲水印的加密解密的实现
2020/12/16 HTML / CSS
如何提高SQL Server的安全性
2016/07/25 面试题
公司业务主管岗位职责
2013/12/07 职场文书
《火烧云》教学反思
2014/04/12 职场文书
教师国庆节演讲稿范文2014
2014/09/21 职场文书
2014年变电站工作总结
2014/12/19 职场文书
优秀共青团员事迹材料
2014/12/25 职场文书
委托函范文
2015/01/29 职场文书
邀请书格式范文
2015/02/02 职场文书
财务部会计岗位职责
2015/02/03 职场文书
springboot+zookeeper实现分布式锁
2022/03/21 Java/Android
使用 Koa + TS + ESLlint 搭建node服务器的过程详解
2022/05/30 NodeJs