”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > ES6 模板文字真的可以重用吗?

ES6 模板文字真的可以重用吗?

发布于2024-11-08
浏览:373

Can ES6 Template Literals be Truly Reusable?

ES6 模板文字中的可重用性难题

本次讨论中提出的主要问题围绕着 ES6 模板文字中假定缺乏可重用性的问题。传统的演示强调声明时的替换,不允许运行时修改。

解决方案:利用函数构造函数

为了解决这个问题,一个可行的解决方案以以下形式出现:函数构造函数。这种方法涉及将模板字符串转换为函数。

考虑以下代码片段:

const templateString = `Hello ${this.name}!`;
const templateVars = {
    name: "world"    
};

const fillTemplate = function(templateString, templateVars){
    return new Function("return `"   templateString   "`;").call(templateVars);
};

console.log(fillTemplate(templateString, templateVars));

通过调用该函数,您可以生成所需的字符串,同时拥有运行时修改变量的灵活性。

的好处这种方法:

  • 启用模板值的运行时替换
  • 有利于来自外部源的插值,例如文件
  • 允许动态字符串操作

潜在缺点:

  • 模板标签可能需要额外的实现工作
  • 由于延迟,不支持模板内的内联 JavaScript 逻辑插值
  • 与每个模板使用的函数创建相关的内存开销

总之,虽然 ES6 模板文字本质上缺乏真正的可重用性,但使用 Function 构造函数提供了一种模拟所需行为的解决方法在运行时创建和修改模板。

最新教程 更多>
  • PHP 4 快速部署
    PHP 4 快速部署
    Servbay 已成为高效配置开发环境的领先工具。在本指南中,我们将引导您完成快速、安全地部署 PHP 8.1 的过程,展示 Servbay 对简化部署的承诺。 先决条件 确保您的计算机上安装了 Servbay。您可以从 Servbay 官方网站轻松下载。安装过程人性化;只需按照安装...
    编程 发布于2024-11-08
  • 如何绕过验证码
    如何绕过验证码
    No matter how many times people wrote that the captcha has outlived itself long time ago and no longer works as effectively as its developers would ha...
    编程 发布于2024-11-08
  • 使用 super 调用超类构造函数
    使用 super 调用超类构造函数
    子类可以使用 super(parameter-list);. 形式调用其超类定义的构造函数 parameter-list 必须指定超类构造函数所需的参数。 子类构造函数中执行的第一条语句必须始终是 super(); (或者 super(parameter-list); 如果需要传递参数). 以下是...
    编程 发布于2024-11-08
  • 你能比较 C++ 中不同容器的迭代器吗?
    你能比较 C++ 中不同容器的迭代器吗?
    比较来自不同容器的迭代器:一个警示故事在 C 中,迭代器提供了一种强大的遍历集合的机制。然而,在使用来自不同容器的迭代器时,重要的是要意识到这些限制。比较来自不同容器的迭代器是否合法的问题经常出现。考虑以下示例:std::vector<int> foo; std::vector<i...
    编程 发布于2024-11-08
  • 帮助 FastAPI:如何为文档翻译做出贡献
    帮助 FastAPI:如何为文档翻译做出贡献
    One of the great features of FastAPI is its great documentation ?. But wouldn't it be better if more people around the world had access to this docume...
    编程 发布于2024-11-08
  • 如何使用 CSS 和 AngularJS 创建垂直 HTML 表格?
    如何使用 CSS 和 AngularJS 创建垂直 HTML 表格?
    垂直 HTML 表格创建具有垂直行的 HTML 表格提供了一种独特的方式来显示数据,行标题位于左侧而不是顶部。要实现此目的,可以应用 CSS 样式来转换表格的结构。CSS 样式要将表格行呈现为垂直列,请遵循以下 CSS 规则可以使用:tr { display: block; float: l...
    编程 发布于2024-11-08
  • 通过自定义 Hooks 在 React 中重用逻辑:实用指南
    通过自定义 Hooks 在 React 中重用逻辑:实用指南
    自定义钩子是 React 中的一项强大功能,与 React 内置钩子不同,它用于更具体的目的,并且它是通过将常见功能封装到独立函数中来完成的。自定义挂钩促进可重用性、改进组件组织并整体增强代码可维护性。 在本指南中,我们将深入探讨使用自定义钩子的目的,了解创建自定义钩子的基础知识以及如何使用其他组件...
    编程 发布于2024-11-08
  • 使用 ReactJS 构建免费的 AI 图像生成器
    使用 ReactJS 构建免费的 AI 图像生成器
    开发者们大家好, 今天,我将向您展示如何使用 ReactJS 创建图像生成器,并且完全可以免费使用,这要感谢黑森林实验室和 Together AI。 第 1 步:设置项目 在本教程中,我们将使用 Vite 来初始化应用程序并使用 Shadcn 来初始化 UI。我假设您已经设置了项目并...
    编程 发布于2024-11-08
  • 字符串中的串联或大括号:哪种方法可以优化性能和美观?
    字符串中的串联或大括号:哪种方法可以优化性能和美观?
    字符串中的变量连接与大括号:评估性能和美观在字符串操作领域,开发人员经常面临两难境地:他们应该连接字符串中的变量还是选择花括号?每种方法都有自己的优点和缺点,我们将深入研究这些优点和缺点,以提供明智的决策。串联:传统方法串联涉及使用以下方法将变量附加到字符串这 '。'操作员。虽然这种...
    编程 发布于2024-11-08
  • 我尝试过花岗岩。
    我尝试过花岗岩。
    花岗岩3.0 Granite 3.0 是一个开源、轻量级的生成语言模型系列,专为一系列企业级任务而设计。它原生支持多语言功能、编码、推理和工具使用,使其适合企业环境。 我测试了运行这个模型,看看它可以处理哪些任务。 环境设置 我在Google Colab中设置了Gr...
    编程 发布于2024-11-08
  • 掌握 JavaScript 函数:开发人员综合指南
    掌握 JavaScript 函数:开发人员综合指南
    JavaScript Functions A JavaScript function is a block of code designed to perform a particular task. A JavaScript function is executed when "...
    编程 发布于2024-11-08
  • Next.js 缓存:通过高效的数据获取来增强您的应用程序
    Next.js 缓存:通过高效的数据获取来增强您的应用程序
    Next.js 中的缓存不仅仅是为了节省时间,还在于减少冗余网络请求、保持数据新鲜并使您的应用程序像摇滚明星一样运行。 无论您是想将数据缓存更长时间还是按需刷新,Next.js 都能为您提供所需的所有工具。在本文中,我们将详细介绍如何在 Next.js 中有效地使用缓存 Next.js 扩展了 f...
    编程 发布于2024-11-08
  • 为什么我的 Go 模板条件检查失败?
    为什么我的 Go 模板条件检查失败?
    Go 模板:条件检查故障排除在 Go 模板渲染中,结构体字段的条件检查有时无法按预期工作。考虑以下示例,其中 bool 字段 isOrientRight 未正确计算:type Category struct { ImageURL string
    编程 发布于2024-11-08
  • 如何解决 MySQL 时区错误:Java 中的“服务器时区值中欧时间”?
    如何解决 MySQL 时区错误:Java 中的“服务器时区值中欧时间”?
    MySQL 连接器在 Java 数据库连接期间出现“服务器时区值中欧时间”错误使用建立数据库连接时会出现此问题Java 中的 MySQL 连接器。该错误消息表明提供的服务器时区值“中欧时间”无法识别或代表多个时区。要解决此问题,必须使用 serverTimezone 配置属性显式指定服务器时区值。一...
    编程 发布于2024-11-08
  • 为什么应该避免在 JSX Props 中使用箭头函数或绑定?
    为什么应该避免在 JSX Props 中使用箭头函数或绑定?
    为什么在 JSX Props 中使用箭头函数或 Bind 是禁忌使用 React 时,避免使用箭头函数或 Bind 非常重要在 JSX 属性中绑定。这种做法可能会导致性能问题和不正确的行为。性能问题在 JSX props 中使用箭头函数或绑定会强制在每次渲染时重新创建这些函数。这意味着:旧函数被丢弃...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3