从这个API能看到整个前端的缩影

开发 前端
本文我们从这个API出发,来聊聊Web的发展。

大家好,我卡颂。

如果要从JS中找一个API作为整个前端的缩影,ESM规范中的import再合适不过了。

本文我们从这个API出发,来聊聊web的发展。

web的本质是开放

在所有JS​运行时中,web​是最开放的(紧随其后的可能是deno​)。这一点可以从import语法的「模块说明符」窥探一丝端倪。

// 模块说明符为 './a.js'
import xxx from './a.js'

在ES规范中只明确「模块说明符是一个字符串字面量」,并没有限制「如何解析模块说明符」,所以「解析模块说明符」的任务就交给了宿主环境。

在web​的HTML规范中,「模块说明符」可以是如下形式:

  • 绝对路径的url,比如:
import confetti from 'https://cdn.skypack.dev/canvas-confetti';
  • 以/、./、../开头的相对路径,比如:
import xxx from './a.js'
  • 定义模块名到url的映射,再以模块名的形式引入,比如:
<script type="importmap">
{
"imports": {
"moment": "/node_modules/moment/src/moment.js"
}
}
</script>

再引入模块:

import moment from "moment";

PS:这种方式被称为import-maps[1],当前浏览器兼容性还不高:

图片

可以发现,这三种方式对「模块说明符」的来源都很开放。反观​​Node.js​​运行时,如果以包名的形式引入模块,比如:

import moment from "moment";

背后是一套指向node_modules,并最终指向npm库的机制。npm是家私人公司,被github收购,而github被微软收购。

所以,如果某一天国内无法直接安装npm包,也不必惊讶,毕竟他的背后是一家私人公司。

与之相对,web的开放让他不会面临这种囧境。

兼容性的迭代

web​的发展史,就是一部「新三年、旧三年、修修补补又三年」的兼容史。很多API​的兼容性问题可以通过polyfill解决。

所以,很自然的,库作者在面对模块规范的兼容性问题时,也想替用户做到最好。但是,这份努力也让代码行为变得更扑朔迷离。

比如:在ESM​模块中是可以引入CJS​模块的。对于如下CJS模块:

// a.js cjs模块
exports.hello = () {
console.log('hello')
}

在同级的ESM模块中引入,并通过解构或者对象方法来使用hello:

import utils from './a.js';

const {hello} = utils;
// 或者
const hello = utils.hello;

为什么不能直接以「具名引入」的形式使用hello呢:

// 不能这样
import {hello} from './a.js'

这是因为ESM规范的导入声明都是静态的,而CJS规范的导出是动态的,所以当ESM模块引入CJS模块时,在编译时是没法知道有哪些导出的。

这很符合规范,但看起来有点不符合直觉。

比如,React只提供了CJS规范的包,所以在ESM模块中正确的引入方式是:

import React from 'react';
const { useState } = React;

而大家日常开发显然下面这种方式用的更多:

import { useState } from 'react';

之所以这么引入不会报错,是因为库作者(比如vite、babel)在编译时默默做了转换。

为了方便开发者而违背规范,这其实是个很不好的事(类似的事还有npm、yarn的影子依赖)。

但开发者喜闻乐见的API就是好API,整个web的发展就是修修补补螺旋向上的。

bundle将长期存在

在vite横空出世,带来极致的开发时速度后,社区就掀起一股「bundle vs bundleless」的讨论。

既然bundleless能为开发环境带来提速,同样的优势能不能也带到生产环境?或者更极端点,未来前端会逐渐抛弃打包工具么?

从ESM​规范的角度出发,答案是否定的。有两个刚需现阶段bundleless还无法解决:

  • tree shaking
  • ESM模块过多,导致发起大量请求

所以,在未来很长一段时间内,打包工具仍会存在。

总结

在我的技术群中,经常看到新人前端发出感叹:「不知道该学啥」。

究其原因,当前的前端开发,主要是使用「集成了最佳实践的各种大型框架」(比如Nuxt​、Next.js​、UmiJS...)。而这些封装完备的框架为了降低上手门槛,隐藏了大量技术细节。

如果你也有这种迷茫,我建议你从ESM规范开始学起。

他就像一张地图,能够串联起前端的方方面面。

参考资料

[1]import-maps:https://github.com/WICG/import-maps

责任编辑:姜华 来源: 魔术师卡颂
相关推荐

2021-04-28 22:42:36

SaaS软件技术

2012-09-18 15:35:45

云计算创意大赛微软

2017-03-29 20:43:32

线上日志磁盘

2020-12-02 09:47:07

DNSIP地址广告弹窗

2023-03-21 23:48:31

ChatGPT漏洞安全

2022-12-29 08:22:32

JOINCPU系统

2016-09-22 13:42:45

用友

2020-09-07 12:53:56

.NET 5Web应用框架

2021-04-07 14:05:59

数据科学CIOCDO

2023-09-21 21:55:44

2012-09-06 13:12:41

架构师ArchSummit

2020-11-10 09:11:02

采集数据

2022-12-07 13:39:51

苹果造车

2013-03-15 10:35:17

编程语言编程笑话

2020-08-10 16:10:02

微软WindowsWindows 10

2020-07-31 11:01:46

BI新基建国产化

2010-10-15 10:35:18

2020-11-09 11:10:56

前端api缓存

2020-08-06 18:11:15

SaaS

2017-05-23 10:19:27

点赞
收藏

51CTO技术栈公众号