淺談js中startsWith 函數不能在任何瀏覽器兼容的問題
更新時間:2017年03月01日 10:40:14 投稿:jingxian
下面小編就為大家?guī)硪黄獪\談js中startsWith 函數不能在任何瀏覽器兼容的問題。小編覺得挺不錯的,現在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
在做js測試的時候用到了startsWith函數,但是他并不是每個瀏覽器都有的,所以我們一般要重寫一下這個函數,具體的用法可以稍微總結一下
在有些瀏覽器中他是undefined 所以我們可以這樣的處理一下、
if (typeof String.prototype.startsWith != 'function') { String.prototype.startsWith = function (prefix){ return this.slice(0, prefix.length) === prefix; }; }
這個需要放在頁面剛要加載完成的函數里,不然不好使。
還有一種直接重寫 不過我沒測試過,你們可以測試一下:
String.prototype.startWith=function(str){ if(str==null||str==""||this.length==0||str.length>this.length) return false; if(this.substr(0,str.length)==str) return true; else return false; return true; }
有的說js中沒有startsWith 和endWith這兩個函數不過就算不聲明有些瀏覽器他還是可以用的,不過為了兼容性還是希望重寫一下。
if (typeof String.prototype.endsWith != 'function') { String.prototype.endsWith = function(suffix) { return this.indexOf(suffix, this.length - suffix.length) !== -1; }; }
采用正則表達式實現startWith、endWith效果函數
String.prototype.startWith=function(str){ var reg=new RegExp("^"+str); return reg.test(this); } //測試ok,直接使用str.endWith("abc")方式調用即可 String.prototype.endWith=function(str){ var reg=new RegExp(str+"$"); return reg.test(this); }
以上這篇淺談js中startsWith 函數不能在任何瀏覽器兼容的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
javascript實現動態(tài)增加刪除表格行(兼容IE/FF)
javascript實現動態(tài)增加刪除表格行(兼容IE/FF)...2007-04-04