ECMAScript6模板字面量:反引号、${}占位符的使用

ECMAScript 6 中引入了模板字面量,主要通过多行字符串和字符串占位符对字符串进行增强操作。如下:

javascript 复制代码
//使用ECMAScript6模板字面量拼接字符串,例如:2024年8月12日 15:38:28 星期一
let dateRet = `${Year}年${Month}月${Dates}日 ${Hours}:${Minutes}:${Seconds} ${Week}`;

1、反引号的使用

模板字面量的基础语法是使用反引号"`"替换字符串的单引号或双引号。

javascript 复制代码
let str = `月落乌啼霜满天,
江枫渔火对愁眠。
姑苏城外寒山寺,
夜半钟声到客船。`

2、${}占位符的使用

在一个模板字面量中,允许将变量或任何合法的表达式嵌入占位符并将其作为字符串的一部分。字符串占位符使用:${}。

(1)将定义的变量嵌入占位符并将其放在字符串中进行输出。

javascript 复制代码
let name = "Tony";
let sex = "男";
let age = 25;
let str = `姓名:${name} 性别:${sex} 年龄:${age}`;
document.write(str); //输入:姓名:Tony 性别:男 年龄:25

(2)将表达式嵌入占位符并将其放在字符串中进行输出。

javascript 复制代码
let unitPrice = 566;
let number = 6;	
let str = `商品总价:${unitPrice * number}元`;
document.write(str); //输入:商品总价:3396元

3、综合实例

**【实例】**使用ECMAScript6模板字面量拼接字符串,实现日期时间的显示,执行结果如下图:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>ECMAScript6模板字面量</title>
</head>
<body>
    <p id="clock"></p>
</body>

<script type="text/javascript">
window.onload = function () {
    realTime(); //获取日期时间
    setInterval(function() { realTime() }, 1000);  //循环调用
}

//获取日期时间
function realTime()
{
    let dateTime = new Date();
    let Year = dateTime.getFullYear().toString();
    let tMonth = String(dateTime.getMonth() + 1);
    let Month = douPosit(tMonth);
    let tDates = dateTime.getDate().toString();
    let Dates = douPosit(dateTime.getDate().toString());
    let Hours = douPosit(dateTime.getHours().toString());
    let Minutes = douPosit(dateTime.getMinutes().toString());
    let Seconds = douPosit(dateTime.getSeconds().toString());
    let Week = convertDay(dateTime); //获取日期是周几

    //使用ECMAScript6模板字面量拼接字符串,例如:2024年8月12日 15:38:28 星期一
    let dateRet = `${Year}年${Month}月${Dates}日 ${Hours}:${Minutes}:${Seconds} ${Week}`;
    document.getElementById('clock').innerText=dateRet;
}

//个位数补两位数
function douPosit(numStr) {
    if (numStr != null && numStr.length == 1) {
        numStr = "0" + numStr;
    }
    return numStr;
}

//获取日期是周几
function convertDay(thisDate) {
    var dayRet = null;
    var show_day = new Array('星期日', '星期一', '星期二', '星期三', '星期四', '星期五', '星期六');
    if (thisDate != null) {
        var day = thisDate.getDay();
        dayRet = show_day[day];
    }
    return dayRet;
}
</script>
</html>
相关推荐
ekskef_sef14 分钟前
32岁前端干了8年,是继续做前端开发,还是转其它工作
前端
sunshine64139 分钟前
【CSS】实现tag选中对钩样式
前端·css·css3
真滴book理喻1 小时前
Vue(四)
前端·javascript·vue.js
蜜獾云1 小时前
npm淘宝镜像
前端·npm·node.js
dz88i81 小时前
修改npm镜像源
前端·npm·node.js
Jiaberrr1 小时前
解锁 GitBook 的奥秘:从入门到精通之旅
前端·gitbook
顾平安2 小时前
Promise/A+ 规范 - 中文版本
前端
聚名网2 小时前
域名和服务器是什么?域名和服务器是什么关系?
服务器·前端
桃园码工2 小时前
4-Gin HTML 模板渲染 --[Gin 框架入门精讲与实战案例]
前端·html·gin·模板渲染
不是鱼3 小时前
构建React基础及理解与Vue的区别
前端·vue.js·react.js