当前位置: 首页 > article >正文

前端架构: 脚手架的开发流程和常用框架

脚手架的开发流程

  • 脚手架的创建
    • $ npm init
  • 脚手架的开发
    • 分包
      • 分包是指当我们一个脚手架比较复杂的时候,不可能把所有的js代码全部写在一个脚手架当中
      • 势必会把它建很多的不同的模块 package,通常我们会把它称之为一个分包的过程
      • 会和实际的这个项目一样,去做这个项目的分包
    • 参数解析
      • 脚手架通常不可能一个命令就能完成所有的功能,一定要一些辅助参数
      • 比如说创建项目的时候,要起一个项目的名称,比如 --name
      • 像这些参数解析都是需要 nodejs 的一个技术能力支持的
  • 脚手架调试
    • $ npm link
    • $ npm unlink
    • 当开发完成之后,我们脚手架在本地还需要调试,因为脚手架上线之前一定是需要测试的
    • 这个脚手架在本地能够装起来进行测试
    • 这个时候会用到 npm link 和 npm unlink 这两个命令来完成脚手架的本地调试
  • 脚手架发布
    • $ npm publish
    • 本地调试通过以后,就可以实现脚手架的一个发布
    • 通过 npm publish 就可以去做脚手架的一个上线发布了
    • 发布完以后,我们可以通过 npm install -g 来完成脚手架的安装

使用框架来搭建脚手架

  • 为什么需要脚手架的框架?

    • 脚手架的框架,可以大幅度的提升脚手架的开发效率
      • 比如说在脚手架当中,想创建一个命令,命令后面要去配置各种属性
      • 在这个过程中,包括后续的维护迭代,修改的时候,是需要有一定的技巧的
      • 使用脚手架框架就可以让大家不需要去关注脚手架命令创建, 修改这些过程
      • 而专注于脚手架的业务开发,从而大幅提升脚手架开发速度
    • 可以简化脚手架开发流程,大幅度提高这个代码的可读性和可维护性
      • 在没使用脚手架框架之前,解析一条命令的时候
      • 可能会存在大量的很难阅读的逻辑,这套逻辑可能是不太好懂的
      • 而使用脚手架框架以后,代码里面的可读性可维护性都会非常大幅度增强
  • 常用的脚手架框架

    • yargs
      • Weekly Downloads 73,386,359 动态数据
      • 案例:gulp-cli
    • commander
      • Weekly Downloads 113,310,535 动态数据
      • 案例
        • vue-cli
        • webapck-cli
        • create-react-app
    • oclif
      • Weekly Downloads 104,302 动态数据
      • 它是一个脚手架生成器,它本身会提供一个 oclif cli 就是这个脚手架生成器
        • 它会提供一个脚手架,帮你来生成自己的脚手架
        • 同时它中间还提供了一系列脚手架的核心方法, 帮助快速的构建脚手架
        • 而 oclif 会把每一个命令当成一个 class 来去看待
        • 直接基于ts编写

http://www.kler.cn/a/231870.html

相关文章:

  • 【HarmonyOS】鸿蒙系统在租房项目中的项目实战(二)
  • 系统思考—结构影响行为
  • STM32 Option Bytes(选项字节)
  • PCB+SMT线上报价系统+PCB生产ERP系统自动化拼板模块升级
  • stdin文件流指针
  • 华为开源自研AI框架昇思MindSpore应用案例:人体关键点检测模型Lite-HRNet
  • 基于“python+”潮汐、风驱动循环、风暴潮等海洋水动力模拟实践技术
  • macOS系统下彻底删除应用程序和其数据、配置等
  • 《Git 简易速速上手小册》第1章:Git 基础(2024 最新版)
  • Python进阶----在线翻译器(Python3的百度翻译爬虫)
  • get通过发送Body传参-工具类
  • Go 语言中如何大小端字节序?int 转 byte 是如何进行的?
  • 小白水平理解面试经典题目LeetCode 21. Merge Two Sorted Lists【Linked List类】
  • 【Web - 框架 - Vue】随笔 - 通过`CDN`的方式使用`VUE 2.0`和`Element UI`
  • CDN相关和HTTP代理
  • nodejs将console.log保存到log.txt文档中(electron工具)
  • 图像处理入门:OpenCV的基础用法解析
  • 09 AB 10串口通信发送原理
  • SpringCloud+RabbitMQ+Docker+Redis+搜索+分布式 基础(持续更新~)
  • PdfFactory Pro软件下载以及序列号注册码生成器
  • 总结-回想2023
  • Java图形化界面编程——Container容器 笔记
  • Netty的常用组件及线程模型设计(二)
  • Markdown:简洁高效的文本标记语言
  • springboot(ssm悦己美容院后台管理系统 美容院管理系统Java系统
  • 第1节、电路连接【51单片机+L298N步进电机系列】