本文介绍如何使用JavaScript将字符串按照“四位、六位、四位”模式进行分割。 假设输入字符串类似于示例图片所示,需要将其按指定长度分段处理。
首先,我们准备一些测试数据:
const cases = [
"GOAC720202EDB",
"GOAC720202MCSMGN06",
"GOAC720202MCSMGN062343456"
];
const segmentLengths = [4, 6, 4]; // 分割长度数组
接下来,我们演示两种实现方法:
方法一:使用reduce
方法
此方法利用reduce
函数迭代处理segmentLengths
数组,每次截取指定长度的字符串片段,并添加到结果数组中。 Infinity
用于处理剩余部分,filter
方法去除空字符串。
cases.forEach(s => {
const result = [...segmentLengths, Infinity] // 添加Infinity处理剩余部分
.reduce(([start, r], length) => {
r.push(s.slice(start, start + length));
return [start + length, r];
}, [0, []])[1] // 获取结果数组
.filter(it => it) // 过滤空字符串
.join(" ");
console.log(`|${result}|`);
});
方法二:使用生成器函数
此方法使用生成器函数seperateBySpace
,更清晰地表达分割逻辑。 生成器函数每次yield
一个分割后的片段。
function* seperateBySpace(s, segmentLengths) {
let begin = 0;
for (const len of segmentLengths) {
yield s.slice(begin, begin + len);
begin += len;
if (begin > s.length) {
return;
}
}
if (begin < s.length) {
yield s.slice(begin);
}
}
cases.forEach(s => {
const result = [...seperateBySpace(s, segmentLengths)].join(" ");
console.log(`|${result}|`);
});
两种方法的输出结果相同:
|GOAC 720202 EDB|
|GOAC 720202 MCSM GN06|
|GOAC 720202 MCSM GN06 2343 456|
选择哪种方法取决于个人偏好和代码风格。 reduce
方法较为简洁,而生成器函数更易于理解和维护,尤其是在分割逻辑更复杂的情况下。 注意方法二的输出与方法一略有不同,这是因为方法二在处理剩余部分时,会将剩余的字符串分成多个片段,如果需要与方法一保持一致,需要修改方法二的逻辑。