举例
例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