• 前端工程化精讲第一课 项目基石:前端脚手架工具探秘


    你好,我是李思嘉,从事前端开发十余年,曾先后在多家大型互联网公司从事前端架构工作,历经很多项目从 0 到 1 的搭建过程,也做了不少前端效率优化和性能提升等工程化的实践。

    目前,我在贝壳找房前端架构组任资深工程师,专注于公司内前端通用构建平台,以及前端开发工具生态的服务建设。工作中,我接触过不少项目搭建、开发提效、构建优化、部署工具和容器化等方面的技术细节,也沉淀出了一套关于前端工程化的方法论,希望在这里分享给你。

    为什么要学习前端效率工程化

    通常,一个中高级前端工程师,除了要完成业务功能开发目标外,还要对所开发项目的效率、性能、质量等工程化维度去制定和实施技术优化目标,其中以提升效率为目标的优化技术和工具就属于效率工程化的范畴。

    对于公司而言,团队效率可以直接带来人工投入产出比的提升,因此效率提升通常会被作为技术层面的一个重点优化方向。而在面试中,对效率工程化的理解程度和实践中的优化产出情况,也是衡量前端工程师能力高低的常见标准。

    例如,在拉勾网搜索前端相关职位,可以看到中高级以上的前端工程师岗位需求中大都会要求熟练掌握 webpack 构建工具、具备开发效率实践经验等。只有具备这方面的能力,你才能应对和优化复杂项目,保证团队高效产出。

    image (3).png

    拉勾网搜索“前端效率工程”的岗位情况

    然而,大部分时间都投身在业务开发中的前端同学,在效率工程化方面经常面临很多困扰:

    • 由于缺乏系统化知识,对于项目中的效率问题常常不知从何处着手,甚至找错解决方向。比如在解决项目构建效率问题时,考虑的通常是增加优化插件的方向,但有时候问题的关键点可能只是一些 source map 、include 之类的基本参数设置不当。

    • 由于缺少工程化的视野,难以发现工作中的效率提升点和制定针对性的提升方案,导致技术优化实践少,成长慢。

    • 技术晋升和面试求职中,由于缺少方法论和深度思考,在讲解技术优化细节时常常回答得不完整或者有错漏、混淆,很难在能力表现上脱颖而出。

    要解决这些问题,单单凭借个人知识积累往往成长缓慢,难以打开视野,最有效的方式是找到自己的短板来做针对性提升。而只有全面、系统地掌握效率的影响因素以及其中的技术细节,才能在面对实际问题时明确分析思路,快速找到症结所在,制定有针对性的优化方案。

    但和语言类教程不同,你很难找到系统讲解前端效率工程化的课程。因为,效率工程化涉及的知识点更为繁杂,散落在大量的细节优化实践中,需要人为地去总结和梳理完善。而这,正是我写作这门课的初衷。

    课程设计

    在这个课程中,我梳理了前端开发工作流程中和效率提升相关的知识点和案例,希望借此能帮你构筑一个系统性的前端效率知识体系,建立正确的问题解决思路,让你进行效率优化时有据可依。

    课程共 22 篇,分别从开发效率、构建效率和部署效率 3 个维度来展开讲解。

    • 第一部分:开发效率。 开发是我们日常工作过程中最熟悉的部分。工欲善其事必先利其器,在这一模块,我会主要分析各种项目在开发过程中的效率提升点,例如在项目启动时如何选择和配置自定义脚手架、如何配置我们的开发联调环境等效率优化细节,还会介绍包括时下流行的云开发、无代码工具、低代码工具等提效新思路。希望你在学习之后,能够在未来的项目开发中自如地选择和搭建最适合自身的开发工具集。

    • 第二部分:构建效率。 如果说开发是我们日常投入最多的工作,那么等待构建结果就是日常耗费最多的非开发时间了。在这一模块,我会分析那些影响到 webpack 构建时间的关键因素,并详细分析对应的解决方案和工具。此外,我还会进一步讲解 webpack 5 中新的效率提升方案,并带你了解 no-bundle 类构建工具的优缺点。希望通过这些内容的学习,来帮助你建立完整的构建工具优化思路,进一步优化你的项目构建效率 最大程度消灭那些无谓的等待时间。

    • 第三部分:部署效率。 代码从构建到部署是前端能力的延伸。许多企业日常工作中的代码部署使用的是前后端通用的 CI/CD 系统,而前端开发人员在使用过程中较少能对其中的流程效率进行优化。在这一模块,我将介绍那些业界常用的 CI/CD 系统 ,并分析其中前端项目的效率优化点,以及从打包机方案到容器化方案、前端项目在部署时的注意点和优化空间。 希望学习完这部分内容,你能结合所在企业的技术特点,来打造或优化适合你前端项目的部署流程。

    你将获得

    全面、系统的效率工程化知识体系。我会带你系统学习相关知识,而不是碎片化获取,让你补全短板,提升个人技术实力。

    对实际项目输出针对性优化方案的能力。正确的方法比努力更重要,有了正确的思路方法,才能在实际工作中快速定位症结、避免跑偏,避免把力气花在一些细枝末节上。

    丰富的实战经验分享。我将从常用的开发效率提升工具讲到 webpack 底层的技术细节,再到部署工具中的效率优化分析,高度还原真实的业务场景,带你了解前端效率工程优化的全过程。

    面试 Offer 收割利器。课程中的许多案例,都是前端工程化方向面试题的重灾区,我将指出容易被忽略的内容考点,让你既能在整体上对效率工程化有一个由点到面的认识,也能深入掌握关键的技术细节。

    作者寄语

    最后,前端效率工程化涉及前端日常工作的各个环节,90% 的复杂度都藏匿在冰山之下,也因此很多人在解决效率问题时 “只见树木,不见森林”,希望这个专栏可以帮你建立上帝视角,让你体会到“哦,原来效率优化还有这些方面!”的感觉。

    单点问题的解决往往只关注当下,但系统化的解决方案,有助于增长你的长期价值。希望这个课程能够让你有新的启发,也希望你在留言区和我说说你的成长与困惑,与众人一起前行。


    你好,前端效率工程化这门课我们会讨论一个前端项目从开发到构建和部署这一系列工作流程的效率问题。在开发效率篇里,我们会讨论一系列影响开发效率的流程和工具。工欲善其事必先利其器,第一课时,我们首先从开发一个新项目时最基础的准备工作讲起。

    当你准备开发一个新项目时,在进入到实际业务编码前,通常需要做很多的基础准备工作,这里会遇到的问题有:

    1. 要准备好一个项目的基础开发设施,需要投入大量时间和精力,这部分的工作计量是以天为单位的。

    2. 一个完备的项目基础环境就像一个精密的仪器,只有各部分都充分协调后才能运转正常。要在较短时间内配置一个技术栈完整、辅助功能丰富、兼顾不同环境下构建优化目标的项目基础代码,通常需要开发人员在工程领域长久的知识储备与实践总结,而这对于经验相对较少的开发人员而言是一个不小的挑战。

    3. 不同的项目需求和团队情况,对应我们在使用基础设施时的选择可能也各不相同,因此我们并不能依靠一套固定不变的模板,而是需要根据不同的现状来使用不同的基础设施。这又增加了整体时间成本。

    脚手架工具,正是为了解决这些问题而诞生的。

    • 利用脚手架工具,我们可以经过几个简单的选项快速生成项目的基础代码。

    • 使用脚手架工具生成的项目模板通常是经过经验丰富的开发者提炼和检验的,很大程度上代表某一类项目开发的最佳实践,相较于让开发者自行配置提供了更优选择。

    • 同时,脚手架工具也支持使用自定义模板,我们也可以根据项目中的实际经验总结、定制一个脚手架模板。

    因此,对于一个熟练的前端工程师来说,要掌握的基本能力之一就是通过技术选型来确定所需要使用的技术栈,然后根据技术栈选择合适的脚手架工具,来做项目代码的初始化。一个合适的脚手架,可以为开发人员提供反复优化后的开发流程配置,高效地解决开发中涉及的流程问题,使得工程师能够快速上手,并提升整个开发流程的效率和体验。当然,前提是建立在选择对了脚手架工具并深入掌握其工作细节的基础上。

    那么下面我们先来谈谈脚手架工具究竟是什么。

    什么是脚手架

    说到脚手架(Scaffold) 这个词,相信你并不陌生,它原本是建筑工程术语,指为了保证施工过程顺利而搭建的工作平台,它为工人们在各层施工提供了基础的功能保障。

    Drawing 0.png

    而在软件开发领域,脚手架是指通过各种工具来生成项目基础代码的技术。通过脚手架工具生成后的代码,通常已包含了项目开发流程中所需的工作目录内的通用基础设施,使开发者可以方便地将注意力集中到业务开发本身。

    那么对于日常的前端开发流程来说,项目内究竟有哪些部分属于通用基础设施呢?让我们从项目创建的流程说起。对于一个前端项目来说,一般在进入开发之前我们需要做的准备有:

    1. 首先我们需要有 package.json,它是 npm 依赖管理体系下的基础配置文件。

    2. 然后选择使用 npm 或 Yarn 作为包管理器,这会在项目里添加上对应的 lock 文件,来确保在不同环境下部署项目时的依赖稳定性。

    3. 确定项目技术栈,团队习惯的技术框架是哪种?使用哪一种数据流模块?是否使用 TypeScript?使用哪种 CSS 预处理器?等等。在明确选择后安装相关依赖包并在 src 目录中建立入口源码文件。

    4. 选择构建工具,目前来说,构建工具的主流选择还是 webpack (除非项目已先锋性地考虑尝试 nobundle 方案),对应项目里就需要增加相关的 webpack 配置文件,可以考虑针对开发/生产环境使用不同配置文件。

    5. 打通构建流程,通过安装与配置各种 Loader 、插件和其他配置项,来确保开发和生产环境能正常构建代码和预览效果。

    6. 优化构建流程,针对开发/生产环境的不同特点进行各自优化。例如,开发环境更关注构建效率和调试体验,而生产环境更关注访问性能等。

    7. 选择和调试辅助工具,例如代码检查工具和单元测试工具,安装相应依赖并调试配置文件。

    8. 最后是收尾工作,检查各主要环节的脚本是否工作正常,编写说明文档 README.md,将不需要纳入版本管理的文件目录记入 .gitignore 等。

    正如下面简单的示例项目模板,经历了上面这些步骤后我们的项目目录下就新增了这些相关的文件:

    package.json         1) npm 项目文件 
    package-lock.json    2) npm 依赖 lock 文件 
    public/              3) 预设的静态目录 
    src/                 3) 源代码目录 
      main.ts            3) 源代码中的初始入口文件 
      router.ts          3) 源代码中的路由文件 
      store/             3) 源代码中的数据流模块目录 
    webpack/             4) webpack 配置目录 
      common.config.js   4) webpack 通用配置文件 
      dev.config.js      4) webpack 开发环境配置文件 
      prod.config.js     4) webpack 生产环境配置文件 
    .browserlistrc       5) 浏览器兼容描述 browserlist 配置文件 
    babel.config.js      5) ES 转换工具 babel 配置文件 
    tsconfig.json        5) TypeScript 配置文件 
    postcss.config.js    5) CSS 后处理工具 postcss 配置文件 
    .eslintrc            7) 代码检查工具 eslint 配置文件 
    jest.config.js       7) 单元测试工具 jest 配置文件 
    .gitignore           8) Git 忽略配置文件 
    README.md            8) 默认文档文件
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19

    而通过脚手架工具,我们就能免去人工处理上的环节,轻松地搭建起项目的初始环境,直接进入到业务开发中。接下来我们就先来看一下前端领域的几个典型脚手架工具,了解这几个脚手架所代表的不同设计理念,接着我们会重点分析两个代表性脚手架工具包内的技术细节,以便在工作中更能得心应手地使用和优化。

    三种代表性的前端脚手架工具

    7.png

    Yeoman

    6.png

    [图:logo-yeoman]

    Yeoman 是前端领域内较早出现的脚手架工具,它由 Google I/O 在 2012 年首次发布。Yeoman 提供了基于特定生成器(Generator)来创建项目基础代码的功能。时至今日,在它的网站中能找到超过 5600 个不同技术栈的代码生成器。

    作为早期出现在前端领域的脚手架工具,它没有限定具体的开发技术栈,提供了足够的开放性和自由度,但也因此缺乏某一技术栈的深度集成和技术生态。随着前端技术栈的日趋复杂化,人们更倾向于选择那些以具体技术栈为根本的脚手架工具,而 Yeoman 则更多用于一些开发流程里特定片段代码的生成。

    Create-React-App

    4.png

    [图:logo-create-react-app]

    Create React App(后简称 CRA )是 Facebook 官方提供的 React 开发工具集。它包含了 create-react-app 和 react-scripts 两个基础包。其中 create-react-app 用于选择脚手架创建项目,而 react-scripts 则作为所创建项目中的运行时依赖包,提供了封装后的项目启动、编译、测试等基础工具。

    正如官方网站中所说的,CRA 带来的最大的改变,是将一个项目开发运行时的各种配置细节完全封装在了一个 react-scripts 依赖包中,这大大降低了开发者,尤其是对 webpack 等构建工具不太熟悉的开发者上手开发项目的学习成本,也降低了开发者自行管理各配置依赖包的版本所需的额外测试成本。

    但事情总有两面性,这种近乎黑盒的封装在初期带来便利的同时,也为后期的用户自定义优化带来了困难。虽然官方也提供了 eject 选项来将全部配置注入回项目,但大部分情况下,为了少量优化需求而放弃官方提供的各依赖包稳定升级的便利性,也仍不是一个好的选择。在这种矛盾之下,在保持原有特性的情况下提供自定义配置能力的工具 react-rewiredcustomize-cra 应运而生。

    Vue CLI

    5.png

    [图:logo-vue-cli]

    正如 Create-React-App 在 React 项目开发中的地位, Vue 项目的开发者也有着自己的基础开发工具。Vue CLI 由 Vue.js 官方维护,其定位是 Vue.js 快速开发的完整系统。完整的 Vue CLI 由三部分组成:作为全局命令的 @vue/cli、作为项目内集成工具的 @vue/cli-service、作为功能插件系统的 @vue/cli-plugin-。

    Vue CLI 工具在设计上吸取了 CRA 工具的教训,在保留了创建项目开箱即用的优点的同时,提供了用于覆盖修改原有配置的自定义构建配置文件和其他工具配置文件。

    同时,在创建项目的流程中,Vue CLI 也提供了通过用户交互自行选择的一些定制化选项,例如是否集成路由、TypeScript 等,使开发者更有可能依据这些选项来生成更适合自己的初始化项目,降低了开发者寻找模板或单独配置的成本。

    除了技术栈本身的区别之外,以上三种脚手架工具,实际上代表了三种不同的工具设计理念:

    • Yeoman 代表的是一般开源工具的理念。它不提供某一技术栈的最佳实践方案,而专注于实现脚手架生成器的逻辑和提供展示第三方生成器。作为基础工具,它的主要目标群体是生成器的开发者,而非那些需要使用生成器来开发项目的人员,尽管后者也能通过前者的实践而受益。

    • CRA 代表的是面向某一技术栈降低开发复杂度的理念。它通过提供一个包含各开发工具的集成工具集和标准化的开发-构建-测试三步流程脚本,使得开发者能无障碍地按照既定流程进行 React 项目的开发和部署。

    • Vue CLI 代表的是更灵活折中的理念。它一方面继承了 CRA 降低配置复杂度的优点,另一方面在创建项目的过程中提供了更多交互式选项来配置技术栈的细节,同时允许在项目中使用自定义配置。这样的设计在一定程度上增加了模板维护的复杂度,但是从最终效果来看,能够较大程度满足各类开发者的不同需求。

    了解脚手架模板中的技术细节

    刚上手开发项目时,我们通过上述脚手架提供的开箱即用的能力可以很容易地上手开发项目,但是往往在开发过程中遇到问题时又需要回过头来查询文档,看脚手架中是否已有相应解决方案。而如果我们对该脚手架足够熟悉,就能减少这类情况下所花费的时间提升开发效率。所以在这里,我们先来聊一下该如何了解一个脚手架。

    要了解一个脚手架,除了学会如何使用脚手架来创建项目外,我们还需要了解它提供的具体功能边界,提供了哪些功能、哪些优化。这样我们才能在后续的开发中更得心应手,后续的优化也更有的放矢。

    还是以上面的 CRA 和 Vue CLI 为例,除了通过脚手架模板生成项目之外,项目内部分别使用 react-scripts 和 vue-cli-service 作为开发流程的集成工具。接下来,我们先来对比下这两个工具在开发与生产环境命令中都使用了哪些配置项,其中一些涉及效率的优化项在后面的课程中还会详细介绍。

    webpack loaders

    从下面表格中我们可以发现,在一般源文件的处理器使用方面,两个脚手架工具大同小异,对于 babel-loader 都采用了缓存优化,Vue 中还增加了多线程的支持。在样式和其他类型文件的处理上 Vue 默认支持更多的文件类型,相应的,在 CRA 模板下如果需要支持对应文件就需要使用 customize-cra 等工具来添加新处理模块。

    1.png

    webpack plugins

    在与构建核心功能相关的方面(html、env、hot、css extract、fast ts check),两者使用的插件相同,而在其他一些细节功能上各有侧重,例如 React 的 inline chunk 和 Vue 的 preload。

    2.png

    第三方工具

    webpack.optimize

    两者在代码优化配置中相同的部分包括:都使用 TerserPlugin 压缩JavaScript, 都使用 splitChunks 做自动分包 (参数不同)。CSS 的压缩分别采用上面表格中的 OptimizeCssAssetsWebpackPlugin 和 OptimizeCssNanoPlugin 。react-scripts 中还开启了 runtimeChunk 以优化缓存。

    webpack resolve

    在 resolve 和 resolve loader 部分,值得一提的是两者都使用 PnpWebpackPlugin(pnp) 来加速使用 Yarn 作为包管理器时的模块安装和解析,感兴趣的同学可以 进一步了解,我们在后面构建和部署的篇章中也会再次谈到。

    通过上述几方面的对比,我们就对这两个典型脚手架工具提供的构建集成能力有了一个大概的了解。这有助于我们在使用具体工具时快速定位问题的边界,同时在使用其他脚手架工具和模板时,我们也可以参照和借鉴上面的最佳实践方案。下一步,我们再来讨论定制专属脚手架模板的问题。

    如何定制一个脚手架模板

    虽然官方提供的默认脚手架模板已经代表了对应技术栈的通用最佳实践,但是在实际开发中,我们还是时常需要对通过这些脚手架创建的模板项目进行定制化,例如:

    1. 为项目引入新的通用特性。

    2. 针对构建环节的 webpack 配置优化,来提升开发环境的效率和生产环境的性能等。

    3. 定制符合团队内部规范的代码检测规则配置。

    4. 定制单元测试等辅助工具模块的配置项。

    5. 定制符合团队内部规范的目录结构与通用业务模块,例如业务组件库、辅助工具类、页面模板等。

    通过将这些实际项目开发中所需要做的定制化修改输出为标准的脚手架模板,我们就能在团队内部孵化出更符合团队开发规范的开发流程。一方面最大程度减少大家在开发中处理重复事务的时间,另一方面也能减少因为开发风格不一导致的团队内项目维护成本的增加。接下来,我们就结合上面提到的三个脚手架工具来分别看下如何定制专属的脚手架模板。

    使用 Yeoman 创建生成器

    脚手架模板在 Yeoman 中对应的是生成器 (Generator)。作为主打自由制作和分享脚手架生成器的开源工具, Yeoman 为制作生成器提供了丰富的 API 和 详细的文档。在这里,我们简单概述一下,一个基本的复制已有项目模板的生成器包含了:

    1. 生成器描述文件 package.json,其中限定了 name、file、keywords 等对应字段的规范赋值。

    2. 作为主体的 generators/app 目录,包含生成器的核心文件。该目录是执行 yo 命令时的默认查找目录, Yeoman 支持多目录的方式集成多个子生成器,篇幅原因我就不在这里展开了。

    3. app/index.js 是生成器的核心控制模块,其内容是导出一个继承自 yeoman-generator 的类,并由后者提供运行时上下文、用户交互、生成器组合等功能。

    4. app/templates/ 目录是我们需要复制到新项目中的脚手架模板目录。

    基本目录结构如下所示:

    generator-[name]/ 
      package.json 
      generators/ 
        app/ 
          templates/... 
          index.js
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6

    其中 app/index.js 的核心逻辑如下:

    var Generator = require('yeoman-generator') 
    module.exports = class extends Generator { 
      writing() { 
        this.fs.copyTpl( 
          this.templatePath('.'),
          this.destinationPath('.')) 
      } 
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    install() {
    this.npmInstall()
    }
    }

    writing 和 install 是 Yeoman 运行时上下文的两个阶段,在例子中,当我们执行下面的创建项目命令时,依次将生成器中模板目录内的所有文件复制到创建目录下,然后执行安装依赖。

    在完成生成器的基本功能后,我们就可以通过在生成器目录里 npm link ,将对应生成器包挂载到全局依赖下,然后进入待创建项目的目录中,执行 yo 创建命令即可。 (如需远程安装,则需要先将生成器包发布到 npm 仓库中,支持发布到 @scope/generator-[name] 。)

    Drawing 4.png

    至此,制作 Yeoman 的生成器来定制项目模板的基本功能就完成了。除了基本的复制文件和安装依赖外, Yeoman 还提供了很多实用的功能,例如编写用户交互提示框或合成其他生成器等,可供开发者定制功能体验更完善的脚手架生成器。

    为 create-react-app 创建自定义模板

    为 create-react-app 准备的自定义模板在模式上较为简单。作为一个最简化的 CRA 模板,模板中包含如下必要文件:

    • README.md:用于在 npm 仓库中显示的模板说明。

    • package.json:用于描述模板本身的元信息 (例如名称、运行脚本、依赖包名和版本等) 。

    • template.json:用于描述基于模板创建的项目中的 package.json 信息。

    • template 目录:用于复制到创建后的项目中,其中 gitignore 在复制后重命名为 .gitignore , public/index.html和src/index 为运行 react-scripts 的必要文件。

    具体目录结构如下所示:

    cra-template-[template-name]/ 
      README.md (for npm) 
      template.json 
      package.json 
      template/ 
        README.md (for projects created from this template) 
        gitignore 
        public/ 
          index.html 
        src/ 
          index.js (or index.tsx)
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    在使用时,同样还是需要将模板通过 npm link 命令映射到全局依赖中,或发布到 npm 仓库中,然后执行创建项目的命令。

    npx create-react-app [app-name] --template [template-name]
    
    • 1
    为 Vue CLI 创建自定义模板

    相比 CRA 模板而言,Vue 的模板中变化最大的当属增加了 meta.js/json 文件,用于描述创建过程中的用户交互信息以及用户选项对于模板文件的过滤等。

    [template-name]/ 
      README.md (for npm) 
      meta.js or meta.json 
      template/
    
    • 1
    • 2
    • 3
    • 4
    • 1
    • 2
    • 3
    • 4

    此外,Vue 的 template 目录中包含了复制到项目中的所有文件,并且在相关文件中还增加了 handlebars 条件判断的部分,根据 meta.js 中指定用户交互结果选项来将模板中带条件的文件转换为最终生成到项目中的产物。如以下代码所示:

    template/package.json 
    ... 
    "dependencies": { 
      "vue": "^2.5.2"{{#router}}, 
      "vue-router": "^3.0.1"{{/router}} 
    }, 
    ... 
    meta.js 
    ... 
    prompts: { 
      ... 
      router: { 
        when: 'isNotTest', 
        type: 'confirm', 
        message: 'Install vue-router?', 
      }, 
      ... 
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18

    使用自定义模板创建项目的命令为:

    npm install -g @vue/cli-init 
    vue init [template-name] [app-name]
    
    • 1
    • 2
    • 1
    • 2

    这样就完成了脚手架的定制工作。有了定制化后的脚手架,我们就可以在之后的创建项目时直接进入到业务逻辑的开发中,而不必重复地对官方提供的标准化模板进行二次优化。

    总结

    使用脚手架工具是提升开发效率的第一项内容。通过今天的学习,我们了解了脚手架的使用场景,了解了 3 个典型脚手架工具的特点,并分析了 React 和 Vue 官方提供的脚手架工具中的构建集成技术细节。最后,对于希望将业务中使用的更具定制化的基础代码转变为新的脚手架模板的同学,我们也了解了如何在不同工具环境下创建和使用自定义模板。

    课程最后,我想请你来回想一下:你在项目开发中使用的是哪一种脚手架工具和模板?使用的理由是?你可以将答案写在留言区与大家一起讨论。

    下个课时我们将要学习的是一个大家一直在使用但是很少了解其中细节的技术点:热更新技术。


    精选评论

    **英:

    老师讲的很实在,很实用,希望能拿到更多offer

    **荣:

    我们公司部分dev机接口只能本机访问,这种情况dev-server 无法使用,前端cli有什么建议吗,旧方式是gulp watch 实时使用sftp上传到dev机进行测试。我准备做一套新的cli,放弃gulp

        讲师回复:

        1. 接口只能本机访问的原因是?如果因为服务启动使用的是127.0.0.1的话可以改成0.0.0.0试试,后者可以通过网络访问。
    2.VS Code支持通过ssh访问远程开发机目录下的代码,代码在dev机器上启动devServer然后本地IDE通过ssh链接这样的工作流程应该也可以。

    1. 构建工具的选择主要还是看开发模式是否符合以及相应工具的生态是否健全。cli是构建工具的一部分,单独开发整个工具生态的投入产出比不是很高,如果单纯是上面的网络问题建议考虑上面2点。如果是希望尝试新的构建工具建议选择其他生态比较成熟的工具。
    vience:

    豁然开朗呀 老师可以出本书 我预订了

        编辑回复:

        感谢同学支持老师

    **潮:

    跟着大佬学习

    **靖:

    老师,amgular-cli不算主流吗?

        讲师回复:

        其实并没有一个主流非主流的绝对定义,只是react和vue的使用者人数上可能更多一些大家会更熟悉一些,所以文章篇幅限制的情况下就只介绍了这两种脚手架工具,让大家有一个对比。使用angular的同学也可以从相同的维度去对比angular-cli和其他脚手架工具的区别。

    *悦:

    思路很不错,一起加油😁

    *亮:

    跟着大佬学习,讲得不错喔

    *林:

    感觉可以写一个脚手架工具而不只对已有脚手架的简单扩展

    **东:

    讲的真的很棒,收获很多,期待接下来的课程

    *子:

    课程内容很给力

    **树:

    超级棒的课程!!!知识点讲的详详细细,讲的通俗易懂

    *红:

    一起加油~

  • 相关阅读:
    hello react
    风控指南 | 风控引擎如何快速管理组件?
    【数据结构C/C++】根据前序中序和中序后续遍历结果生成二叉树
    2019年[海淀区赛 第2题] 阶乘
    HTTP协议。(HTTP-概述和特点、HTTP-请求协议、HTTP-请求数据格式、浏览器访问服务器的几种方式)
    IDEA 新建 JavaWeb 项目(:找不到 Web Application 解决方法)
    R语言混合效应逻辑回归(mixed effects logistic)模型分析肺癌数据
    UE基础篇六:音频
    通信总线协议五 :CAN
    Git 创建分支、合并分支
  • 原文地址:https://blog.csdn.net/fegus/article/details/126553996