'14 2'
转换为包含两个整数的数组。如何操作呢?现代浏览器可轻松实现:
'14 2'.split(' ').map(Number);
// [14, 2]`
您可以使用.split()
来获取一个字符串数组,然后循环遍历将它们转换为数字,就像这样:
var myArray = "14 2".split(" ");
for(var i=0; i<myArray.length; i++) { myArray[i] = +myArray[i]; }
//use myArray, it's an array of numbers
+myArray[i]
是进行数字转换的一种快速方式,如果你确定它们是整数,你可以直接这样做:
for(var i=0; i<myArray.length; i++) { myArray[i] = parseInt(myArray[i], 10); }
for(var i=myArray.length; i--;) myArray[i] = myArray[i]|0;
翻译为:for(var i=myArray.length; i--;) myArray[i] = ~~myArray[i];
。 - vsyncmyArray.forEach(function(x,y,z){ z[y]=x|0 })
- vsync.min.js
和.js
文件。请记住,代码压缩并不是为了使代码难以理解(或者不应该是),而是为了减少HTTP开销,从而更快地加载页面以便于用户使用。 - Nick Craver虽然这是一个旧帖子,但我还是想回复一下...
@RoccoMusolino 指出了一个不错的问题,这里提供另一种方法:
简而言之:
const intArray = [...("5 6 7 69 foo 0".split(' ').filter(i => /\d/g.test(i)))]
WRONG: "5 6 note this foo".split(" ").map(Number).filter(Boolean); // [5, 6]
这里列出的更优雅的解决方案存在一个微妙的缺陷,特别是@amillara和@Marcus的优美答案。问题出现在字符串数组的一个元素不像整数,例如在没有输入验证的情况下的案例。以下是一个虚构的示例...
问题:
var effedIntArray = "5 6 7 69 foo".split(' ').map(Number); // [5, 6, 7, 69, NaN]
显然,你需要一个纯整数数组,这是一个问题。老实说,我直到将 SO 代码复制粘贴到我的脚本中才注意到这个问题... :/
稍微不那么炫酷的 解决方法:
var intArray = "5 6 7 69 foo".split(" ").map(Number).filter(Boolean); // [5, 6, 7, 69]
所以,现在即使您有一个糟糕的int字符串,输出也是一个纯整数数组。其他情况下可能更加优美,但我想提供我的大多啰嗦的w'actually。尽管如此,这仍然是一个一行代码的解决方案,可以算作我的功劳...
希望它能为某人节省时间!
.filter( (x) => !Number.isNaN(x))
替换 .filter(Boolean)
。 - Bob9630var result = "14 2".split(" ").map(function(x){return parseInt(x)});
parseInt()
函数应该始终传递一个进制参数。 - Nick Craver.map
和类似的JS功能,而无需额外的库。 - JAL'14 2'.split(' ').map(x=>+x);
// [14, 2]`
使用parseInt
方法的缺点:
不需要使用lambda表达式或给parseInt
方法传递radix
参数,可以使用parseFloat
或Number
方法代替。
原因:
It's working:
var src = "1,2,5,4,3";
var ids = src.split(',').map(parseFloat); // [1, 2, 5, 4, 3]
var obj = {1: ..., 3: ..., 4: ..., 7: ...};
var keys= Object.keys(obj); // ["1", "3", "4", "7"]
var ids = keys.map(parseFloat); // [1, 3, 4, 7]
var arr = ["1", 5, "7", 11];
var ints= arr.map(parseFloat); // [1, 5, 7, 11]
ints[1] === "5" // false
ints[1] === 5 // true
ints[2] === "7" // false
ints[2] === 7 // true
It's shorter.
It's a tiny bit quickier and takes advantage of cache, when parseInt
-approach - doesn't:
// execution time measure function
// keep it simple, yeah?
> var f = (function (arr, c, n, m) {
var i,t,m,s=n();
for(i=0;i++<c;)t=arr.map(m);
return n()-s
}).bind(null, "2,4,6,8,0,9,7,5,3,1".split(','), 1000000, Date.now);
> f(Number) // first launch, just warming-up cache
> 3971 // nice =)
> f(Number)
> 3964 // still the same
> f(function(e){return+e})
> 5132 // yup, just little bit slower
> f(function(e){return+e})
> 5112 // second run... and ok.
> f(parseFloat)
> 3727 // little bit quicker than .map(Number)
> f(parseFloat)
> 3737 // all ok
> f(function(e){return parseInt(e,10)})
> 21852 // awww, how adorable...
> f(function(e){return parseInt(e)})
> 22928 // maybe, without '10'?.. nope.
> f(function(e){return parseInt(e)})
> 22769 // second run... and nothing changes.
> f(Number)
> 3873 // and again
> f(parseFloat)
> 3583 // and again
> f(function(e){return+e})
> 4967 // and again
> f(function(e){return parseInt(e,10)})
> 21649 // dammit 'parseInt'! >_<
注意:在Firefox浏览器中,parseInt
函数的速度比其他浏览器快4倍左右,但仍然比其他函数慢。综合来看:+e
< Number
< parseFloat
< parseInt
首先按空格分割字符串:
var result = '14 2'.split(' ');
for (var i in result) {
result[i] = parseInt(result[i], 10);
}
parseInt()
传递一个基数参数,否则可能会得到八进制数。 - Nick Craver0
或0x
开头,那么就没问题。 - Marcus Whybrow\s+
。Number
函数将每个元素map
转换。请注意,parseInt
不能工作(即arr.map(parseInt)
),因为map
将三个参数传递给映射函数:元素、索引和原始数组。parseInt
将第二个参数作为基数或进制,因此它最终会将索引作为基数,从而在结果中产生许多NaN
。但是,Number
忽略除第一个参数外的任何参数,因此它可以直接起作用。const str = '1\t\t2 3 4';
const result = str.split(/\s+/).map(Number); //[1,2,3,4]
Array#filter
和 isNaN
可以一起过滤掉非数字元素。const str = '1\t\t2 3 ab 4 c';
const result = str.split(/\s+/).map(Number).filter(x => !isNaN(x)); //[1,2,3,4]
const str = '1\t\t2 3 4';
const result = str.split(/\s+/).map(x => +x); //[1,2,3,4]
parseInt
也可以工作。const str = '1\t\t2 3 4';
const result = str.split(/\s+/).map(x => parseInt(x)); //[1,2,3,4]
仅仅为了好玩,我想也提供一个forEach(f())
的解决方案。
var a=[];
"14 2".split(" ").forEach(function(e){a.push(parseInt(e,10))});
// a = [14,2]
let idsArray = ids.split(',').map((x) => parseInt(x));