标签模板字面量的用法

1、处理复杂的字符串

  • 标签函数format 被定义为接受两个参数: strings:模板字符串中的所有文本部分,作为一个字符串数组传入。

  • …values:模板字符串中被 ${} 包裹的表达式的计算结果,作为一个数组传入。
    使用 reduce 合并结果:

  • reduce 函数通过累加器 acc 逐步拼接字符串数组 strings 中的文本,并将相应的 values 值插入到指定位置。循环索引i 用于定位 values 中的正确值。 在模板中,如果存在对应的表达式值 (values[i]),则该值会被包裹在 标签中实现加粗效果;否则,只添加字符串 str 本身。

  • reduce 从空字符串 ‘’ 开始,逐步将每段模板字符串 str 和相应的表达式值合并,最终生成完整的字符串,输出为:Hello, Alice! You have 12 new messages.。

function format(strings, ...values) {
    return strings.reduce((acc, str, i) => {
        return `${acc}${str}${values[i] ? `<b>${values[i]}</b>` : ''}`;
    }, '');
}



const name = "世界";
const result = processTemplate`你好,${name}! 今天天气怎么样?`;
console.log(result);  // 输出: 你好,世界! 今天天气怎么样?

2、使用标签可以在多层嵌套循环中直接退出外层循环

outerLoop: for (let i = 0; i < 5; i++) {
    for (let j = 0; j < 5; j++) {
        if (i === 3 && j === 3) {
            break outerLoop; // 当i和j都等于3时退出外层循环
        }
        console.log(`i = ${i}, j = ${j}`);
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值