• vue-cli创建自定义preset预设项目


    背景

    一个 Vue CLI preset 是一个包含创建新项目所需预定义选项和插件的 JSON 对象,让用户无需在命令提示中选择它们。
    vue create 过程中保存的 preset 会被放在你的 home 目录下的一个配置文件 ~/.vuerc,你可以通过直接编辑这个文件夹来调整,添加,删除保存好的 preset。

    上面是 官方 preset 教程 给出的 preset 的定义和用途。其实就是一套针对你们企业所用到的一套脚手架,比如每个项目都有标准的典型页面布局和样式,一些通用方法(比如 numeral 处理千分位数字)、通用校验(比如 IPV4、IPV6校验)、通用多语言配置、通用样式(比如公司有针对不同多语言需要展示不同主题色,这种主题色配置、典型页面的 layout 布局)等等。

    自定义预设项目就是这样,路由信息可能是针对不同项目内容是不同的,但是上面这些通用内容可以像脚手架默认内容一样写在项目中,当你基于这个自定义预设项目来创建一个新项目时,新项目中就会自动带有这些配置,就不需要你手动再一条一条添加,或者从别的项目里一遍遍复制了。

    那如何自定义自己的 preset 项目呢?

    自定义预设

    创建默认预设

    vue create 项目名
    
    • 1

    这里 winpty vue.cmdvue 效果一样

    首先选择 Vue CLI 脚手架配置选项(同时作为自定义预设内容),并将其保存到本地,内容命名为 ws_vue2_preset,确认后去本地磁盘 C:\User\你的名字\.vuerc 查看

    请添加图片描述

    打开 .vuerc 文件,其中我们刚命名的预设名 ws_vue2_preset 所指向的内容就是我们需要的默认预设内容

    请添加图片描述

    创建预设项目

    创建预设项目

    • 创建文件夹 ws_vue2_preset
    • 创建预设文件 ws_vue2_preset/preset.json
    • 创建 ws_vue2_preset/generator/index.js 导出一个函数
    • 创建 ws_vue2_preset/prompts.js 交互式告知自定义设置的信息
    preset.json

    C:\User\你的名字\.vuerc 中的预设对象复制到 preset.json 文件中

    请添加图片描述

    prompts.js

    暂时不写内容设置为空

    module.exports = []
    
    • 1
    template预设模板

    将包含了你想加入到自定义预设的所有配置的项目内容复制到 template

    请添加图片描述

    需要注意的点:

    • public/index.html 模板中用到的 webpack 变量需要修改下语法糖
      请添加图片描述
    • 所有.xxx 文件需要改成 _xxx 文件
      请添加图片描述
    • 去除 node_modulespackage.json 文件
    • 项目中你不希望预设时复制的文件都可以去除,不放在 template
    generator.js

    在这里插入图片描述

    • api.extendPackage 里的内容就是你去除的那个 package.json 中的内容
    • api.render('./template') 指向的模板就是创建项目时会复制的内容

    本地预设创建项目

    此时预设项目已完成 ws_vue2_preset,测试是否可以通过这个预设来创建一个包含其内容的新项目。当前,当你开发一个远程 preset 时,也不需要频繁的向远程 repo 发出 push 进行反复测试。

    请添加图片描述

  • 相关阅读:
    PMP_第8章章节试题
    StringTable详解 串池 性能调优 字符串拼接
    C# Microsoft.Office.Interop.Word设置Word页脚之添加当前页数
    流(43)
    既生瑜,何生亮?
    设计模式之观察者模式
    uniapp微信小程序开发基于ali-oss直传文件上传解决方案
    Rocky Linux怎么安装mysql
    竞赛选题 深度学习 python opencv 火焰检测识别
    早安心语微语早读,好好善待自己,珍惜今天,期待明天
  • 原文地址:https://blog.csdn.net/weixin_43443341/article/details/134287925