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>
相关推荐
ice___Cpu7 分钟前
Linux 基本使用和 web 程序部署 ( 8000 字 Linux 入门 )
linux·运维·前端
JYbill10 分钟前
nestjs使用ESM模块化
前端
加油吧x青年28 分钟前
Web端开启直播技术方案分享
前端·webrtc·直播
吕彬-前端1 小时前
使用vite+react+ts+Ant Design开发后台管理项目(二)
前端·react.js·前端框架
小白小白从不日白1 小时前
react hooks--useCallback
前端·react.js·前端框架
恩婧1 小时前
React项目中使用发布订阅模式
前端·react.js·前端框架·发布订阅模式
mez_Blog1 小时前
个人小结(2.0)
前端·javascript·vue.js·学习·typescript
珊珊而川2 小时前
【浏览器面试真题】sessionStorage和localStorage
前端·javascript·面试
森叶2 小时前
Electron 安装包 asar 解压定位问题实战
前端·javascript·electron
drebander2 小时前
ubuntu 安装 chrome 及 版本匹配的 chromedriver
前端·chrome