Prototype prov " /> 青青青伊人,www.伊人网,老司机亚洲精品影院在线观看

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

Prototype ObjectRange對象學習

Ranges represent an interval of values. The value type just needs to be “compatible,” that is, to implement a succ method letting us step from one value to the next (its successor).

Prototype provides such a method for Number and String, but you are of course welcome to implement useful semantics in your own objects, in order to enable ranges based on them.

ObjectRange對象基本就是實現了連續的數字或者字符串,其中只包含一個方法,include,判斷某個數字或者字符串是否在ObjectRange里。并且ObjectRange對象還混入了Enumerable的方法,所以可以直接在ObjectRange對象上調用Enumerable對象里面的方法。
復制代碼 代碼如下:
//創建ObjectRange的便捷方法
function $R(start, end, exclusive) {
return new ObjectRange(start, end, exclusive);
}

//創建ObjectRange對象并且繼承自Enumerable
var ObjectRange = Class.create(Enumerable, (function() {
    //初始化方法,exclusive為true時,不包含end數值,默認為undefined也就相當于false
function initialize(start, end, exclusive) {
this.start = start;
this.end = end;
this.exclusive = exclusive;
}

//覆蓋Enumerable里面的_each方法,在遍歷ObjectRange對象時需要用到此方法
function _each(iterator) {
var value = this.start;
while (this.include(value)) {
iterator(value);
value = value.succ();
}
}

//判斷某個數值或者字符串是否包含在ObjectRange對象里
function include(value) {
if (value < this.start)
return false;
if (this.exclusive)
return value < this.end;
return value <= this.end;
}

return {
initialize: initialize,
_each: _each,
include: include
};
})());

看一下示例,然后在詳細解釋一些細節:
復制代碼 代碼如下:
$A($R('a', 'e'))
// -> ['a', 'b', 'c', 'd', 'e'], no surprise there

//千萬不要嘗試輸出下面返回的結果,否者將會造成瀏覽器直接死掉
$A($R('ax', 'ba'))
// -> Ouch! Humongous array, starting as ['ax', 'ay', 'az', 'a{', 'a|', 'a}', 'a~'...]

這里說一下$A($R('a', 'e')),如何返回值。首先看$A方法,前面的文章【Prototype 學習――工具函數學習($A方法)】中已經詳細講解了$A方法,不知道請自行參考。在$A方法里面有這樣一句:if ('toArray' in Object(iterable)) return iterable.toArray();我們知道,ObjectRange里面混入了Enumerable里面的方法,也就是說間接實現了toArray方法,那么看一下Enumerable里面的toArray方法:
復制代碼 代碼如下:
function toArray() {
return this.map();
}

//======> this.map()

//我們注意到在返回的時候map方法被映射到了collect方法
return {
//...
collect: collect,
map: collect,
//...
}

//======> collect()

//在本例中這個方法其實就相當于返回一個數組,因為傳進來的參數都是undefined。這里面有一個this.each方法,繼續查看
function collect(iterator, context) {
iterator = iterator || Prototype.K;
var results = [];
this.each(function(value, index) {
results.push(iterator.call(context, value, index));
});
return results;
}

//======> this.each()

//終于看到this._each了,現在明白為什么ObjectRange里面會重寫了_each方法了吧。在遍歷的時候要用到這個方法
function each(iterator, context) {
var index = 0;
try {
this._each(function(value) {
iterator.call(context, value, index++);
});
} catch (e) {
if (e != $break) throw e;
}
return this;
}

//======> this._each()

//詳細說明一下this._each()
//關鍵就是succ()這個方法,因為_each里面使用這個方法產生下一個數值。
//這個succ()在哪里呢?在Number.prototype和String.prototype里面定義了這個方法
function _each(iterator) {
var value = this.start;
while (this.include(value)) {
iterator(value);
value = value.succ();
}
}

//下面兩個方法我就不講了吧。

//======> String.prototype.succ()

function succ() {
return this.slice(0, this.length - 1) +
String.fromCharCode(this.charCodeAt(this.length - 1) + 1);
}

//======> Number.prototype.succ()

function succ() {
return this + 1;
}

//綜上所述,如果你自己想定義其它類型的ObjectRange對象,譬如Date類型,那么你就要自己實現succ()方法,用來生成連續的對象

上面的流程將清楚了,但一些函數沒有仔細講,等講到這些對象的時候在仔細說明里面的函數。下面看幾個include的示例吧:
復制代碼 代碼如下:
$R(1, 10).include(5)
// -> true
$R('a', 'h').include('x')
// -> false
$R(1, 10).include(10)
// -> true
$R(1, 10, true).include(10)
// -> false

JavaScript技術Prototype ObjectRange對象學習,轉載需保留來源!

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

主站蜘蛛池模板: 伊人亚洲综合网色 | YELLOW视频在线观看免费版高清 | www.一级毛片 | 超碰97人人做人人爱亚洲尤物 | 亚州AV中文无码乱人伦在线 | 国产亚洲视频在线 | 97超碰在线视频 免费 | 九色PORNY真实丨首页 | 欧美最猛性XXX孕妇 欧美最猛性xxxxx亚洲精品 | 好硬好湿好大再深一点动态图 | 成人毛片100部免费看 | 国产精品成人久久久久A伋 国产精品成人观看视频免费 | 国产精品免费观看视频播放 | 性色AV一区二区三区咪爱四虎 | 亚洲粉嫩美白在线 | 国产又黄又粗又爽又色的视频软件 | 少妇精品久久久一区二区三区 | 国产精品久久国产三级国不卡顿 | 蜜臀AV人妻久久无码精品麻豆 | 久久99影院 | 老头狠狠挺进小莹体内视频 | 九九在线免费视频 | 97国产精品人妻无码免费 | 国产亚洲精品久久久久小 | 男人的天堂黄色 | 伊人久久青草 | 日本漫画之无彩翼漫画 | 精品视频在线观看视频免费视频 | 在线观看中文字幕码2021不用下载 | 国产老师开裆丝袜喷水漫画 | 天天狠狠色综合图片区 | 亚洲中文字幕在线第六区 | 精品欧美小视频在线观看 | xxxx俄罗斯1819| 精品国产高清自在线看 | 麻生希第一部快播 | 国产福利高清在线视频 | 超碰v | 人人在线碰碰视频免费 | 国产亚洲制服免视频 | 国产 亚洲 中文字幕 在线 |