热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ECMAScript6模板字面量的常见用法

模板字面量可以理解成是字符串的一种,形式上用反引号将内容括起来。目录特点一:模板字面量会保留反引号内部的空格、回车、tab,会将\n,\t翻译。特

模板字面量可以理解成是字符串的一种,形式上用反引号 `` 将内容括起来。

目录

特点一:模板字面量会保留反引号内部的空格、回车、tab,会将\n,\t翻译。

特点二:支持字符串插值

特点三:和标签函数搭配食用




特点一:模板字面量会保留反引号内部的空格、回车、tab,会将\n,\t翻译。


        //展示保留空格、回车,翻译\n

        let templateLiteral = `    当时共客长安。\n似二陆初来俱少年。`;

        console.log(templateLiteral);


结果

 可见 4个空格被保留,\n被翻译。

顾名思义,模板字面量在定义模板时特别有用,比如


        //展示html模板

        let htmlTemplate = `

           

               

                    行步至春深

               

           

`;

        console.log(htmlTemplate);


控制台输出

当然,如果想要保留\n,\t也是完全可以的~

只需调用String.raw函数


let templatedStr = `\t海绵宝宝和派大星永远是好朋友\n!`;

console.log(String.raw`\t海绵宝宝和派大星永远是好朋友\n!`);


控制台输出

 

 


特点二:支持字符串插值

也就是可以直接在反引号内应用${}的格式把变量值取出来,和其他内容合并成字符串(一对引号搞定拼接)


        //展示模板字面量支持字符串插值

        let subject = 'knowledge';

        let predicative = 'power';

        let interpolatedString = `${subject} is ${predicative} ~`;

        console.log(interpolatedString);


 控制台输出

而且${}内的值可以是自身


        //展示模板字面量支持字符串插值

        let subject = 'knowledge';

        let predicative = 'power';

        let interpolatedString = `${subject} is ${predicative} ~`;

        console.log(interpolatedString);

        interpolatedString = `Now I understand,${interpolatedString}`;

        console.log(interpolatedString);


 控制台输出

 ${}内还可以调用方法


        //展示模板字面量支持字符串插值,并调用方法

        let begin = 'now I understand,';

        let interpolatedString = `${begin.toUpperCase()}what you said to me.`;

        console.log(interpolatedString);


 控制台输出


特点三:和标签函数搭配食用

标签函数的特点:

①接收的第一个参数是被插值分隔的字符串数组

比如

如果传入

`${a}+${b}=${a+b}`

函数的第一个实参是

['','+','=','']

这个字符串数组一共有4个元素,依次为空字符串、加号、等号、空字符串。

可以看出,对于有n个插值的模板字面量,标签函数的第一个参数接收到的字符串数组的大小是n+1。

②接收的参数从第二个开始都是插值的实际值

③可以之间用函数名+模板字面量的形式调用


let name1 = 'SpongeBob';        

let name2 = 'Patrick';

let templatedStr = `${name1}和${name2}永远是好朋友`;

function tagFun(strArr,insert1,insert2){

    console.log(strArr);

    console.log(insert1);

    console.log(insert2);

}

tagFun`${name1}和${name2}永远是好朋友`;


控制台输出

 那么标签函数有什么用呢?

例:styled-components 就是通过 Tag 函数来给 React 和 ReactNative 设置 CSS 样式。

详见:https://styled-components.com/

参考:

1.《Javascript高级程序设计(第四版)》 Matt Frisbie

2. ES6 - 标签函数 


推荐阅读
  • H5技术实现经典游戏《贪吃蛇》
    本文将分享一个使用HTML5技术实现的经典小游戏——《贪吃蛇》。通过H5技术,我们将探讨如何构建这款游戏的两种主要玩法:积分闯关和无尽模式。 ... [详细]
  • 本文详细介绍了 Node.js 中 OS 模块的 arch 方法,包括其功能、语法、参数以及返回值,并提供了具体的使用示例。 ... [详细]
  • 本文探讨了互联网服务提供商(ISP)如何可能篡改或插入用户请求的数据流,并提供了有效的技术手段来防止此类劫持行为,确保网络环境的安全与纯净。 ... [详细]
  • 本文基于Java官方文档进行了适当修改,旨在介绍如何实现一个能够同时处理多个客户端请求的服务端程序。在前文中,我们探讨了单客户端访问的服务端实现,而本篇将深入讲解多客户端环境下的服务端设计与实现。 ... [详细]
  • 本文回顾了作者在求职阿里和腾讯实习生过程中,从最初的迷茫到最后成功获得Offer的心路历程。文中不仅分享了个人的面试经历,还提供了宝贵的面试准备建议和技巧。 ... [详细]
  • 本文探讨了异步编程的发展历程,从最初的AJAX异步回调到现代的Promise、Generator+Co以及Async/Await等技术。文章详细分析了Promise的工作原理及其源码实现,帮助开发者更好地理解和使用这一重要工具。 ... [详细]
  • 利用Node.js实现PSD文件的高效切图
    本文介绍了如何通过Node.js及其psd2json模块,快速实现PSD文件的自动化切图过程,以适应项目中频繁的界面更新需求。此方法不仅提高了工作效率,还简化了从设计稿到实际应用的转换流程。 ... [详细]
  • 本文探讨了如何通过优化 DOM 操作来提升 JavaScript 的性能,包括使用 `createElement` 函数、动画元素、理解重绘事件及处理鼠标滚动事件等关键主题。 ... [详细]
  • 深入理解Java SE 8新特性:Lambda表达式与函数式编程
    本文作为‘Java SE 8新特性概览’系列的一部分,将详细探讨Lambda表达式。通过多种示例,我们将展示Lambda表达式的不同应用场景,并解释编译器如何处理这些表达式。 ... [详细]
  • 本文探讨了如何使用Scrapy框架构建高效的数据采集系统,以及如何通过异步处理技术提升数据存储的效率。同时,文章还介绍了针对不同网站采用的不同采集策略。 ... [详细]
  • ArcBlock 发布 ABT 节点 1.0.31 版本更新
    2020年11月9日,ArcBlock 区块链基础平台发布了 ABT 节点开发平台的1.0.31版本更新,此次更新带来了多项功能增强与性能优化。 ... [详细]
  • Spring Security基础配置详解
    本文详细介绍了Spring Security的基础配置方法,包括如何搭建Maven多模块工程以及具体的安全配置步骤,帮助开发者更好地理解和应用这一强大的安全框架。 ... [详细]
  • 本文探讨了如何利用RxJS库在AngularJS应用中实现对用户单击和拖动操作的精确区分,特别是在调整区域大小的场景下。 ... [详细]
  • 理解浏览器历史记录(2)hashchange、pushState
    阅读目录1.hashchange2.pushState本文也是一篇基础文章。继上文之后,本打算去研究pushState,偶然在一些信息中发现了锚点变 ... [详细]
  • 八段代码完全控制Promise
    1.Promise的马上实行性varpnewPromise(function(resolve,reject){console.log(createapromise);resolve ... [详细]
author-avatar
520sweet跃_322
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有