最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 正经人一辈子都用不到的 JavaScript 方法总结 (一)

    正文概述 掘金(编程三昧)   2021-08-25   262

    这是我参与8月更文挑战的第24天,活动详情查看:8月更文挑战

    前言

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

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

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

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

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

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

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

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

    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个字符,
    // 任何类型的转义形式都会失效,保留原样输出,不信你试试.length
    
    let 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;
    

    正确显示:

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

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

    总结

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

    ~

    ~本文完,感谢阅读!

    ~


    起源地下载网 » 正经人一辈子都用不到的 JavaScript 方法总结 (一)

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元