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>
相关推荐
Bellafu66636 分钟前
selenium 常用xpath写法
前端·selenium·测试工具
blackorbird3 小时前
Edge 浏览器 IE 模式成攻击突破口:黑客借仿冒网站诱导攻击
前端·edge
谷歌开发者4 小时前
Web 开发指向标 | Chrome 开发者工具学习资源 (一)
前端·chrome·学习
名字越长技术越强4 小时前
Chrome和IE获取本机ip地址
前端
天***88964 小时前
Chrome 安装失败且提示“无可用的更新” 或 “与服务器的连接意外终止”,Chrome 离线版下载安装教程
前端·chrome
半梦半醒*4 小时前
zabbix安装
linux·运维·前端·网络·zabbix
清羽_ls5 小时前
React Hooks 核心规则&自定义 Hooks
前端·react.js·hooks
你的人类朋友5 小时前
“签名”这个概念是非对称加密独有的吗?
前端·后端·安全
西陵5 小时前
Nx带来极致的前端开发体验——任务缓存
前端·javascript·架构
10年前端老司机6 小时前
Promise 常见面试题(持续更新中)
前端·javascript