搜尋
首頁web前端js教程Nobuild 與 Rails 和 Importmap

最新版本的 Ruby on Rails 專注於框架不同方面的簡單性,並承諾回歸「單人框架」(單一開發人員可以有效地建立和維護整個應用程式)。

Importmap Rails 庫基於現代 Web 瀏覽器已經趕上 ECMAScript 規範並且可以解釋 ES 模組(ESM)的原理。作為 Web 標準,Importmap 可讓您控制 JavaScript 模組在瀏覽器中的解析方式並管理依賴項和版本,而無需轉譯或捆綁發送到瀏覽器的程式碼。

Importmap Web 標準的工作原理

這一切都始於應用程式主版面或網頁中定義的 importmap 類型的腳本標籤。在此標籤內,一個 JSON 物件定義了別名及其對應的原始碼路徑。

<script type="importmap">
  {
    "imports": {
      "application": "/assets/application.js",
      "local-time": "https://cdn.jsdelivr.net/npm/local-time@3.0.2/app/assets/javascripts/local-time.es2017-esm.min.js",
      "utils": "/assets/utils.js"
    }
  }
</script>

在同一個地圖中,您可以混合指向 CDN 或使用本地資源的庫路徑。要使用此地圖中的庫,請引用別名。

<!-- Below the importmap script -->
<script type="module">import "application"</script>

並在您的application.js中,匯入所需的依賴項:

// application.js

import LocalTime from "local-time";
LocalTime.start();

import "utils";

瀏覽器 Chrome 89 、 Safari 16.4 、 Firefox 108 和 Edge 89 皆支援導入地圖。對於較舊的瀏覽器,請包含一個polyfill:

<script async src="https://ga.jspm.io/npm:es-module-shims@1.10.1/dist/es-module-shims.js"></script>

Importmap 在 Ruby on Rails 中的工作原理

Ruby on Rails 中的匯入映射功能遵循上述相同標準,並提供了一種建立映射和版本檔案的簡單方法。使用名為 heroImage 的 Web 應用程式作為範例(原始程式碼可在 Github 上取得),讓我們探索一下實作。

Nobuild with Rails and Importmap

當您建立新的 Rails 8 應用程式時,預設會新增並安裝 importmap-rails gem。將建立一個檔案config/importmap.rb,您可以在其中固定應用程式中所需的JavaScript程式碼。

pin "application"

pin "@hotwired/turbo-rails", to: "turbo.min.js"
pin "@hotwired/stimulus", to: "stimulus.min.js"
pin "@hotwired/stimulus-loading", to: "stimulus-loading.js"

pin_all_from "app/javascript/controllers", under: "controllers", preload: false

pin 關鍵字最多需要三個參數。第一個是必需的,因為它是 JavaScript 程式碼的別名。 pin「application」是檔案 application.js 的捷徑,別名為 application:

pin "application", to: "application.js"

當別名和檔案名稱不同時,使用關鍵字::

pin "@hotwired/turbo-rails", to: "turbo.min.js"

pin_all_from 關鍵字有助於一次引用多個檔案。第一個參數是 JavaScript 檔案所在的路徑,under: 參數是每個檔案的別名的前綴。產生的別名使用下的前綴和檔名,例如alert_controller.js檔案的controllers/alert-controller。

要視覺化 Importmap JSON 文件,請執行:

<script type="importmap">
  {
    "imports": {
      "application": "/assets/application.js",
      "local-time": "https://cdn.jsdelivr.net/npm/local-time@3.0.2/app/assets/javascripts/local-time.es2017-esm.min.js",
      "utils": "/assets/utils.js"
    }
  }
</script>

Rails 透過Propshaft gem 解析所有JavaScript,它解析JavaScript 程式碼的實體路徑,對應到/assets Web 路徑,並將摘要新增到每個檔案中,以實現更好的快取和失效。

Propshaft 從資產配置發現實體路徑:

<!-- Below the importmap script -->
<script type="module">import "application"</script>

確保您的檔案存在於任何已註冊的路徑中,或新增您自己的路徑以供 Propshaft 和 Importmap 發現。

Rails 中的 Importmap 可讓您指定瀏覽器應如何載入 JavaScript 檔案。有兩個選項:預先載入(預設)和無預載。預先載入告訴瀏覽器盡快下載檔案。 Importmap 產生一個帶有 rel="modulepreload":
的連結標籤

// application.js

import LocalTime from "local-time";
LocalTime.start();

import "utils";

如果將 preload 參數設為 false,則不會產生連結標籤,瀏覽器會在需要時下載檔案。

使用 Rails 的 Importmap,您也可以使用 URL 的 to: 參數固定 CDN 中的 JavaScript 程式碼:

<script async src="https://ga.jspm.io/npm:es-module-shims@1.10.1/dist/es-module-shims.js"></script>

Importmap 包含一個 CLI,用於將固定取消固定 JavaScript 程式碼到config/importmap.rb 檔案中。它還包括更新、審核和檢查版本的命令:

pin "application"

pin "@hotwired/turbo-rails", to: "turbo.min.js"
pin "@hotwired/stimulus", to: "stimulus.min.js"
pin "@hotwired/stimulus-loading", to: "stimulus-loading.js"

pin_all_from "app/javascript/controllers", under: "controllers", preload: false

當對JavaScript 套件使用pin 指令時,Importmap 不會將to: 參數設為CDN,而是解析套件依賴項並將套件和相依性下載到vendor/javascript ,允許Rails 應用程式提供這些檔案:

pin "application", to: "application.js"

當您的套件在 JavaScript 套件中具有簡單的依賴項或定義良好的依賴項時,此方法效果很好。如果情況並非如此,使用 Importmap 在 vendor/javascript 供應程式碼會變得具有挑戰性。它可能與 URL 和手動依賴項添加一起使用,或者您可以調整供應商的程式碼以使其工作。

如何使用 Rails Gems - 引擎 - 和 Importmap?

有兩種方法可以建立與 Importmap 相容的 Ruby on Rails gem。第一種方法可讓您的 gem 提供 JavaScript 程式碼,您可以選擇將其固定在 Importmap 配置中。這就是 turbo-railsstimulus-rails gem 的實作方式。

將 JavaScript 程式碼放入 gem 的 app/assets/javascripts 資料夾中。您可能需要一個額外的過程來縮小 JavaScript 檔案並產生 JavaScript 映射檔案。然後,在 Engine 類別中,定義一個初始化器鉤子以使用 Propshaft 宣告 JavaScript 程式碼:

<script type="importmap">
  {
    "imports": {
      "application": "/assets/application.js",
      "local-time": "https://cdn.jsdelivr.net/npm/local-time@3.0.2/app/assets/javascripts/local-time.es2017-esm.min.js",
      "utils": "/assets/utils.js"
    }
  }
</script>

第二個選項使用 Importmap 設定檔。如果您的引擎有其佈局模板,並且視圖與主機應用程式隔離,且引擎不需要與主機應用程式共用JavaScript 程式碼,您可以在config/importmap.rb 建立一個Importmap 設定檔,設置腳,將JavaScript 程式碼放置在app/javascript,並使用初始值設定項配置引擎。

開啟您的engine.rb Ruby 檔案並新增Importmap 設定檔和掃描器:

<!-- Below the importmap script -->
<script type="module">import "application"</script>

指定要在引擎佈局範本中使用的匯入對映:

// application.js

import LocalTime from "local-time";
LocalTime.start();

import "utils";

要與主機應用程式共用 JavaScript 程式碼(例如 Stimulus 控制器),請建立部分 Importmap 設定檔並將引擎設定為將其與主機應用程式中的主檔案合併。

config/importmap.rb 建立一個 Importmap 設定文件,並新增 JavaScript 引腳以與主機應用程式共用。如果您有外部套件的依賴項,請透過產生器或安裝程式將它們新增至主機應用程式:

<script async src="https://ga.jspm.io/npm:es-module-shims@1.10.1/dist/es-module-shims.js"></script>

開啟你的engine.rb 檔案並加入一個初始化器:

pin "application"

pin "@hotwired/turbo-rails", to: "turbo.min.js"
pin "@hotwired/stimulus", to: "stimulus.min.js"
pin "@hotwired/stimulus-loading", to: "stimulus-loading.js"

pin_all_from "app/javascript/controllers", under: "controllers", preload: false

使用 Importmap 有什麼優點?

從 Ruby on Rails 開發人員的角度來看,使用 Importmap 的主要優點是不需要類似 JavaScript 運行時的節點,並且不受 node_modules 依賴關係。

此外,您不需要在開發模式下進行額外的過程來轉譯和縮小 JavaScript 程式碼。您依靠 Web 標準將程式碼提供給瀏覽器。在反向代理後面部署 Rails 應用程式有幾個好處。首先,如果您啟用 HTTP/2 協議,您的瀏覽器可以透過單一 HTTP 連接取得多個文件,並且下載許多小型 JavaScript 文件不會影響效能。

Nobuild with Rails and Importmap

啟用代理程式使用 gzip 或 brotli 壓縮可確保您傳送非常小的文件,同時在使用瀏覽器開發人員工具時保持可讀性。如果更改一個文件,只需使瀏覽器下載的該特定文件失效即可。由於 Propshaft 新增到所有檔案的指紋,瀏覽器知道檔案已被修改。

使用像 Thruster 這樣的反向代理以及 Puma 可以卸載 Rails 應用程式提供的資源。 Thruster 可以快取資源並在用戶端請求檔案時提供它們。

何時不使用導入映射

在某些情況下,您應該避免在 Rails 應用程式中使用 Importmap。如果您正在使用 React、Vue 或任何其他類似工具來建立 SPA 應用程序,那麼您很可能正在使用 TypeScript 編寫程式碼。在這種情況下,您應該堅持捆綁策略。

此外,如果您需要支援較舊的瀏覽器,與代碼轉譯捆綁在一起是更好的選擇。

以上是Nobuild 與 Rails 和 Importmap的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
JavaScript的核心:它是在C還是C上構建的?JavaScript的核心:它是在C還是C上構建的?May 05, 2025 am 12:07 AM

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript應用程序:從前端到後端JavaScript應用程序:從前端到後端May 04, 2025 am 12:12 AM

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

Python vs. JavaScript:您應該學到哪種語言?Python vs. JavaScript:您應該學到哪種語言?May 03, 2025 am 12:10 AM

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架:為現代網絡開發提供動力JavaScript框架:為現代網絡開發提供動力May 02, 2025 am 12:04 AM

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

JavaScript,C和瀏覽器之間的關係JavaScript,C和瀏覽器之間的關係May 01, 2025 am 12:06 AM

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr

node.js流帶打字稿node.js流帶打字稿Apr 30, 2025 am 08:22 AM

Node.js擅長於高效I/O,這在很大程度上要歸功於流。 流媒體匯總處理數據,避免內存過載 - 大型文件,網絡任務和實時應用程序的理想。將流與打字稿的類型安全結合起來創建POWE

Python vs. JavaScript:性能和效率注意事項Python vs. JavaScript:性能和效率注意事項Apr 30, 2025 am 12:08 AM

Python和JavaScript在性能和效率方面的差異主要體現在:1)Python作為解釋型語言,運行速度較慢,但開發效率高,適合快速原型開發;2)JavaScript在瀏覽器中受限於單線程,但在Node.js中可利用多線程和異步I/O提升性能,兩者在實際項目中各有優勢。

JavaScript的起源:探索其實施語言JavaScript的起源:探索其實施語言Apr 29, 2025 am 12:51 AM

JavaScript起源於1995年,由布蘭登·艾克創造,實現語言為C語言。 1.C語言為JavaScript提供了高性能和系統級編程能力。 2.JavaScript的內存管理和性能優化依賴於C語言。 3.C語言的跨平台特性幫助JavaScript在不同操作系統上高效運行。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

mPDF

mPDF

mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

VSCode Windows 64位元 下載

VSCode Windows 64位元 下載

微軟推出的免費、功能強大的一款IDE編輯器