在浏览器中打开开发者控制台。如果您看到“Hello world”,则说明它正在正确加载。

浏览器现在支持 ECMAScript 模块。您可以导入其他文件以了解其副作用:

import \\\"./some-other-script.js\\\";

或用于出口

import { add, multiply } \\\"./my-math-lib.js\\\";

很酷吧?请参阅上面的 MDN 指南以获取更多信息。

套餐

您可能不想重新发明轮子,因此您的项目可能会使用一些第三方包。这并不意味着您现在需要开始使用包管理器。

假设我们想使用超结构进行数据验证。我们不仅可以从我们自己的(本地)文件服务器加载模块,还可以从任何 URL 加载模块。 esm.sh 方便地为 npm 上可用的几乎所有软件包提供模块。

当您访问 https://esm.sh/superstruct 时,您可以看到您被重定向到最新版本。您可以在代码中包含此包,如下所示:

import { assert } from \\\"https://esm.sh/superstruct\\\";

如果您想安全起见,您可以固定版本。

类型

我不了解你,但 TypeScript 宠坏了我(并且让我变得懒惰)。在没有类型检查器帮助的情况下编写纯 JavaScript 感觉就像走钢丝一样。幸运的是,我们也不必放弃类型检查。

是时候淘汰 npm 了(尽管我们不会发布它提供的任何代码)。

npm init --yesnpm install typescript

您可以在 JavaScript 代码上使用 TypeScript 编译器!对此有一流的支持。创建jsconfig.json:

{  \\\"compilerOptions\\\": {    \\\"strict\\\": true,    \\\"checkJs\\\": true,    \\\"allowJs\\\": true,    \\\"noImplicitAny\\\": true,    \\\"lib\\\": [\\\"ES2022\\\", \\\"DOM\\\"],    \\\"module\\\": \\\"ES2022\\\",    \\\"target\\\": \\\"ES2022\\\"  },  \\\"include\\\": [\\\"**/*.js\\\"],  \\\"exclude\\\": [\\\"node_modules\\\"]}

现在运行

npm run tsc --watch -p jsconfig.json

并在代码中出现类型错误。 TypeScript 编译器应该抱怨:

/** @type {number} **/const num = \\\"hello\\\";

顺便说一下,你上面看到的评论是JSDoc。您可以通过这种方式用类型注释您的 JavaScript。虽然它比使用 TypeScript 更冗长一些,但你很快就会习惯它。它也非常强大,只要您不编写疯狂的类型(对于大多数项目来说您不应该这样做),您应该没问题。

如果您确实需要复杂的类型(帮助程序),您可以随时在 .d.ts 文件中添加一些 TypeScript。

JSDoc 只是那些陷入大型 JavaScript 项目的人能够逐渐迁移到 TypeScript 的垫脚石吗?我不这么认为! TypeScript 团队还继续向 JSDoc TypeScript 添加出色的功能,例如即将发布的 TypeScript 版本。自动完成在 VS Code 中也很有效。

导入地图

我们学习了如何在不使用构建工具的情况下将外部包添加到我们的项目中。但是,如果您将代码拆分为多个模块,则一遍又一遍地写出完整的 URL 可能会有点冗长。

我们可以将导入映射添加到我们的index.html的head部分:

现在我们可以简单地使用
导入这个包

import {} from \\\"superstruct\\\"

就像一个“正常”项目。另一个好处是,如果您在本地安装包,类型的完成和识别将按预期工作。

npm install --save-dev superstruct

请注意,您的node_modules目录中的版本将被使用。您可以删除它,您的项目将继续运行。

我喜欢使用的一个技巧是添加:

      \\\"cdn/\\\": \\\"https://esm.sh/\\\",

到我的导入地图。然后,通过 esm.sh 提供的任何项目都可以通过简单地导入来使用。例如。:

import Peer from \\\"cdn/peerjs\\\";

如果您也想从node_modules中提取类型以进行此类导入的开发,则需要将以下内容添加到jsconfig.json的compilerOptions中:

    \\\"paths\\\": {      \\\"cdn/*\\\": [\\\"./node_modules/*\\\", \\\"./node_modules/@types/*\\\"]    },

部署

要部署您的项目,请将所有文件复制到静态文件主机,然后就完成了!如果您曾经参与过旧版 JavaScript 项目,您就会知道更新不到 1-2 年的构建工具的痛苦。通过此项目设置,您将不会遭受同样的命运。

测试

如果您的 JavaScript 不依赖于浏览器 API,您可以只使用与 Node.js 捆绑在一起的测试运行器。但为什么不编写自己的可以在浏览器中运行的测试运行程序呢?

/** @type {[string, () => Promise | void][]} */const tests = [];/** * * @param {string} description * @param {() => Promise | void} testFunc */export async function test(description, testFunc) {  tests.push([description, testFunc]);}export async function runAllTests() {  const main = document.querySelector(\\\"main\\\");  if (!(main instanceof HTMLElement)) throw new Error();  main.innerHTML = \\\"\\\";  for (const [description, testFunc] of tests) {    const newSpan = document.createElement(\\\"p\\\");    try {      await testFunc();      newSpan.textContent = `✅ ${description}`;    } catch (err) {      const errorMessage =        err instanceof Error && err.message ? ` - ${err.message}` : \\\"\\\";      newSpan.textContent = `❌ ${description}${errorMessage}`;    }    main.appendChild(newSpan);  }}/** * @param {any} val */export function assert(val, message = \\\"\\\") {  if (!val) throw new Error(message);}

现在创建一个文件 example.test.js.

import { test, assert } from \\\"@/test.js\\\";test(\\\"1 1\\\", () => {  assert(1   1 === 2);});

还有一个导入所有测试的文件:

import \\\"./example.test.js\\\";console.log(\\\"This should only show up when running tests\\\");

在页面加载时运行此命令:

await import(\\\"@/test/index.js\\\"); // file that imports all tests(await import(\\\"@/test.js\\\")).runAllTests();

您获得了完美的 TDD 设置。要仅运行一部分测试,您可以注释掉一些 .test.js 导入,但只有当您积累了大量测试时,测试执行速度才会开始成为问题。

好处

你为什么要这样做?那么,使用较少的抽象层可以使您的项目更易于调试。还有“利用平台”的信条。您学到的技能将更好地转移到其他项目中。另一个优点是,当您在 10 年内返回这样构建的项目时,它仍然可以正常工作,并且您不需要进行考古来尝试恢复已经失效 8 年的构建工具。许多从事遗留项目的 Web 开发人员都会熟悉这种经历。

请访问 plainvanillaweb.com 了解更多想法。

","image":"http://www.luping.net/uploads/20240807/172301184466b313046f19c.jpg","datePublished":"2024-08-07T14:24:03+08:00","dateModified":"2024-08-07T14:24:03+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}
」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 無需(建置)工具的 Web 開發

無需(建置)工具的 Web 開發

發佈於2024-08-07
瀏覽:270

Web Development Without (Build) Tooling

当开始一个将使用 JavaScript 的新 Web 项目时,我们做的第一件事通常是设置构建和开发人员工具。比如最近很火的Vite。您可能不知道并非所有 JavaScript(Web)项目都需要复杂的构建工具。事实上,正如我将在本文中展示的那样,现在比以往任何时候都更容易摆脱困境。

使用index.html文件创建一个新项目。


  
  
  
    

Hello world

如果您使用的是 VS Code,请安装实时预览扩展。运行。这是一个具有实时重新加载功能的简单文件服务器。你可以使用任何文件服务器,Python 内置了一个:

python3 -m http.server

我喜欢实时预览,因为它在更改文件后会自动刷新页面。

您现在应该能够从浏览器访问您的index.html 文件并看到“Hello world”。

接下来,创建一个index.js文件:

console.log("Hello world");

export {};

将其包含在您的index.html中:

在浏览器中打开开发者控制台。如果您看到“Hello world”,则说明它正在正确加载。

浏览器现在支持 ECMAScript 模块。您可以导入其他文件以了解其副作用:

import "./some-other-script.js";

或用于出口

import { add, multiply } "./my-math-lib.js";

很酷吧?请参阅上面的 MDN 指南以获取更多信息。

套餐

您可能不想重新发明轮子,因此您的项目可能会使用一些第三方包。这并不意味着您现在需要开始使用包管理器。

假设我们想使用超结构进行数据验证。我们不仅可以从我们自己的(本地)文件服务器加载模块,还可以从任何 URL 加载模块。 esm.sh 方便地为 npm 上可用的几乎所有软件包提供模块。

当您访问 https://esm.sh/superstruct 时,您可以看到您被重定向到最新版本。您可以在代码中包含此包,如下所示:

import { assert } from "https://esm.sh/superstruct";

如果您想安全起见,您可以固定版本。

类型

我不了解你,但 TypeScript 宠坏了我(并且让我变得懒惰)。在没有类型检查器帮助的情况下编写纯 JavaScript 感觉就像走钢丝一样。幸运的是,我们也不必放弃类型检查。

是时候淘汰 npm 了(尽管我们不会发布它提供的任何代码)。

npm init --yes
npm install typescript

您可以在 JavaScript 代码上使用 TypeScript 编译器!对此有一流的支持。创建jsconfig.json:

{
  "compilerOptions": {
    "strict": true,
    "checkJs": true,
    "allowJs": true,
    "noImplicitAny": true,
    "lib": ["ES2022", "DOM"],
    "module": "ES2022",
    "target": "ES2022"
  },
  "include": ["**/*.js"],
  "exclude": ["node_modules"]
}

现在运行

npm run tsc --watch -p jsconfig.json

并在代码中出现类型错误。 TypeScript 编译器应该抱怨:

/** @type {number} **/
const num = "hello";

顺便说一下,你上面看到的评论是JSDoc。您可以通过这种方式用类型注释您的 JavaScript。虽然它比使用 TypeScript 更冗长一些,但你很快就会习惯它。它也非常强大,只要您不编写疯狂的类型(对于大多数项目来说您不应该这样做),您应该没问题。

如果您确实需要复杂的类型(帮助程序),您可以随时在 .d.ts 文件中添加一些 TypeScript。

JSDoc 只是那些陷入大型 JavaScript 项目的人能够逐渐迁移到 TypeScript 的垫脚石吗?我不这么认为! TypeScript 团队还继续向 JSDoc TypeScript 添加出色的功能,例如即将发布的 TypeScript 版本。自动完成在 VS Code 中也很有效。

导入地图

我们学习了如何在不使用构建工具的情况下将外部包添加到我们的项目中。但是,如果您将代码拆分为多个模块,则一遍又一遍地写出完整的 URL 可能会有点冗长。

我们可以将导入映射添加到我们的index.html的head部分:

现在我们可以简单地使用
导入这个包

import {} from "superstruct"

就像一个“正常”项目。另一个好处是,如果您在本地安装包,类型的完成和识别将按预期工作。

npm install --save-dev superstruct

请注意,您的node_modules目录中的版本将被使用。您可以删除它,您的项目将继续运行。

我喜欢使用的一个技巧是添加:

      "cdn/": "https://esm.sh/",

到我的导入地图。然后,通过 esm.sh 提供的任何项目都可以通过简单地导入来使用。例如。:

import Peer from "cdn/peerjs";

如果您也想从node_modules中提取类型以进行此类导入的开发,则需要将以下内容添加到jsconfig.json的compilerOptions中:

    "paths": {
      "cdn/*": ["./node_modules/*", "./node_modules/@types/*"]
    },

部署

要部署您的项目,请将所有文件复制到静态文件主机,然后就完成了!如果您曾经参与过旧版 JavaScript 项目,您就会知道更新不到 1-2 年的构建工具的痛苦。通过此项目设置,您将不会遭受同样的命运。

测试

如果您的 JavaScript 不依赖于浏览器 API,您可以只使用与 Node.js 捆绑在一起的测试运行器。但为什么不编写自己的可以在浏览器中运行的测试运行程序呢?

/** @type {[string, () => Promise | void][]} */
const tests = [];

/**
 *
 * @param {string} description
 * @param {() => Promise | void} testFunc
 */
export async function test(description, testFunc) {
  tests.push([description, testFunc]);
}

export async function runAllTests() {
  const main = document.querySelector("main");
  if (!(main instanceof HTMLElement)) throw new Error();
  main.innerHTML = "";

  for (const [description, testFunc] of tests) {
    const newSpan = document.createElement("p");

    try {
      await testFunc();
      newSpan.textContent = `✅ ${description}`;
    } catch (err) {
      const errorMessage =
        err instanceof Error && err.message ? ` - ${err.message}` : "";
      newSpan.textContent = `❌ ${description}${errorMessage}`;
    }
    main.appendChild(newSpan);
  }
}

/**
 * @param {any} val
 */
export function assert(val, message = "") {
  if (!val) throw new Error(message);
}

现在创建一个文件 example.test.js.

import { test, assert } from "@/test.js";

test("1 1", () => {
  assert(1   1 === 2);
});

还有一个导入所有测试的文件:

import "./example.test.js";

console.log("This should only show up when running tests");

在页面加载时运行此命令:

await import("@/test/index.js"); // file that imports all tests
(await import("@/test.js")).runAllTests();

您获得了完美的 TDD 设置。要仅运行一部分测试,您可以注释掉一些 .test.js 导入,但只有当您积累了大量测试时,测试执行速度才会开始成为问题。

好处

你为什么要这样做?那么,使用较少的抽象层可以使您的项目更易于调试。还有“利用平台”的信条。您学到的技能将更好地转移到其他项目中。另一个优点是,当您在 10 年内返回这样构建的项目时,它仍然可以正常工作,并且您不需要进行考古来尝试恢复已经失效 8 年的构建工具。许多从事遗留项目的 Web 开发人员都会熟悉这种经历。

请访问 plainvanillaweb.com 了解更多想法。

版本聲明 本文轉載於:https://dev.to/louwers/web-development-without-tooling-flk?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 網站 HTML 程式碼
    網站 HTML 程式碼
    我一直在嘗試建立一個與航空公司相關的網站。我只是想確認我是否可以使用人工智慧生成程式碼來產生整個網站。 HTML 網站是否相容於博客,或者我應該使用 JavaScript?這是我用作演示的程式碼。 <!DOCTYPE html> <html lang="en">[](url...
    程式設計 發佈於2024-11-05
  • 像程式設計師一樣思考:學習 Java 基礎知識
    像程式設計師一樣思考:學習 Java 基礎知識
    本文介紹了 Java 程式設計的基本概念和結構。它首先介紹了變數和資料類型,然後討論了操作符和表達式,以及控制流程。其次,它解釋了方法和類,然後介紹了輸入和輸出操作。最後,本文透過一個工資計算器的實際範例展示了這些概念的應用。 像程式設計師一樣思考:掌握Java 基礎1. 變數與資料型別 ]Java...
    程式設計 發佈於2024-11-05
  • PHP GD 可以比較兩個影像的相似性嗎?
    PHP GD 可以比較兩個影像的相似性嗎?
    PHP GD 可以確定兩個影像的相似度嗎? 正在考慮的問題詢問是否可以使用以下命令確定兩個圖像是否相同PHP GD 通過比較它們的差異。這需要獲取兩個影像之間的差異並確定它是否完全由白色(或任何統一的顏色)組成。 根據所提供的答案,雜湊函數(如其他回應所建議的)不適用於此情境。比較必須涉及圖像內容而...
    程式設計 發佈於2024-11-05
  • 使用這些鍵編寫進階測試(JavaScript 中的測試需求)
    使用這些鍵編寫進階測試(JavaScript 中的測試需求)
    在本文中,您將學習每個高級開發人員都應該了解的 12 個測試最佳實踐。您將看到 Kent Beck 的文章“Test Desiderata”的真實 JavaScript 範例,因為他的文章是用 Ruby 編寫的。 這些屬性旨在幫助您編寫更好的測試。了解它們還可以幫助您在下一次工作面試中取得好成績。...
    程式設計 發佈於2024-11-05
  • 透過將 matlab/octave 演算法移植到 C 來實現 AEC 的最佳解決方案
    透過將 matlab/octave 演算法移植到 C 來實現 AEC 的最佳解決方案
    完畢!對自己有點印象。 我們的產品需要迴聲消除功能,確定了三種可能的技術方案, 1)利用MCU偵測audio out和audio in的音訊訊號,編寫演算法計算兩側聲音訊號的強度,根據audio out和audio in的強弱在兩個通道之間進行可選的切換,實現半雙工通話效果,但現在市面上都是全雙工...
    程式設計 發佈於2024-11-05
  • 逐步建立網頁:探索 HTML 中的結構和元素
    逐步建立網頁:探索 HTML 中的結構和元素
    ?今天標誌著我軟體開發之旅的關鍵一步! ?我編寫了第一行程式碼,深入研究了 HTML 的本質。涵蓋的元素和標籤。昨天,我探索了建立網站的拳擊技術,今天我透過創建頁眉、頁腳和內容區域等部分將其付諸實踐。我還添加了各種 HTML 元素,包括圖像元素和連結元素,甚至嘗試在單頁網站上進行內部連結。看到這些部...
    程式設計 發佈於2024-11-05
  • 專案創意不一定是獨特的:原因如下
    專案創意不一定是獨特的:原因如下
    在創新領域,存在一個常見的誤解,即專案創意需要具有開創性或完全獨特才有價值。然而,事實並非如此。我們今天使用的許多成功產品與其競爭對手共享一組核心功能。讓他們與眾不同的不一定是想法,而是他們如何執行它、適應用戶需求以及在關鍵領域進行創新。 通訊應用案例:相似但不同 讓我們考慮一下 ...
    程式設計 發佈於2024-11-05
  • HackTheBox - Writeup 社論 [已退休]
    HackTheBox - Writeup 社論 [已退休]
    Neste writeup iremos explorar uma máquina easy linux chamada Editorial. Esta máquina explora as seguintes vulnerabilidades e técnicas de exploração: S...
    程式設計 發佈於2024-11-05
  • 強大的 JavaScript 技術可提升您的編碼技能
    強大的 JavaScript 技術可提升您的編碼技能
    JavaScript is constantly evolving, and mastering the language is key to writing cleaner and more efficient code. ?✨ Whether you’re just getting starte...
    程式設計 發佈於2024-11-05
  • 如何在 ReactJS 中建立可重複使用的 Button 元件
    如何在 ReactJS 中建立可重複使用的 Button 元件
    按鈕無疑是任何 React 應用程式中重要的 UI 元件,按鈕可能用於提交表單或開啟新頁面等場景。您可以在 React.js 中建立可重複使用的按鈕元件,您可以在應用程式的不同部分中使用它們。因此,維護您的應用程式將變得更加簡單,並且您的程式碼將保持 DRY(不要重複自己)。 您必須先在元件資料夾...
    程式設計 發佈於2024-11-05
  • 如何在 Apache HttpClient 4 中實作搶佔式基本驗證?
    如何在 Apache HttpClient 4 中實作搶佔式基本驗證?
    使用Apache HttpClient 4 簡化搶佔式基本驗證雖然Apache HttpClient 4 已經取代了早期版本中的搶佔式驗證方法,但它提供了替代方法以實現相同的功能。對於尋求直接搶佔式基本驗證方法的開發人員,本文探討了一種簡化方法。 為了避免向每個請求手動新增 BasicHttpCon...
    程式設計 發佈於2024-11-05
  • 例外處理
    例外處理
    異常是運行時發生的錯誤。 Java 中的異常處理子系統可讓您以結構化和受控的方式處理錯誤。 Java為異常處理提供了易於使用且靈活的支援。 主要優點是錯誤處理程式碼的自動化,以前必須手動完成。 在舊語言中,需要手動檢查方法傳回的錯誤碼,既繁瑣又容易出錯。 異常處理透過在發生錯誤時自動執行...
    程式設計 發佈於2024-11-05
  • 如何在不使用「dangerouslySetInnerHTML」的情況下安全地在 React 中渲染原始 HTML?
    如何在不使用「dangerouslySetInnerHTML」的情況下安全地在 React 中渲染原始 HTML?
    使用更安全的方法在React 中渲染原始HTML在React 中,您現在可以使用更安全的方法來渲染原始HTML ,避免使用危險的SetInnerHTML 。這裡有四個選項:1。 Unicode 編碼使用Unicode 字元表示UTF-8 編碼檔案中的HTML 實體:<div>{`Firs...
    程式設計 發佈於2024-11-05
  • PHP 死了嗎?不,它正在蓬勃發展
    PHP 死了嗎?不,它正在蓬勃發展
    PHP 是一種不斷受到批評但仍在蓬勃發展的程式語言。 使用率:根據 W3Techs 的數據,截至 2024 年 8 月,全球 75.9% 的網站仍在使用 PHP,其中 43% 的網站基於 WordPress。使用PHP作為開發語言的主流網站中,超過70%包括Facebook、微軟、維基百科、Moz...
    程式設計 發佈於2024-11-05
  • PgQueuer:將 PostgreSQL 轉變為強大的作業佇列
    PgQueuer:將 PostgreSQL 轉變為強大的作業佇列
    PgQueuer 簡介:使用 PostgreSQL 實現高效能作業佇列 社區開發者您好! 我很高興分享一個項目,我相信該項目可以顯著簡化開發人員在使用 PostgreSQL 資料庫時處理作業佇列的方式。 PgQueuer,這是一個 Python 函式庫,旨在利用 PostgreS...
    程式設計 發佈於2024-11-05

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

Copyright© 2022 湘ICP备2022001581号-3