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

系统 浏览器
今天为大家带来一篇浅谈js中startsWith 函数不能在任何浏览器兼容的问题

在做js测试的时候用到了startsWith函数,但是他并不是每个浏览器都有的,所以我们一般要重写一下这个函数,具体的用法可以稍微总结一下。

[[184585]]

在有些浏览器中他是undefined 所以我们可以这样的处理一下

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

这个需要放在页面刚要加载完成的函数里,不然不好使。

还有一种直接重写 不过我没测试过,你们可以测试一下:

  1. String.prototype.startWith=function(str){  
  2.  if(str==null||str==""||this.length==0||str.length>this.length)  
  3.   return false;  
  4.  if(this.substr(0,str.length)==str)  
  5.    return true;  
  6.  else 
  7.    return false;  
  8.  return true;  

有的说js中没有startsWith 和endWith这两个函数不过就算不声明有些浏览器他还是可以用的,不过为了兼容性还是希望重写一下。

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

采用正则表达式实现startWith、endWith效果函数

  1. String.prototype.startWith=function(str){ 
  2. var reg=new RegExp("^"+str); 
  3. return reg.test(this); 
  4. //测试ok,直接使用str.endWith("abc")方式调用即可 
  5. String.prototype.endWith=function(str){ 
  6. var reg=new RegExp(str+"$"); 
  7. return reg.test(this); 
  8. }  

以上这篇浅谈js中startsWith 函数不能在任何浏览器兼容的问题就是小编分享给大家的全部内容了,希望能给大家一个参考,

责任编辑:赵宁宁 来源: 脚本之家
相关推荐

2010-09-16 11:21:54

FirefoxJS

2010-09-15 09:43:24

Javascript浏览器兼容

2010-08-11 13:35:10

JavaScriptCSS

2011-04-12 16:51:29

Javascript兼容性

2017-04-26 14:15:35

浏览器缓存机制

2011-08-29 14:27:33

QTWebkit浏览器

2013-01-21 15:33:30

浏览器

2016-09-18 20:48:21

苹果safari浏览器

2017-05-15 13:40:20

浏览器http缓存机制

2010-10-09 13:07:51

Javascript兼容

2010-09-16 13:48:15

CSS Hack

2010-09-15 09:12:03

JavaScript浏览器兼容

2009-06-22 14:06:00

java浏览器

2017-05-02 09:25:13

浏览器指纹追踪虚拟化

2011-06-10 16:44:17

Qt 浏览器

2010-08-30 15:40:31

CSS浏览器兼容

2012-08-02 10:21:49

DOM浏览器

2013-07-08 14:45:52

2010-08-11 15:17:51

浏览器兼容性问题

2020-08-31 19:20:33

浏览器CORS跨域
点赞
收藏

51CTO技术栈公众号