首頁 >web前端 >js教程 >Javascript中實作String.startsWith和endsWith方法_javascript技巧

Javascript中實作String.startsWith和endsWith方法_javascript技巧

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原創
2016-05-16 15:56:201619瀏覽

在操作字串(String)類型的時候,startsWith(anotherString)和endsWith(anotherString)是非常好用的方法。其中startsWith判斷目前字串是否以anotherString作為開頭,而endsWith則是判斷是否為結尾。舉例:

"abcd".startsWith("ab"); // true
"abcd".startsWith("bc"); // false
"abcd".endsWith("cd");  // true
"abcd".endsWith("e");  // false
"a".startsWith("a");   // true
"a".endsWith("a");    // true

但不幸的是,Javascript中沒有自備這兩個方法,需要的話只能自己寫。當然寫起來也不難就是了。

if (typeof String.prototype.startsWith != 'function') {
 String.prototype.startsWith = function (prefix){
  return this.slice(0, prefix.length) === prefix;
 };
}

String.slice()和String.substring()類似,都是取得一段子字串,但有評測說slice的效率較高。這裡不使用indexOf()的原因是,indexOf會掃描整個字串,如果字串很長,indexOf的效率就會很差。

if (typeof String.prototype.endsWith != 'function') {
 String.prototype.endsWith = function(suffix) {
  return this.indexOf(suffix, this.length - suffix.length) !== -1;
 };
}

和startsWith不一樣,endsWith中可以使用indexOf。原因是它只掃描了最後的一段字串,而比起slice的優勢是它不用複製字串,直接掃描即可,所以效率更高。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn