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

ES6的高阶语法特性

一、模板字符串的高级用法

1.1.模板字符串的嵌套

模板字符串的嵌套允许在一个模板字符串内部再嵌入一个或多个模板字符串。这种嵌套结构在处理复杂数据结构或生成具有层级关系的文本时非常有用。

1. 嵌套示例

假设我们有一个包含多个对象的数组,每个对象都有名称、描述和价格属性。我们可以使用嵌套的模板字符串来生成一个包含这些对象信息的表格

const products = [{ name: 'Product A', description: 'This is product A', price: 100 },{ name: 'Product B', description: 'This is product B', price: 200 }
];const tmpl = products => `<table border="1"><tr><th>Name</th><th>Description</th><th>Price</th></tr>${products.map(product => `<tr><td>${product.name}</td><td>${product.description}</td><td>${product.price.toFixed(2)}</td></tr>`).join('')}</table>
`;console.log(tmpl(products));

在这个例子中,内部的模板字符串用于生成每个表格行的内容,而外部的模板字符串则负责将这些行组合成一个完整的HTML表格。

2. 嵌套深度

模板字符串的嵌套深度可以根据需要调整。例如,如果我们的数据结构包含多层嵌套的对象或数组,我们可以相应地增加模板字符串的嵌套层级

const nestedData = [{id: 1,name: 'Category 1',items: [{ id: 101, name: 'Item 1-1', price: 50 },{ id: 102, name: 'Item 1-2', price: 60 }]},{id: 2,name: 'Category 2',items: [{ id: 201, name: 'Item 2-1', price: 70 },{ id: 202, name: 'Item 2-2', price: 80 }]}
];const nestedTmpl = nestedData => `<ul>${nestedData.map(category => `<li><h2>${category.name}</h2><ul>${category.items.map(item => `<li>${item.name} - $${item.price.toFixed(2)}</li>`).join('')}</ul></li>`).join('')}</ul>
`;console.log(nestedTmpl(nestedData));

在这个例子中,我们有一个包含类别和项目的嵌套数据结构。我们使用嵌套的模板字符串来生成一个包含这些类别和项目的HTML列表。

1.2.标签模板的详细分析

标签模板是一种特殊的函数调用,它允许对模板字符串进行自定义处理。标签模板函数接收一个字符串数组(由模板字符串中的静态文本部分组成)和一个包含模板字符串中表达式求值结果的剩余参数列表。

1.字符串格式化

标签模板函数可以用于实现复杂的字符串格式化逻辑。例如,我们可以创建一个函数来格式化货币金额

function formatCurrency(strings, ...values) {const currencySymbol = '$';const decimalPlaces = 2;return strings.reduce((result, str, idx) => {result += str;if (idx < values.length) {result += `${currencySymbol}${values[idx].toFixed(decimalPlaces)}`;}return result;}, '');
}const price = 1234.5678;
console.log(formatCurrency`The price is ${price}`); // 输出 "The price is $1234.57"

在这个例子中,formatCurrency函数接收一个模板字符串和一个或多个值。它遍历模板字符串的静态文本部分和值,将每个值格式化为货币金额,并将结果组合成一个完整的字符串。

2. 自定义插值逻辑

        标签模板函数不仅可以用于简单的字符串插值,还可以对插入的变量或表达式进行自定义处理。例如,我们可以创建一个函数来将插入的字符串转换为大写,并在其前后添加特定的标记:

function customInterpolate(strings, ...values) {return strings.reduce((result, str, idx) => {result += str;if (idx < values.length) {result += `[${values[idx].toUpperCase()}]`;}return result;}, '');
}const text = 'hello';
console.log(customInterpolate`This is a ${text} world!`);
// 输出 "This is a [HELLO] world!"

在这个例子中,customInterpolate函数接收一个模板字符串和一个或多个值。它遍历模板字符串的静态文本部分和值,将每个值转换为大写,并在其前后添加方括号作为标记,然后将结果组合成一个完整的字符串。

3. 防止XSS攻击

在处理用户输入时,标签模板函数还可以用于防止跨站脚本攻击(XSS)。通过自定义处理函数,我们可以对用户输入进行HTML转义,从而避免潜在的XSS漏洞。

function escapeHTMLTags(strings, ...values) {const escapeMap = {'&': '&amp;','<': '&lt;','>': '&gt;','"': '&quot;',"'": '&#39;'};const escape = (str) => str.replace(/[&<>"']/g, (char) => escapeMap[char]);return strings.reduce((result, str, idx) => {result += str;if (idx < values.length) {result += escape(values[idx]);}return result;}, '');
}const userInput = '<script>alert("XSS!");</script>';
console.log(escapeHTMLTags`Safe input: ${userInput}`); 
// 输出 "Safe input: &lt;script&gt;alert(&quot;XSS!&quot;);&lt;/script&gt;"

        在这个例子中,escapeHTMLTags函数接收一个模板字符串和一个或多个值。它遍历模板字符串的静态文本部分和值,对每个值进行HTML转义,并将结果组合成一个安全的字符串。这样,即使用户输入包含恶意代码,也不会被执行,从而防止了XSS攻击。

        模板字符串的嵌套和标签模板功能为字符串的格式化、插值等操作提供了极大的灵活性和便利性。在实际开发中,我们可以根据具体需求选择合适的模板字符串用法来优化代码的可读性和可维护性。同时,我们还需要注意处理用户输入时的安全性问题,避免潜在的XSS漏洞.

1.3.模板字符串嵌套的深入探索

1.深度嵌套与性能优化

        当模板字符串嵌套到非常深的层次时,可能会带来性能上的开销。这是因为每次嵌套都会创建一个新的字符串,而字符串在JavaScript中是不可变的这意味着每次操作都会生成一个新的字符串对象。因此,在处理大量数据或深度嵌套的结构时,需要注意性能优化。

        

        一种优化方法是尽量减少不必要的嵌套,或者使用其他数据结构(如数组或对象)来组织数据,然后再通过循环或递归的方式生成最终的字符串。

2. 动态模板生成

在某些情况下,我们可能需要根据运行时条件动态地生成模板字符串。这可以通过使用函数来返回模板字符串,并在函数中根据条件拼接不同的字符串片段来实现。

例如,我们可以编写一个函数来根据用户权限生成不同的页面内容

function generatePageContent(userRole) {return `<div><h1>Welcome to Our Website</h1>${userRole === 'admin' ? `<div><h2>Admin Panel</h2><!-- Admin-specific content --></div>` : `<div><h2>User Panel</h2><!-- User-specific content --></div>`}</div>`;
}

generatePageContent函数根据userRole的值返回不同的模板字符串

3. 与其他JavaScript特性的结合

模板字符串可以与其他JavaScript特性(如模板字面量类型、箭头函数、解构赋值等)结合使用,以实现更复杂的逻辑和更简洁的代码。

例如,我们可以使用模板字面量类型和箭头函数来创建一个函数,该函数接收一个对象并返回格式化的字符串

const formatPerson = ({ name, age, occupation }) => `Name: ${name}Age: ${age}Occupation: ${occupation}
`;console.log(formatPerson({ name: 'John Doe', age: 30, occupation: 'Engineer' }));

1.4.标签模板的深入探索

1. 自定义标签函数的高级用法

标签模板函数不仅可以用于简单的字符串插值,还可以实现更复杂的逻辑,如条件渲染、循环、国际化(i18n)等。

例如,我们可以编写一个自定义标签函数来实现条件渲染:

function conditionalRender(strings, ...values) {return strings.reduce((result, str, idx) => {result += str;if (idx < values.length) {const value = values[idx];result += typeof value === 'function' && value() ? '' : `[${value}]`;}return result;}, '');
}const condition = true;
console.log(conditionalRender`This is a ${condition ? 'true' : () => 'false'} statement.`); // 输出 "This is a true statement."
// 注意:这里的例子有点简化,实际使用中可能需要更复杂的逻辑来处理函数和值的混合情况。

然而,上面的例子并不完全展示了标签模板函数的强大之处。在实际应用中,我们可能会传递更复杂的值(如对象、数组等)给标签模板函数,并在函数内部进行更复杂的处理。

2. 与第三方库的集成

标签模板函数可以与第三方库集成,以实现更强大的功能。例如,我们可以使用intl-messageformat库来实现国际化

import IntlMessageFormat from 'intl-messageformat';const msg = IntlMessageFormat('Hello, {name}!', 'en', { name: 'John' });
console.log(msg.format()); // 输出 "Hello, John!"

虽然这个例子没有直接使用标签模板语法,但intl-messageformat库的设计灵感部分来源于标签模板,它允许我们以一种类似模板字符串的方式来定义和格式化国际化消息。

3. 性能与安全性考虑

与模板字符串嵌套类似,标签模板函数在处理大量数据或复杂逻辑时也可能带来性能开销。因此,需要注意性能优化,如避免不必要的计算、使用缓存等。

此外,在处理用户输入时,标签模板函数也需要考虑安全性问题。例如,如果标签模板函数接收用户输入并直接插入到HTML中,那么就需要进行HTML转义以防止XSS攻击。

码字不易,各位大佬点点赞

相关文章:

ES6的高阶语法特性

一、模板字符串的高级用法 1.1.模板字符串的嵌套 模板字符串的嵌套允许在一个模板字符串内部再嵌入一个或多个模板字符串。这种嵌套结构在处理复杂数据结构或生成具有层级关系的文本时非常有用。 1. 嵌套示例 假设我们有一个包含多个对象的数组&#xff0c;每个对象都有名称、…...

GO:GO程序如何处理缓存加载和大数据缓存

如果我们会在程序启动时&#xff0c;需要加载所有数据&#xff0c;最简单的方式就是程序启动&#xff0c;通过轮训从数据库拉取所有数据&#xff0c;并写入到本地缓存中。 问题&#xff1a;数据量较大的时候&#xff0c;程序加载慢&#xff0c;启动时间长&#xff0c;遇到问题不…...

时序数据库TDengine 3.3.5.0 发布:高并发支持与增量备份功能引领新升级

近日&#xff0c;TDengine 3.3.5.0 版本正式发布&#xff0c;带来了多项重磅更新与优化&#xff0c;从功能拓展到性能提升&#xff0c;再到用户体验进行了全面改进。本次更新围绕用户核心需求展开&#xff0c;涵盖了开发工具、数据管理、安全性、可视化等多个层面&#xff0c;为…...

信息系统项目管理-采购管理-采购清单示例

序号类别产品/服务名称规格/功能描述数量备注1硬件服务器高性能处理器&#xff0c;大容量存储10HP、DELL2网络设备高速路由器和交换机10华为3工作站多核处理器&#xff0c;高分辨率显示器25国产设备4移动检查设备手持式移动检查仪&#xff0c;可连接云平台30国产设备5打印机和扫…...

python识别图片中指定颜色的图案并保存为图片

示例代码&#xff1a; def chuli(color):import cv2import numpy as np# 定义颜色名称到HSV阈值范围的映射color_thresholds {red: ([0, 100, 100], [10, 255, 255], [160, 100, 100], [180, 255, 255]),yellow: ([20, 100, 100], [30, 255, 255]),blue: ([90, 100, 100], [1…...

【git命令行】git pull冲突如何使用stash暂存,不提交当前工作的情况下临时保存修改

1、git add . 暂存区暂存 2、git stash save "message" 保存当前工作目录的临时状态&#xff0c;并将其存储为一个新的stash 3 、git pull 重新拉取 4、**git stash pop**吐出之前暂存的改动&#xff0c;git stash clear 清空所有暂存...

浏览器输入http形式网址后自动跳转https解决方法

一、问题描述 使用浏览器 网上冲浪 时会遇到一个情况&#xff1a; 在浏览器中输入“http域名”后会自动变成“https 域名”的形式&#xff0c;此时“https 域名”的网站可能已停止对外提供服务了&#xff0c;这时会出现如下不友好的网页提示&#xff1a; 二、处理方法&#x…...

BertTokenizerFast 和 BertTokenizer 的区别

BertTokenizerFast 和 BertTokenizer 都是用于对文本进行标记化的工具&#xff0c;主要用于处理和输入文本数据以供 BERT 模型使用。它们都属于 HuggingFace 的 transformers 库。 主要区别 底层实现&#xff1a; BertTokenizer: 这是一个使用纯 Python 实现的标记器&#xff…...

【update 更新数据语法合集】.NET开源ORM框架 SqlSugar 系列

系列文章目录 &#x1f380;&#x1f380;&#x1f380; .NET开源 ORM 框架 SqlSugar 系列 &#x1f380;&#x1f380;&#x1f380; 文章目录 系列文章目录前言 &#x1f343;一、实体对象更新1.1 单条与批量1.2 不更新某列1.3 只更新某列1.4 NULL列不更新1.5 无主键/指定列…...

测试人员面试需要掌握的内容

测试人员面试需要掌握的内容 1、在公司的测试流程是什么&#xff1f; 产品经理确认本次版本的需求&#xff0c;召开需求评审会&#xff0c;进行估时排期&#xff0c;需求和时间都确定之后&#xff0c;UI出设计图&#xff0c;开发人员进行开发&#xff0c;测试人员编写测试用例…...

git 新建分支并推到远程分支

在git或者码云上创建一个项目管理&#xff0c;已经存在主分支&#xff0c;现在需要创建一个其他分支&#xff1b; 具体操作&#xff1a; 1. 查看分支情况 git branch 2. 查看分支状态 git status 3. 一次性创建并切换到本地分支 git checkout -b dev 分步骤创建和切换&…...

【Uniapp-Vue3】showLoading加载和showModal模态框示例

一、showLoading加载 uni.showLoading({ title:"标题", // 其他配置 }); uni.hideLoading(); showLoading开启后不会自动关闭&#xff0c;只能手动配置uni.hideLoading() 来关闭加载框。 二、showModel模态框 uni.showModel({ title:"标题", // 其他配置 …...

PythonOpenCV图片识别

在windows下面&#xff0c;使用python opencv 进行识别&#xff0c;获取到坐标。 依赖安装&#xff1a; pip install opencv-python pip install numpy pip install pyautogui pip install pywin32代码&#xff1a; import cv2 import numpy as np import pyautogui import o…...

构建优雅、高效的 Nodejs 命令行工具 - Archons

目录 项目简介安装基本用法样例创建一个简单的命令行工具使用archons上下文创建进度条 最后 项目地址: https://github.com/noctisynth/archons Bug反馈或功能请求&#xff1a;https://github.com/noctisynth/archons/issues 项目简介 Archons意思是“执政官”&#xff0c;我使…...

你喜欢用什么编辑器?

电脑工作者和程序员所使用的文本编辑器通常需要具备高效率、易用性以及对代码友好等特点&#xff0c;包括语法高亮、自动完成、多文件同时编辑、查找替换、版本控制集成等功能。以下是几个广受开发者欢迎且实用性较强的文本编辑器&#xff1a; Visual Studio Code&#xff08;V…...

鸿蒙报错Init keystore failed: keystore password was incorrect

报错如下&#xff1a; > hvigor ERROR: Failed :entry:defaultSignHap... > hvigor ERROR: Tools execution failed. 01-13 16:35:55 ERROR - hap-sign-tool: error: Init keystore failed: keystore password was incorrect * Try the following: > The key stor…...

【Flink】Flink内存管理

Flink内存整体结构图&#xff1a; JobManager内存管理 JVM 进程总内存(Total Process Memory)Flink总内存(Total Flink Memory)&#xff1a;JVM进程总内存减去JVM Metaspace(元空间)和JVM Overhead(运行时开销)上图解释&#xff1a; JVM进程总内存为2G;JVM运行时开销(JVM Overh…...

JVM:ZGC详解(染色指针,内存管理,算法流程,分代ZGC)

1&#xff0c;ZGC&#xff08;JDK21之前&#xff09; ZGC 的核心是一个并发垃圾收集器&#xff0c;所有繁重的工作都在Java 线程继续执行的同时完成。这极大地降低了垃圾收集对应用程序响应时间的影响。 ZGC为了支持太字节&#xff08;TB&#xff09;级内存&#xff0c;设计了基…...

Docker常用命令大全

Docker容器相关命令&#xff1a; 创建并启动容器&#xff1a; docker run&#xff1a;创建一个新的容器并运行一个命令。例如&#xff1a;docker run -d -p 8080:80 nginx这将后台(-d)运行一个Nginx容器&#xff0c;并映射宿主机的8080端口到容器的80端口。 列出容器&#x…...

(12)springMVC文件的上传

SpringMVC文件上传 首先是快速搭建一个springMVC项目 新建项目mvn依赖导入添加webMoudle添加Tomcat运行环境.在配置tomcat时ApplicationContext置为"/"配置Artfact的lib配置WEB-INF配置文件&#xff08;记得添加乱码过滤&#xff09;配置springmvc-servlet文件&…...

后进先出(LIFO)详解

LIFO 是 Last In, First Out 的缩写&#xff0c;中文译为后进先出。这是一种数据结构的工作原则&#xff0c;类似于一摞盘子或一叠书本&#xff1a; 最后放进去的元素最先出来 -想象往筒状容器里放盘子&#xff1a; &#xff08;1&#xff09;你放进的最后一个盘子&#xff08…...

iOS 26 携众系统重磅更新,但“苹果智能”仍与国行无缘

美国西海岸的夏天&#xff0c;再次被苹果点燃。一年一度的全球开发者大会 WWDC25 如期而至&#xff0c;这不仅是开发者的盛宴&#xff0c;更是全球数亿苹果用户翘首以盼的科技春晚。今年&#xff0c;苹果依旧为我们带来了全家桶式的系统更新&#xff0c;包括 iOS 26、iPadOS 26…...

利用ngx_stream_return_module构建简易 TCP/UDP 响应网关

一、模块概述 ngx_stream_return_module 提供了一个极简的指令&#xff1a; return <value>;在收到客户端连接后&#xff0c;立即将 <value> 写回并关闭连接。<value> 支持内嵌文本和内置变量&#xff08;如 $time_iso8601、$remote_addr 等&#xff09;&a…...

边缘计算医疗风险自查APP开发方案

核心目标:在便携设备(智能手表/家用检测仪)部署轻量化疾病预测模型,实现低延迟、隐私安全的实时健康风险评估。 一、技术架构设计 #mermaid-svg-iuNaeeLK2YoFKfao {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg…...

Module Federation 和 Native Federation 的比较

前言 Module Federation 是 Webpack 5 引入的微前端架构方案&#xff0c;允许不同独立构建的应用在运行时动态共享模块。 Native Federation 是 Angular 官方基于 Module Federation 理念实现的专为 Angular 优化的微前端方案。 概念解析 Module Federation (模块联邦) Modul…...

Axios请求超时重发机制

Axios 超时重新请求实现方案 在 Axios 中实现超时重新请求可以通过以下几种方式&#xff1a; 1. 使用拦截器实现自动重试 import axios from axios;// 创建axios实例 const instance axios.create();// 设置超时时间 instance.defaults.timeout 5000;// 最大重试次数 cons…...

html-<abbr> 缩写或首字母缩略词

定义与作用 <abbr> 标签用于表示缩写或首字母缩略词&#xff0c;它可以帮助用户更好地理解缩写的含义&#xff0c;尤其是对于那些不熟悉该缩写的用户。 title 属性的内容提供了缩写的详细说明。当用户将鼠标悬停在缩写上时&#xff0c;会显示一个提示框。 示例&#x…...

LeetCode - 199. 二叉树的右视图

题目 199. 二叉树的右视图 - 力扣&#xff08;LeetCode&#xff09; 思路 右视图是指从树的右侧看&#xff0c;对于每一层&#xff0c;只能看到该层最右边的节点。实现思路是&#xff1a; 使用深度优先搜索(DFS)按照"根-右-左"的顺序遍历树记录每个节点的深度对于…...

jmeter聚合报告中参数详解

sample、average、min、max、90%line、95%line,99%line、Error错误率、吞吐量Thoughput、KB/sec每秒传输的数据量 sample&#xff08;样本数&#xff09; 表示测试中发送的请求数量&#xff0c;即测试执行了多少次请求。 单位&#xff0c;以个或者次数表示。 示例&#xff1a;…...

Linux部署私有文件管理系统MinIO

最近需要用到一个文件管理服务&#xff0c;但是又不想花钱&#xff0c;所以就想着自己搭建一个&#xff0c;刚好我们用的一个开源框架已经集成了MinIO&#xff0c;所以就选了这个 我这边对文件服务性能要求不是太高&#xff0c;单机版就可以 安装非常简单&#xff0c;几个命令就…...