前言

假如有这样一个需求:要求将给定的一个文件路径 D:\bianchengsanmei\blogs\categories\JavaScript 在页面展示出来。

最基本的实现方法可能是下面这个:

<body><div id = "container"></div>
</body>
const filePath = "D:\bianchengsanmei\blogs\categories\JavaScript";
document.querySelector("#container").innerText = filePath;

如果真能这么简单就实现的话,那我这篇文章到这里就结束了,这是要写个寂寞吗?

结束是不可能结束的,不信,你看看输出结果:

显然,我们很多时候会忘记有转义符这回事。

因为在 HTML 网页里,像 >、<、 等字符是由特殊含义的,再加上有些字符在 ASCII 字符集中没有定义,因此需要使用转义字符串来表示。

要想正确显示,应该这么写:

const filePath = "D:\\bianchengsanmei\\blogs\\categories\\JavaScript";
document.querySelector("#container").innerText = filePath;

转义符 + “\” 表示的是字符串 \。

我今天写这篇文章的意思呢,就是推荐给大家另外一种实现方法。

String.raw 简介

String.raw() 是一个模板字符串的标签函数,用来获取一个模板字符串的原始字符串的,比如说,占位符(例如 ${foo})会被处理为它所代表的其他字符串,而转义字符(例如 \n)不会。

语法

String.raw(callSite, ...substitutions)
String.raw`templateString`

参数

  • callSite 一个模板字符串的“调用点对象”。类似{ raw: [‘foo’, ‘bar’, ‘baz’] }。
  • …substitutions 任意个可选的参数,表示任意个内插表达式对应的值。
  • templateString 模板字符串,可包含占位符(${…})。

返回值

给定模板字符串的原始字符串。

使用示例

以下是一些关于 String.raw 的使用示例:

String.raw`Hi\n${2+3}!`;
// 'Hi\\n5!',Hi 后面的字符不是换行符,\ 和 n 是两个不同的字符String.raw `Hi\u000A!`;
// "Hi\\u000A!",同上,这里得到的会是 \、u、0、0、0、A 6个字符,
// 任何类型的转义形式都会失效,保留原样输出,不信你试试.lengthlet name = "Bob";
String.raw `Hi\n${name}!`;
// "Hi\\nBob!",内插表达式还可以正常运行// 正常情况下,你也许不需要将 String.raw() 当作函数调用。
// 但是为了模拟 `t${0}e${1}s${2}t` 你可以这样做:
String.raw({ raw: 'test' }, 0, 1, 2); // 't0e1s2t'
// 注意这个测试, 传入一个 string, 和一个类似数组的对象
// 下面这个函数和 `foo${2 + 3}bar${'Java' + 'Script'}baz` 是相等的.
String.raw({raw: ['foo', 'bar', 'baz']
}, 2 + 3, 'Java' + 'Script'); // 'foo5barJavaScriptbaz'

实现需求

我们使用 String.raw 来实现以下文章开头的需求:

const filePath = String.raw`D:\bianchengsanmei\blogs\categories\JavaScript`;
document.querySelector("#container").innerText = filePath;

正确显示:

可以看到,使用 String.raw 可以原汁原味的输出期望结果,再也不会因为转义字符的原因导致各种预期之外的结果。

总结

我们可以使用 String.raw 来保证模板字符的输出结果是原始值。

~

~本文完,感谢阅读!

~

学习有趣的知识,结识有趣的朋友,塑造有趣的灵魂!

大家好,我是〖编程三昧〗的作者 隐逸王,我的公众号是『编程三昧』,欢迎关注,希望大家多多指教!

你来,怀揣期望,我有墨香相迎! 你归,无论得失,唯以余韵相赠!

知识与技能并重,内力和外功兼修,理论和实践两手都要抓、两手都要硬!

正经人一辈子都用不到的 JavaScript 方法总结 (一)相关推荐

  1. 正经人一辈子都用不到的 JavaScript 方法总结 (二)

    前言 现在有这样一个需求:用一个对象存储某学生的各科成绩,要求每次只能改变科目分数,不能再添加或者删除科目. 分析一下,这个需求其实就是需要创建一个固定属性的对象,其属性不可增删,但属性值可更改. 有 ...

  2. jrtplib 打包做了哪些事_30岁前就实现财务自由的人,都做了哪些事

    作者|一磊 [媛创写作变现营]学员 前段时间,身价过亿的28岁程序员郭宇从字节跳动退休,现旅居日本开温泉酒店的事情引发人们热议. 确实,一个28岁的人,没有特殊的背景,做程序员身家过亿,在这个年纪就选 ...

  3. 他用1年时间,从负债6万到年入百万:最会赚钱的人,都在做这件事

    最近听到这样一种说法:世界上90%的问题都能用钱来解决,剩下10%的问题,也能用钱来缓解. 不能同意再多. 也许你会说:你说得倒轻巧,哪有那么容易做到啊. 的确,对大部分人来说,只有一份工资收入,想要 ...

  4. 把自己当成打工的,一辈子都是打工的!:周鸿祎

    我希望大家这样来理解创业,把创业看成是一种心态,为了实现一个目标,孜孜不倦的去追求.只要你不满足于现状,想法设法去突破,那就是创业.如果你是一个在校学生,是搞电脑,如果你不满足于只是把学分学好,不满足 ...

  5. 懂得一些基本常识,就不会被《非酒精類致命飲料》或者叫做《我一辈子都不再喝可口可乐》的这篇文章所蒙蔽...

    懂得一些基本常识,就不会被<非酒精類致命飲料>或者叫做<我一辈子都不再喝可口可乐>的这篇文章所蒙蔽. 首先,原文说"除去衣物的油脂:将整罐可乐倒在一堆油腻的衣物,加入 ...

  6. 谁说程序员赚得比医生少?网友:我一年的收入医生一辈子都赚不到

    最近,某阿里程序员在脉脉上发布了自己的收入情况,并直言协和医院的主治医生一辈子都赚不到这么多钱.此言论立刻引起了大家的热议,评论数超过500条,如下图所示: 以上可以看出,楼主在阿里里面是P7级别,每 ...

  7. 获取当地天气_6 点起来看天气预报?正经人谁看天气预报,原来是为了看她

    往期文章回顾: 日本最美混血记者,用翘臀征服 NBA,万千人沦陷:我好了​mp.weixin.qq.com九头身模特,牛仔裤女王,却也是恶女?菜菜绪了解一下​mp.weixin.qq.com 「小睡」 ...

  8. “凡事不发朋友圈的人,都是过的不好的人”你认同这句话吗为什么?

    我不认同凡事不发朋友圈的人,都是过得不好的人?恰恰相反,凡事不发朋友圈的人,大部分都是过得很好的人! 本人大约是在2012年开始接触微信,之前跟老板开车,好像老板娘因为充话费还是办业务,送了一台智能机 ...

  9. 想法越多越贫穷,赚钱的人,都是少想多干

    说实话,赚钱是个特别枯燥的过程,而且经常需要去做一些重复,看起来没啥作用的事情. 很多人去创业,为啥失败居多呀? 就是做之前,想象很美好,真的去干了,发现完全不是那么回事. 电影里的创业,一般老板都是 ...

最新文章

  1. 重新分区_完全不需要装软件!教你轻松调整硬盘分区
  2. Android应用截图嵌入到真实设备
  3. 使用Eclipse-Maven-git做Java开发(3)--Eclipse的安装和配
  4. javascript 基础之事件(event)-------1
  5. python快速排序的原理_理解快速排序算法
  6. Python 代码库之Tuple如何append添加元素
  7. 如何屏蔽搜狗浏览器中的广告 搜狗浏览器拦截广告的教程
  8. 生日在java中怎么写_怎样用java做个生日提醒?如果同一天有多个人过生日怎么做?...
  9. ADS1256实现轮询
  10. Python-生成gif图片验证码
  11. 学习管理系统 LMS
  12. 药监局,药品监督管理局
  13. Python自动化测试系列[v1.0.0][Win32模拟键盘]
  14. 机器学习----决策树(一)
  15. OID的获取及使用方法
  16. 【Luat-air105】8.2 fatfs及照片存储
  17. 西行漫记(14):慌神了
  18. 云闪付UA 通过user-agent判断用户是否使用云闪付
  19. 下角标怎么打java_java 实现excel中上下角标处理实现原理
  20. 关于开展2020年全国大学生电子设计竞赛模拟电子系统设计专题邀请赛(TI杯)的第二次通知

热门文章

  1. 如何在悬停而不是单击时使Twitter Bootstrap菜单下拉列表
  2. js判断是否是当前点击对象
  3. android 嵌套分组拖动_Android NestedScrolling嵌套滑动机制
  4. web网络图片查看器Android
  5. 以下不是python内置函数的是_为什么说python内置函数并不是万能的?
  6. 路径规划之曲线插值拟合算法分析
  7. 全向轮机器人直线运动分析
  8. java实现增量更新_Android 增量更新的完整实现步骤
  9. app 如何接收遥控信息_如何选购红外接收头?华新告诉你产品的标准
  10. JavaScript中的(字符串,数字型,布尔型)是如何实现类型转换的?