天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

JavaScript對象鏈式操作代碼(jquery)

雖然現在慢慢減少了對jQuery的使用(項目上還是用,效率高點。平時基本不用了),希望從而減少對jQuery的依賴度。
但是這鏈式操作的方式實在吸引人(貌似現在不少新庫都采用了鏈式操作)。
新手無畏嘛,所以寫了以下代碼。主要是避免以后又忘了,呵呵。
復制代碼 代碼如下:
window.k = function() {
return new k.fn.init(arguments);
}
k.fn = k.prototype = {
init:function() {
this.length = 0;
//var args = Array.prototype.slice.call(arguments,0);
Array.prototype.push.apply(this,arguments[0]);
return this;
},
show:function() {
console.log(Array.prototype.slice.call(this,0).join("$"));
return this;
},
hide:function() {
console.log(this);
return this;
}
}
k.fn.init.prototype = k.fn;
console.log(k("0",1,2,3,4,5).show().hide());

這只是進行了鏈式操作。但是在firbug下可以看到jQuery對象返回的是數組/類數組。要實現這個卻不知道怎么辦好。。
總不能讓k.fn.prototype = new Array()吧。真要看jQuery源代碼還真是有點累。。
下面是針對網友的一些回復
其實鏈式操作很簡單,就是每次返回操作對象本身,這樣就可以持續的調用該對象本身定義的所有方法了。
最簡單的例子:
復制代碼 代碼如下:
var o = function() {
/**
do something
*/
return this;
}
o.prototype = {
action1: function() {
/**
do something
*/
return this;
},
action2: function() {
/**
do something
*/
return this;
}
}

你可以這樣調用:
new o() //
.action1() //
.action2(); //每一步操作返回的都是實例化的o對象
它其實等同于這樣:
var a = new o();//如果沒有返回this,那么就不能在這里繼續調用了。因為返回的是undefined。
a.action1(); //這個時候就只能對a(實例化的o對象的引用)來操作。
a.action2();
如果你用過jQuery就應該發現了。jQuery并不需要你使用new來實例化一個對象,在使用的時候顯得更方便。
所以我們定義另一個對象來封裝上面提到的o對象:
var k = function() {
return new o();
}
這樣我們就可以這樣調用了:
k().action1().action2();
我為你推薦 一個叫 "函數化"的 構造JS的方法。
復制代碼 代碼如下:
//加粗表示強調
//這個方法是 《Javascript語言精粹》第52頁 5.4函數化 上的。
var constructor = function (spec,my){
var that,其他的私有實例變量;
my = my || {};
把共享的變量和函數添加到my中
that = 一個新對象
添加給that 的特權方法
return that;
}

JavaScript技術JavaScript對象鏈式操作代碼(jquery),轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 热99re久久精品国产首页 | 国产三级级在线电影 | ca88亚洲城娱乐 | 99久久精品免费看国产一区二区 | 日韩欧美一区二区三区在线视频 | 美女扣逼软件 | 亚洲免费成人 | 国产乱人精品视频AV麻豆 | 老男人粗大猛 | 俄罗斯女人Z0ZOZO | 亚洲中文字幕无码一去台湾 | 性色AV一区二区三区咪爱四虎 | 成人高清护士在线播放 | 亚洲日本一区二区三区在线不卡 | 99久久99久久精品免费看子 | 九热这里只有精品 | 久久三级视频 | 手机看片一区二区 | 黑人开嫩苞 | 亚洲乱码在线卡一卡二卡新区 | 手机在线观看你懂的 | 日韩欧美视频一区二区 | 国产亚洲精品成人a在线 | 久久亚洲精品无码A片大香大香 | 国产精品视频国产永久视频 | TIMI1TV天美传媒在线观看 | 亚洲精品无码不卡在线播放he | 久久精品国产欧美日韩99热 | 激情床戏揉胸吃胸视频 | 亚洲专区中文字幕视频专区 | 花蝴蝶高清影视视频在线播放 | 日本阿v片在线播放免费 | 国产精品VIDEOS麻豆TUBE | 亚洲欧美一区二区三区导航 | 情欲.美女高潮 | 国产亚洲高清视频 | 99热婷婷国产精品综合 | 国产成人免费全部网站 | 国产普通话精品久久 | 国产在线高清视频无码 | 一级毛片皇帝 宫女 |