js中startsWith 函数不能在任何浏览器兼容的问题

来源:互联网 发布:csgo fps优化 编辑:程序博客网 时间:2024/06/05 03:57

在做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);} 




1 0