添加到String.prototype中的方法比較多,不過歸結起來,大致分為下面幾類:
| 分類 | 方法名 |
| 原始能力增強 | strip | include | startsWith | endsWith | empty | blank |
| 格式 | camelize | capitalize | underscore | dasherize | inspect |
| 變形 | toArray | succ | times |
| 替換 | interpolate | sub | scan | truncate | gsub |
| HTML處理 | stripTags | escapeHTML | unescapeHTML |
| 參數序列化 | toQueryParams |
| JSON處理 | unfilterJSON | isJSON | evalJSON | parseJSON |
| 腳本處理 | stripScripts | extractScripts | evalScripts |
從基本的原始能力增強開始,下面是具體的實現,這一段很好理解的:
代碼如下:
(function(s){
function strip(){
return this.replace(/^/s+/,'').replace(//s+$/,'');
}
function include(pattern){
return this.indexOf(pattern) > -1;//split
}
function startsWith(pattern) {
return this.lastIndexOf(pattern, 0) === 0;
}
function endsWith(pattern) {
var d = this.length - pattern.length;
return d >= 0 && this.indexOf(pattern, d) === d;
}
function empty() {
return this == '';
}
function blank() {
return /^/s*$/.test(this);
}
s.strip = String.prototype.trim || strip;
s.include = include;
s.startsWith = startsWith;
s.endsWith = endsWith;
s.empty = empty;
s.blank = blank;
})(String.prototype);
上面的strip在jquery里面是$.trim,而且大部分貌似都是trim。這里直接擴展原生原型的悲劇之處就顯現出來了,因為后面的JS實現中(比如chrome)就實現了trim方法,那就弄巧成拙了。
代碼如下:
function strip(){
return this.replace(/^/s+/,'').replace(//s+$/,'');
}
這里面的replace(/^/s+/,'')就是trimLeft,replace(//s+$/,'')是trimRight,不過Prototype.String中沒有這兩個方法。
下面是這一部分比較有意思的地方:
當時看這段的時候,對其中的startsWith和endsWith甚是不解,按理來說,startsWith用indexOf就可以了,這里卻是用的lastIndexOf。后來去翻了一下Prototype1.6版本的實現:
代碼如下:
function startsWith(pattern) {
return this.indexOf(pattern) === 0;
}
function endsWith(pattern) {
var d = this.length - pattern.length;
return d >= 0 && this.lastIndexOf(pattern) === d;
}
可見,以前版本中startsWith用的就是indexOf,不過1.7版本修改了startsWith的實現。在1.7版本中:
|
新聞熱點
疑難解答
圖片精選