0

0

无需(构建)工具的 Web 开发

WBOY

WBOY

发布时间:2024-08-05 19:10:26

|

559人浏览过

|

来源于dev.to

转载

无需(构建)工具的 web 开发

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

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

<!doctype html>
<html>
  <head>
  </head>
  <body>
    <p>hello world</p>
  </body>
</html>

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

python3 -m http.server

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

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

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

console.log("hello world");

export {};

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

<script type="module" src="./index.js"></script>

在浏览器中打开开发者控制台。如果你看到“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"]
}

现在就跑吧

极限网络办公Office Automation
极限网络办公Office Automation

专为中小型企业定制的网络办公软件,富有竞争力的十大特性: 1、独创 web服务器、数据库和应用程序全部自动傻瓜安装,建立企业信息中枢 只需3分钟。 2、客户机无需安装专用软件,使用浏览器即可实现全球办公。 3、集成Internet邮件管理组件,提供web方式的远程邮件服务。 4、集成语音会议组件,节省长途话费开支。 5、集成手机短信组件,重要信息可直接发送到员工手机。 6、集成网络硬

下载
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部分:

<script type="importmap">
  {
    "imports": {
      "superstruct": "https://esm.sh/superstruct@1.0.4"
    }
  }
</script>

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

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> | void][]} */
const tests = [];

/**
 *
 * @param {string} description
 * @param {() => promise<void> | 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 了解更多想法。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

43

2026.02.13

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

160

2026.02.25

json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

452

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

546

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

330

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

81

2025.09.10

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

514

2023.07.28

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

4

2026.03.05

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.8万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号