」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 模板文字可以真正重複使用嗎?

模板文字可以真正重複使用嗎?

發佈於2024-11-07
瀏覽:799

Can Template Literals Be Truly Reused?

模板文字:復興重用

ES6 中的模板文字經常被吹捧為強大的文本操作工具,但一個棘手的問題仍然存在:它們真的可以重用嗎?

無法實現的期望

乍一看,模板文字似乎只在聲明時承諾動態替換。這就引出了一個問題:什麼是保持靜態的模板?

打破循環

與流行的看法相反,模板文字可以使用函數通過運行時替換來重新煥發活力構造函數作為中介:

const template = "Hello ${this.name}!";
const variables = {
  name: "world"
};
function fillTemplate(str, data) {
  return new Function("return `"   str   "`;").call(data);
}
console.log(fillTemplate(template, variables)); // Output: Hello world!

可重複使用模板剖析

此技術允許以下內容:

  • 運行時插值: 變數是動態填充的,就像在傳統模板引擎中一樣。
  • 碎片: 範本可以儲存在單獨的文件中或動態取得。
  • 動態創建:可以動態建立和評估範本。

解決警告

雖然此方法提供了復甦的功能,但有一些警告:

  • 有限的JavaScript: 由於後期插值,內嵌JavaScript 邏輯是不可能的。
  • 模板標籤: 模板標籤變得具有挑戰性

儘管有這些限制,但很明顯,只要有一點獨創性,模板文字就可以超越其傳統限制並變得真正可重複使用。

最新教學 更多>
  • 為什麼多年的經驗讓我選擇全端而不是平均棧
    為什麼多年的經驗讓我選擇全端而不是平均棧
    在全栈和平均栈开发方面工作了 6 年多,我可以告诉你,虽然这两种方法都是流行且有效的方法,但它们满足不同的需求,并且有自己的优点和缺点。这两个堆栈都可以帮助您创建 Web 应用程序,但它们的实现方式却截然不同。如果您在两者之间难以选择,我希望我对两者的经验能给您一些有用的见解。 在这篇文章中,我将带...
    程式設計 發佈於2024-11-07
  • 如何處理 Python Base64 解碼中不正確的填滿錯誤?
    如何處理 Python Base64 解碼中不正確的填滿錯誤?
    在Python Base64解碼中處理不正確的填充在Python中使用64.decodestring()解碼basebase64編碼的資料時,你可能會遇到“填充不正確”錯誤。要繞過這個問題,您可以考慮幾種方法。 1。添加填充根據接受的答案中的建議,您可以在解碼之前簡單地添加最大可能的填充字符。在 P...
    程式設計 發佈於2024-11-07
  • PHP 可以像 JavaScript 一樣將函數當作參數傳遞嗎?
    PHP 可以像 JavaScript 一樣將函數當作參數傳遞嗎?
    在 PHP 中將函數作為參數傳遞將函數作為資料元素進行操作是現代程式設計中常用的通用技術。一個這樣的例子是將函數作為參數傳遞,這是 5.3 之前的 PHP 版本中不容易使用的功能。現在,我們深入研究此功能,探索何時以及如何使用它。 問題: 函數可以在 PHP 中作為參數傳遞嗎,類似 JavaScri...
    程式設計 發佈於2024-11-07
  • 反思 GSoC 4
    反思 GSoC 4
    Achievements, Lessons, and Tips for Future Success An exciting summer has come to a close for stdlib with our first participation in Google Summer of...
    程式設計 發佈於2024-11-07
  • 在 Go 中如何將位元組數組轉換為有符號整數和浮點數?
    在 Go 中如何將位元組數組轉換為有符號整數和浮點數?
    Go 中將位元組數組轉換為有符號整數和浮點數在Go 中,二進位包提供了從[]byte轉換無符號整數的函數數組,例如binary.LittleEndian.Uint16()和binary.BigEndian.Uint32()。然而,有符號整數或浮點數沒有直接等價物。 缺少有符號整數轉換函數的原因缺少有...
    程式設計 發佈於2024-11-07
  • 如何修復 Java + MySQL UTF-8 編碼問題:為什麼我的特殊字元顯示為問號?
    如何修復 Java + MySQL UTF-8 編碼問題:為什麼我的特殊字元顯示為問號?
    Java MySQL UTF-8 編碼問題Java MySQL UTF-8 編碼問題您提到了使用Java 和MySQL 時經常遇到的問題,其中儲存了特殊字元作為問號(“?”)。當 MySQL 資料庫、表格和欄位設定為使用 UTF-8 字元編碼,但 JDBC 連線未正確配置時,就會發生此問題。 在您的...
    程式設計 發佈於2024-11-07
  • 令牌桶演算法:流量管理必備指南
    令牌桶演算法:流量管理必備指南
    令牌桶演算法是控製網路流量、確保公平頻寬使用和防止網路擁塞的流行機制。它的運作原理很簡單,即根據令牌可用性來調節資料傳輸,其中令牌代表發送一定量資料的權利。該演算法對於維護各種系統(包括網路、API 和雲端服務)中的流量至關重要,提供了一種在不造成資源過載的情況下管理流量的方法。 令牌桶演算法如...
    程式設計 發佈於2024-11-07
  • 如何為您的 Python 專案選擇最佳的 XML 函式庫?
    如何為您的 Python 專案選擇最佳的 XML 函式庫?
    Python 中的XML 創建:庫和方法綜合指南在Python 中建立XML 文件時,開發人員可以選擇各種庫選項處理。最受歡迎和最直接的選擇是 ElementTree API,它是 Python 標準庫自 2.5 版以來不可或缺的一部分。 ElementTree:高效率選項ElementTree 提...
    程式設計 發佈於2024-11-07
  • 如何使用多個欄位對 Java 中的物件清單進行排序?
    如何使用多個欄位對 Java 中的物件清單進行排序?
    Java 中具有多個字段的列表對象的自定義排序雖然基於一個字段對列表中的對象進行排序很簡單,但使用多個字段進行排序可能有點棘手。本文深入研究按多個欄位排序的問題,並探討 Java 中可用的各種解決方案。 問題考慮一個場景,其中您有一個包含三個欄位的「Report」物件清單:ReportKey、學號和...
    程式設計 發佈於2024-11-07
  • 如何使用遞歸從具有父類別的資料庫產生巢狀選單樹?
    如何使用遞歸從具有父類別的資料庫產生巢狀選單樹?
    選單樹產生的遞歸在您的情況下,您有一個資料庫結構,其中類別有一個「根」欄位指示其父類別。您想要的 HTML 輸出涉及表示類別層次結構的巢狀清單。為此,可以使用遞歸 PHP 函數。 這是一個範例函數:function recurse($categories, $parent = null, $leve...
    程式設計 發佈於2024-11-07
  • Array_column 函數可以用於物件陣列嗎?
    Array_column 函數可以用於物件陣列嗎?
    將 array_column 與物件陣列一起使用將 array_column 與物件陣列一起使用本題探討了將 array_column 函數與由物件組成的陣列一起使用的可行性。開發人員實作了 ArrayAccess 接口,但發現它沒有任何影響。 PHP 5$titles = array_map(fu...
    程式設計 發佈於2024-11-07
  • HashMap 實際應用:應對常見的 Java 面試挑戰
    HashMap 實際應用:應對常見的 Java 面試挑戰
    技术面试通常会提出一些问题来测试您对集合的理解,尤其是HashMaps。一个常见的挑战涉及计算列表中元素的出现次数。这个问题可以帮助面试官评估您有效处理数据聚合并避免NullPointerException等陷阱的能力。 如果您是 HashMap 新手,在深入研究本文之前,您可能需要查看我的破解...
    程式設計 發佈於2024-11-07
  • SQL中什麼情況下交易不會自動回滾?
    SQL中什麼情況下交易不會自動回滾?
    自動事務回滾問題圍繞著 START TRANSACTION 包含的 SQL 語句區塊中發生錯誤時交易的行為提交交易。 OP注意到,當COMMIT TRANSACTION語句之前遇到語法錯誤時,交易會自動回滾。 事務回溯機制不,交易不會回溯遇到錯誤立即回傳。然而,某些客戶端應用程式可能會採用特定的錯誤...
    程式設計 發佈於2024-11-07
  • 如何使用陣列函數將字串轉換為關聯數組?
    如何使用陣列函數將字串轉換為關聯數組?
    使用陣列函數將字串轉換為關聯數組在PHP 中,經常需要將包含鍵值對的字串轉換為關聯數組關聯數組。考慮像“1-350,9-390.99”這樣的字串,其中每個元素由連字符和逗號分隔。目標是建立一個關聯數組,其中每個元素中的第一個數字成為鍵,第二個數字成為值。 可以使用 PHP 的內建數組函數有效地實現此...
    程式設計 發佈於2024-11-07
  • 了解無衝突複製資料類型
    了解無衝突複製資料類型
    無衝突複製資料類型 (CRDT) 是一類資料結構,可在分散式系統中實現無縫協作和資料同步,從而實現無衝突的協作更新。 CRDT 旨在實現跨多個資料副本的最終一致性,確保即使更新獨立發生,所有副本也能收斂到相同狀態,而不需要複雜的衝突解決機制。 在這篇文章中,我們將深入研究 CRDT 是什麼,探索它...
    程式設計 發佈於2024-11-07

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3