修改:
此问题专门解决了使用0
将空字符串以及任意数量的空格字符转换为Number(str)
的问题。
看看下面的代码片段:
convertBtn.addEventListener('click', () => console.log(toArrayOfNumber(foo.value)))
const toArrayOfNumber = str => str.split(',').map(Number);
<input type="text" id="foo" value="1,2,4,-1" />
<button type="button" id="convertBtn">convert to array of numbers</button>
只要输入具有正确的value
,一切正常。现在,我要使它具有以下值的故障保护:
,
, ,,
让我措手不及的是,Number("")
和Number(" ")
都返回0
(我不想用我的用例,我不想""
或任意数量的空格视为Number
)。
所以我想到了这个:
convertBtn.addEventListener('click', () => console.log(toArrayOfNumber(foo.value)))
const toArrayOfNumber = str => str.split(',').filter(x => x.trim() !== "").map(Number);
<input type="text" id="foo" value="1,2,4,-1,,, ,, 11" />
<button type="button" id="convertBtn">convert to array of numbers</button>
这很尴尬,我希望有一个显而易见的更好的解决方案,我看不到。
答案 0 :(得分:2)
@KendallFrey的答案(谁拒绝发帖,所以我要窃取他的解决方案)
'1,2,4,-1,,, ,, 11,0,0'.split(/[, ]+/).map(x=>+x)
您仍然可以使用.map(Number)
,但x=>+x
短1字节。
控制台中的结果:(7) [1, 2, 4, -1, 11, 0, 0]
另一种正则表达式解决方案(不允许使用小数):/-?\d+/g
答案 1 :(得分:2)
如果您仅处理整数,则以下内容也将起作用。将保留0,但将删除空值。
split(',').filter(num => !isNaN(parseInt(num))).map(Number);
示例
const str = '1,2,4,-1,,, ,0, 11';
console.log(str.split(',').filter(num => !isNaN(parseInt(num))).map(Number));
答案 2 :(得分:1)
您也可以通过Array.reduce
进行此操作,在每次迭代中,您都用isNaN
检查parseInt
:
let data = "1,2,4,-1,,, ,0, 11"
let r = data.split(',').reduce((r,c) => isNaN(parseInt(c)) ? r : [...r, +c],[])
console.log(r)
通过这种方式,您仅iterate over the array once
个帖子拆分。同样,这将使零保持不变,并且仅丢弃任何非数字。
答案 3 :(得分:0)
尝试一下:
const value="-99,1,2,4,-1,,, ,0,, 11"
const toArrayOfNumber = str => str.split(',').map(num => num.trim() && Number(num)).filter(num => !Number.isNaN(num) && typeof num != 'string');
const nums = toArrayOfNumber(value);
nums.forEach(num => console.log(typeof num, num));
我们使用trim
的结果来确定是否应该像数字一样处理它。如果没有,那么我们只有一个string
,它就会被过滤掉。