ES6系列之模板字符串

本文介绍了ES6中的模板字符串特性,包括基础用法、嵌入变量、对运算的支持及模板字符串调用函数。模板字符串允许直接在字符串中插入变量,保留空格和换行,并能直接执行JS表达式,简化了字符串处理操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

模板字符串是ES6中非常重要的一个新特性,这个特性使得处理相关业务变得更加容易。

基础用法

let a = `hello world`;
console.log(a); // hello world

注意这里不是双引号,而是反撇号`

在模板字符串中,还可以拼接html元素,同时空格、缩进、换行都会被保留,并且如果模板字符串中的变量没有声明,将报错。

let str = `
    <div>
        <ul>
            <li>11</li>
            <li>22</li>
        </ul>
    </div>
`;

上面代码中,<div>标签前面会有一个换行。如果你不想要这个换行,可以使用trim方法消除它。

let str = `
    <div>
        <ul>
            <li>11</li>
            <li>22</li>
        </ul>
    </div>
`.trim();
console.log(str);

在模版字符串内使用反引号`时,需要在它前面加转义符\

let a = `hello \\n`;
console.log(a);

嵌入变量

let name = 'jacky';
let str = '我叫' + name + ',大家好';
console.log(str); // 我叫jacky,大家好

当有变量参与拼接时,ES5下必须用+号这样的形式进行拼接,这样很麻烦而且很容易出错。
ES6新增了字符串模版,可以很好的解决这个问题。这时再引用str变量就需要用${name}这种形式了。

let name = 'jacky';
let str = '我叫${name},大家好';
console.log(str); // 我叫jacky,大家好

如果大括号内部是一个字符串,将会原样输出:

let world = '666';
let a = `hello ${'world'}`;
console.log(a); // hello world

对运算的支持

在${}里面,可以写任意的JS表达式,比如我们用它进行运算

let a = 1;
let b = 2;
let c = `${a+b}`;
console.log(c); //3

let obj = { x: 1, y: 2 };
console.log(`${obj.x + obj.y}`); // 3

模板字符串调用函数

function fn() {
    return "Hello World";
}
console.log(`foo ${fn()} bar`); // foo Hello World bar
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值