3 回答
TA贡献1843条经验 获得超7个赞
var str = 'abcdefghijkl';
console.log(str.match(/.{1,3}/g));
注意:使用{1,3}而不是仅{3}包括其余部分,该长度不是3的倍数,例如:
console.log("abcd".match(/.{1,3}/g)); // ["abc", "d"]
还有一些细微之处:
如果您的字符串可能包含换行符(您希望将其视为一个字符而不是拆分字符串),则.不会捕获这些换行符。使用/[\s\S]{1,3}/代替。(感谢@Mike)。
如果您的字符串为空,则当您期望一个空数组时match()将返回null。通过附加来防止这种情况|| []。
因此,您可能最终得到:
var str = 'abcdef \t\r\nghijkl';
var parts = str.match(/[\s\S]{1,3}/g) || [];
console.log(parts);
console.log(''.match(/[\s\S]{1,3}/g) || []);
TA贡献1780条经验 获得超1个赞
如果您不想使用正则表达式...
var chunks = [];
for (var i = 0, charsLength = str.length; i < charsLength; i += 3) {
chunks.push(str.substring(i, i + 3));
}
...否则正则表达式解决方案就很好了:)
TA贡献1752条经验 获得超4个赞
以先前对该问题的答案为基础;以下函数将分割字符串(str)n个数字(size)。
function chunk(str, size) {
return str.match(new RegExp('.{1,' + size + '}', 'g'));
}
演示版
(function() {
function chunk(str, size) {
return str.match(new RegExp('.{1,' + size + '}', 'g'));
}
var str = 'HELLO WORLD';
println('Simple binary representation:');
println(chunk(textToBin(str), 8).join('\n'));
println('\nNow for something crazy:');
println(chunk(textToHex(str, 4), 8).map(function(h) { return '0x' + h }).join(' '));
// Utiliy functions, you can ignore these.
function textToBin(text) { return textToBase(text, 2, 8); }
function textToHex(t, w) { return pad(textToBase(t,16,2), roundUp(t.length, w)*2, '00'); }
function pad(val, len, chr) { return (repeat(chr, len) + val).slice(-len); }
function print(text) { document.getElementById('out').innerHTML += (text || ''); }
function println(text) { print((text || '') + '\n'); }
function repeat(chr, n) { return new Array(n + 1).join(chr); }
function textToBase(text, radix, n) {
return text.split('').reduce(function(result, chr) {
return result + pad(chr.charCodeAt(0).toString(radix), n, '0');
}, '');
}
function roundUp(numToRound, multiple) {
if (multiple === 0) return numToRound;
var remainder = numToRound % multiple;
return remainder === 0 ? numToRound : numToRound + multiple - remainder;
}
}());
#out {
white-space: pre;
font-size: 0.8em;
}
<div id="out"></div>
添加回答
举报