jQuery.extend()与 jQuery.fn.extend()比较
相同点
两者都是用来扩展 jQuery,为 jQuery添加方法的,在开发jQuery 的相关插件时经常用到。
不同点
jQuery.extend()
为 jQuery 类本身添加类方法,即为静态方法;
调用添加的方法时只能通过 jQuery 本身来调用,jQuery 实例对象是无法调用新添加的方法的。比如 添加了 show 和 hide 方法,则调用方式为: jQuery.show()和 jQuery.hide().
jQuery.fn.extend()
看 jQuery 的源代码时会看到: jQuery.fn=jQuery.prototype,不难发现 jQuery.fn实际即为 jQuery 的原型。则调用jQuery.fn.extend()实际是在扩展jQuery.prototype对象的方法。由于 jQuery原型中的所有成员方法会被所有jQuery实例对象继承,则只要是 jQuery 实例对象就有添加的方法。
与 jQuery.extend()不同,jQuery.fn.extend()是为jQuery 原型添加方法,即为jQuery实例对象的成员方法。
调用方式也发生了改变,不用通过 jQuery 本身来调用添加的方法,所有 jQuery 实例对象都可以调用。
代码示例
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>jquery.extend()</title>
</head>
<body>
<div id="sample">extend</div>
</body>
<script src="jquery-1.11.0.js"></script>
<script>
$(document).ready(function($){
jQuery.extend({
show:function(){
alert("show message!");
},
hide: function () {
alert("hide message!");
}
});
jQuery.hide();
jQuery.show();//使用jQuery本身调用新添加的方法
})
jQuery(function($){
jQuery.fn.extend({
show:function(){
alert("show message!");
},
hide: function () {
alert("hide message!");
}
});
$("#sample").show();
$("#sample").hide();//使用jQuery 实例对象调用新添加的方法
})
</script>
</html>
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。