ホームページ >ウェブフロントエンド >jsチュートリアル >jQueryでextendを使う方法
jQuery.extend
2 つ以上のオブジェクトの内容を最初のオブジェクトに結合します。 2 つ以上のオブジェクトの内容を最初のオブジェクトに結合します。 2 つ以上のオブジェクトのコンテンツを最初のオブジェクトにまとめます。jQuery.fn.extend オブジェクトのコンテンツを jQuery プロトタイプにマージして、新しい jQuery インスタンス メソッドを提供します。新しい jQuery
インスタンス メソッドjQuery.extendの拡張メソッド機能については公式には言及されていませんが、jQueryの
クラスメソッドオブジェクトの結合
まずはオブジェクトの結合におけるextend関数の使い方を紹介します。
jQuery.extend(target [, object1] [, objectN])
上述代码展示的是将 obj2 对象合并到 obj1 对象中,这种方法会 改变 obj1 对象的结构。如果你 不想改变 合并目标对象的结构,你可以这么做。 和上面的讲述的不同的是,该方法多了一个类型为 boolean 的 [deep] 传参,当其为 true 时,将 object1 , objectN 深度复制 后合并到 target 中。 首先,我们理解一下什么叫做 深度复制 。看看其和 浅度复制 有什么区别。 由此可见,执行 深度复制 会递归遍历每个对象中含有复杂对象(如:数组、函数、json对象等)的属性值进行复制,而且 浅度复制便不会这么做。
上述的 extend 方法中的 target 参数是可以省略的。如果省略了,则该方法就只能传入一个 object 参数,该方法功能是将该 object 合并到调用 extend 方法的对象中。 我们通常会使用这种方式来对 jQuer进行一些方法上的扩展。 jQurey 提供了两种方法扩张方式,分别为 想要搞清楚两种扩展方式之间的区别的话,先要了解什么是 本猿参考了 jQuery 的源码,发现其中玄机: 其次,我们要引入两个概念 类方法 和 实例方法 。 类方法 是直接可以使用类引用,不需要实例化就可以使用的方法。一般在项目中 类方法 都是被设置为工具类使用; 实例方法 必须先创建实例,然后才能通过实例调用该 实例方法 。
jQuery.fn.extend(object)是对jQuery.prototype上的扩展。 这种方式相当对 实例方法 的扩展。 举个栗子: 上述代码可以实现预想的扩展,但最好返回 改良之后,代码如下:var obj1 = {
name: 'Tom',
age: 21
}
var obj2 = {
name: 'Jerry',
sex: 'boy'
}
$.extend(obj1, obj2); // {name: "Jerry", age: 21, sex: "boy"}
obj1 // {name: "Jerry", age: 21, sex: "boy"}
obj2 // {name: "Jerry", sex: "boy"}
var obj1 = {
name: 'Tom',
age: 21
}
var obj2 = {
name: 'Jerry',
sex: 'boy'
}
$.extend({}, obj1, obj2); // { name: "Jerry", age: 21, sex: "boy" }
obj1 // { name: "Tom", age: 21 }
obj2 // { name: "Jerry", sex: "boy" }
深浅拷贝
jQuery.extend([deep], target, object1 [, objectN])
var obj1 = {
name: "John",
location: {
city: "Boston",
county: "USA"
}
}
var obj2 = {
last: "Resig",
location: {
state: "MA",
county: "China"
}
}
$.extend(false, {}, obj1, obj2); // { name: "John", last: "Resig", location: { state: "MA", county: "China" }}
$.extend(true, {}, obj1, obj2); // { name: "John", last: "Resig", location: { city: "Boston", state: "MA", county: "China" }}
方法扩展
引子
jQuery.fn.extend(object)
和jQuery.extend(object)
.jQuery.fn
.jQuery.fn = jQuery.prototype = {
init: function(selector, context) {
// ...
};
}
jQuery.fn = jQuery.prototype
这句代码明确指出jQuery.fn
指代的就是 jQuery 的原型。
jQuery
可以看做是这个封装得非常好的类,而我们可以使用jQuery选择器
来创建 jQuery 的实例。比如:使 id 选择器$('#btn')
来创建一个实例。区别
jQuery.extend(object)
相当于对 类方法 的扩展。jQuery.extend({
/* 返回两个元素中较小的值 */
min: function(a, b) {
return a < b ? a : b;
},
/* 返回两个元素中较大的值 */
max: function(a, b) {
return a > b ? a : b;
}
});
jQuery.min(2, 3); // 2
jQuery.max(4, 5); // 5
jQuery.fn.extend = jQuery.prototype.extend
开发一个简单的小功能,使用该方法可以使选定元素内的文字变红。$.fn.extend({
setRed: function() {
$(this).css("color", "red");
}
});
$('.tip').setRed();
$(".tip")
创建了一个jQuery实例
,通过它可以调用成员方法setRed
.this
以满足 jQuery 链式操作 的需要。$.fn.extend({
red: function() {
return $(this).css("color", "red");
}
});
以上がjQueryでextendを使う方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。