当前位置: 首页 > article >正文

es6中标签模板

之所以写这篇文章,是因为标签模板是一个很容易让人忽略的知识点

首先我们已经非常熟悉模板字符串的使用方法

const name = "诸葛亮"
const templateString = `hello, My name is ${name}`

标签模板介绍

这里的标签模板其实不是模板,而是函数调用的一种特殊形式

“标签”指的就是函数(函数名),紧跟在后面的模板字符串就是它的参数

比如,下面的代码可以正常运行

alert`hello world`

如果模板字符里面有变量,就不是简单的调用了,而是会将模板字符串先处理成多个参数,再调用函数

const name = '诸葛亮'
const age = 18

console.log`hello ${name}, I know your age is ${age}`

控制台打印如下
在这里插入图片描述

const name = '诸葛亮'
const age = 18

const tag = (stringArr, ...args) => {
    console.log('stringArr', stringArr)
    console.log('args', args)
}

tag`hello ${name}, I know your age is ${age}`
// 相当于调用函数tag, tag(['hello ', ', I know your age is ', ''], '诸葛亮', 18)

控制台打印如下
在这里插入图片描述

使用场景

  • 过滤 HTML 字符串,防止用户输入恶意内容
function saferHTML(templateData) {
  let s = templateData[0];
  for (let i = 1; i < arguments.length; i++) {
    let arg = String(arguments[i]);
    s += arg.replace(/&/g, "&amp;").replace(/</g, "&lt;").replace(/>/g, "&gt;");
    s += templateData[i];
  }
  return s;
}

const string = '<script>alert("恶意代码")</script>';
const content = saferHTML`<p>${sender}富文本内容</p>`;
// <p>&lt;script&gt;alert("恶意代码")&lt;/script&gt;富文本内容</p>
  • 多语言转换
i18n`Welcome to China!`
// "欢迎来到中国!"
  • 将命令式编程转为声明式编程
// 命令式编程
const url = 'xxxxxxx'
a.style.color = "red"
a.style.backgroundColor = 'blue'
a.style.fontSize = '18px'
a.style.lineHeight = '26px'
a.href = `https://${url}`
a.target = '_blank'
a.textContent = '点击跳转'

// 声明式编程
a.styles`
	color: red;
	backgroundColor: blue;
	fontSize: 18px;
	lineHeight: 26px;
`.props`
	href: `https://${url}`;
	target: '_blank';
`.content`点击跳转`

http://www.kler.cn/a/228223.html

相关文章:

  • 信息收集(下)
  • 2024 自主创业事业小结和2025展望
  • 双目立体校正和Q矩阵
  • SQL UNION 和 UNION ALL 区别
  • Dify:低代码 AI 应用开发平台详解与实战指南
  • leetcode 2920. 收集所有金币可获得的最大积分
  • 大型软件编程实例分享,诊所门诊处方笺管理系统多台电脑同时使用的软件教程
  • 常用工具类-StringUtils
  • 网易和腾讯面试题精选---API 设计和开发面试问答
  • 387. First Unique Character in a String(字符串中的第一个唯一字符)
  • 【Spring连载】使用Spring Data访问Redis(八)----发布/订阅消息
  • platfrom tree架构下实现3-Wire驱动(DS1302)
  • 【PostgreSQL内核学习(二十六) —— (共享数据缓冲区)】
  • Qt案例 在对QGraphicsView视图修改和撤销修改图元操作时,使用命令模式实现。
  • sqlserver alwayson部署文档手册
  • 一知半解,临时解决ajax跨域请求
  • L2-005 集合相似度 java
  • myql 项目数据库和表的设计
  • 瑞_23种设计模式_工厂模式
  • 【webrtc】跟webrtc学list遍历
  • 洛谷:P2957 [USACO09OCT] Barn Echoes G
  • 通用函数
  • 【C/C++ 14】C++11智能指针
  • MySQL操作问题汇总
  • 06 - python操作xml
  • CI/CD总结