首页 > js的数组方法中,哪一些性能比较好的方法

js的数组方法中,哪一些性能比较好的方法

举例

例1:

const url = "http://test15-www.baidu.com"
let testHead = null
testHead = url.substr(0,url.indexOf('-'))
console.log(testHead)

例2:

const url = "http://test15-www.baidu.com"
let testHead = null
testHead = url.split("-")[0]
console.log(testHead)

js基础差,目前只想到这两个方法来取得“-”之前的字符,请问下,上面例2是被说性能不好的例子,那么第一个呢?或者还有哪些别的方法更好的实现这个功能,而且性能还好的?


const url = "http://test15-www.baidu.com"
let testHead = null
var time = new Date();
var reg = new RegExp('^([^-]+)-');
for(var i =0;i<1000000;i++){
    reg.exec(url)[1]
}
console.log(new Date-time)
// 86 90 84

const url = "http://test15-www.baidu.com"
let testHead = null
var time = new Date();
for(var i =0;i<1000000;i++){
    testHead = url.substr(0,url.indexOf('-'))
}
console.log(new Date-time)
//89 87 86

const url = "http://test15-www.baidu.com"
let testHead = null
var time = new Date();
for(var i =0;i<1000000;i++){
    testHead = url.split("-")[0]
}
console.log(new Date-time)
//94 173 92

感觉正则表达式更直接简单。


如果不是性能特别差的情况,不要太在意性能的问题,

还可以用正则表达式

const url = "http://test15-www.baidu.com";
let m = url.match(/^(.*?)-/);
if (m) {
    console.log(m[1]);
}

去看看 MDN 上的 Array.prototype 和 RegExp

【热门文章】
【热门文章】