es6模板字符串_es6字符串模板

es6模板字符串_es6字符串模板模板字符串主要用于插入表达式!

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

前言:看了MDN的官方文档,让我一个头两个大。可能又陷入了完美主义的陷阱:总是想一下子把关于某方面的知识全部看完,全部看懂。就像我本来只是想查看一下单词take,却把所有的关于take的短语看了一遍,结果一个没记住。有些用法可能从它诞生到以后被废弃都使用不到,花费时间在它上面没有任何意义。因此,我是想介绍一下它最基础,最核心的用法。其他不常用用法可能会一笔带过。

一、模板字符串

模板字符串是可以插入表达式的字符串字面量

在ES6(ES2015)中引入,另外,它还可以具有多行文本,换句话说可以直接输出回车换行符。

1. 模板字符串和传统字符串比较

传统字符串字面量使用单引号''或者双引号"",如下所示

var str = 'hello world';
var str2 = "hello world";

模板字符串使用反单引号(backquote) ``,如下所示

var str3 = `hello world`;

反单引号位置,如下图所示,英文输入状态下按下可输入

在这里插入图片描述

形式虽然有差别,但是作为字符串字面量本质上是完全等价的。

在这里插入图片描述

2. 模板字符串可以插入表达式 (重点)

语法如下

`${expression}`

简介:expression可以是任意常量、变量、函数调用。在${expression}前后,也可以有任意的其他合法的字符,例如`abc${expression}xyz`。最终,${expression} 会转化为字符串和前后的字符串拼接,如果有的话。

当没有字符串时,我们想打印一个对象的信息,只能通过字符串拼接。

var xiaoming = { 
   
	name: '小明',
	age: 14,
	sex: 'male'
};

var bio = 'name: ' + xiaoming.name + ', age: ' + xiaoming.age + ', sex: ' + 'male';

console.log(bio);

现在,只有三个属性,拼接字符串还可以介绍。但是,当对象的属性比较多时,拼接字符串就会很费时费力。这时,应该用模板字符串。

var xiaoming = { 
   
	name: '小明',
	age: 14,
	sex: 'male'
};

var bio = `name: ${ 
     xiaoming.name}, age: ${ 
     xiaoming.age}, sex: ${ 
     xiaoming.sex}`;

console.log(bio);

可以达到相同的目的
在这里插入图片描述
表达式可以是一个常量、变量、函数调用,它们最终都可返回一个值,这个值会被转换成字符串类型,然后和其他字符拼接。如果是引用类型的值,会调用对象的toString方法,最终把返回字符串拼接

在这里插入图片描述

在这里插入图片描述

3. 模板字符串可以有多行文本

可以直接在``中输入回车换行符

var str = `我是第一行 我是第二行`

输出效果在这里插入图片描述

这在传统字符中是不允许的,直接插入换行符

JavaScript会报错:

在这里插入图片描述

主要适用于字符串中包含HTML标签的场景。如果是纯文本字符串,你输入回车字符串,这是代码缩进中的字符也会被包含进来。
在这里插入图片描述

输出效果

在这里插入图片描述
这时,你只能把代码中的缩进字符删除,但是会影响代码的可读性,得不偿失。但是如果字符串中时html标签,最终要插入到dom树中,缩进的字符会因为html的空白折叠现象忽略,因此可以使用。如果单纯再代码中使用字符串,完全没必要使用这个功能,简直是一种鸡肋的存在。

二、学生信息加载demo

一个小demo,练习下模板字符串的使用

代码如下:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>

    <style> span { 
      font-weight:bold; } </style>
</head>
<body>

    <h1>学生信息列表</h1>
    <ul id="list">
        <li id='info'>信息加载中...</li>
    </ul>

    <script> const students = [ { 
      name: 'Alice', age: 20, sex: 'famale' }, { 
      name: 'Jimmy', age: 15, sex: 'male' }, { 
      name: 'xiaoxiao', age: 23, sex: 'female' } ]; const list = document.querySelector('#list'); let index = 0; const printTimer = setInterval(()=>{ 
      if (index >= students.length) { 
      clearInterval(printTimer); document.getElementById('info').innerText = '信息加载完毕!'; } let liNode = document.createElement('li'); liNode.innerHTML = `<span>name: </span>${ 
       students[index].name}, <span>age: </span>${ 
       students[index].age}, <span>sex: </span>${ 
       students[index].sex}`; list.appendChild(liNode); index ++; }, 2000) </script>
</body>
</html>

效果如下:
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/171842.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月21日 上午7:16
下一篇 2022年8月21日 上午7:36


相关推荐

  • Vue项目打包部署总结

    Vue项目打包部署总结关注公众号前端开发博客 回复 加群 加入我们一起学习 天天进步作者 沐码链接 https wintc top article 29 使用 Vue 做前后端分离项目时 通常前端是单独部署

    2026年3月19日
    2
  • java、spring线程池面试题

    java、spring线程池面试题一、线程池的好处?1.通过newThread来创建线程池会比较耗时,性能差,当我们在通过线程的时候,有可能会出现(创建线程+销毁线程)的时长>线程执行(业务逻辑)的时长;2.线程缺乏统一管理,可能会出现无限制的创建线程,线程之间相互竞争,争夺资源而导致系统崩溃;3.缺乏更多的管理功能,比如定时执行、定期执行、线程中断;相比较于newThread,创建线程的好处在于:1.重用已存在的线程,避免线程新建和消亡产生的开销。2.可以控制最大并发数,避免同时多个线程执行,争夺资源,导致系统崩溃;

    2022年5月6日
    76
  • 什么软件可以更换手机ip地址「建议收藏」

    什么软件可以更换手机ip地址「建议收藏」这里写自定义目录标题欢迎使用Markdown编辑器新的改变功能快捷键合理的创建标题,有助于目录的生成如何改变文本的样式插入链接与图片如何插入一段漂亮的代码片生成一个适合你的列表创建一个表格设定内容居中、居左、居右SmartyPants创建一个自定义列表如何创建一个注脚注释也是必不可少的KaTeX数学公式新的甘特图功能,丰富你的文章UML图表FLowchart流程图导出与导入导出导入欢迎使用Markdown编辑器你好!这是你第一次使用Markdown编辑器所展示的欢迎页。如果你想学习如何使用Mar

    2022年6月17日
    31
  • MySQL中的锁机制详细说明[通俗易懂]

    MySQL中的锁机制详细说明[通俗易懂]一、MySQL锁机制起步锁是计算机用以协调多个进程间并发访问同一共享资源的一种机制。MySQL中为了保证数据访问的一致性与有效性等功能,实现了锁机制,MySQL中的锁是在服务器层或者存储引擎层实现的。二、行锁与表锁首先我们来了解行锁与表锁的基本概念,从名字中我们就可以了解:表锁就是对整张表进行加锁,而行锁则是锁定某行、某几行数据或者行之间的间隙。各引擎对锁的支持情况如下:行锁表锁页锁MyISAM√BDB√√InnoDB√√1.行锁A

    2022年9月29日
    4
  • SQL语句中创建表的语句_用sql创建表

    SQL语句中创建表的语句_用sql创建表mysql创建表的sql语句mysql建表常用sql语句:连接:mysql-h主机地址-u用户名-p用户密码(注:u与root可以不用加空格,其它也一样)断开:exit(回车)创建授权:grantselecton数据库.*to用户名@登录主机identifiedby”密码”修改密码:mysqladmin-u用户名-p旧密码password新密码删除授权:revo…

    2022年10月17日
    4
  • Docker安装RabbitMQ教程「建议收藏」

    Docker安装RabbitMQ教程「建议收藏」本章教程介绍如何利用Docker快速搭建RabbitMQ环境。目录一、拉取镜像二、运行容器三、访问测试一、拉取镜像dockerpullrabbitmq:3.7.7-management二、运行容器dockerrun-d–namerabbitmq3.7.7-p5672:5672-p15672:15672-v`pwd`/data:/var/lib/rabbitmq–hostnamemyRabbit-eRABBITMQ_DEFAUL..

    2022年5月23日
    38

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号