前端变化日新月异,层出不穷,公司原项目使用vuecil2版本开发,elementUI等一系列库版本太低,也脱离世界很久远了,新版本库需要webpack4等环境,而老版本配置起来bug很多,在使用过程中很多东西都不能实现,所以升级真的是迫在眉睫; 此篇会逐步解析: Vue CLI 的包名称由 vue-cli 改成了 @vue/cli。 如果你已经全局安装了旧版本的 vue-cli (1.x 或 2.> x),你需要先通过 npm uninstall vue-cli -g 或 yarn global remove vue-cli 卸载它。 Vue CLI3+ 需要 Node.js 8.9 或更高版本 (推荐 8.11.0+) vuecil3+和vuecil2的最大区别就在于内置了很多配置,没有了build文件夹和config的配置。但是在开发中,避免不了的还是需要个性化的配置,之前有写过ts+vue中的vue.config.js的配置文件,这里系统讲一下 vue.config.js的配置; 以上配置按需引用,常见的配置项都已经写出,其他特殊可参考vue-cil官网,有问题可以留言问我; vuecil3+关于环境变量的配置方式也发生的改变 这篇就主要讲vuecil3/4+的配置于之前的版本不同的地方。但路由,vuex用法并没有变化,所以我们项目升级的方法就是:新建了vuecil4.4的新版本项目,然后将src文件代码整体复制到新项目内,启动测试无误。 现版本在打包速度和启动时间上比旧版本优秀,但是改变并不是质的飞跃,升级的目的还是为了整体升级成webpack4+及其他插件的使用。 之后继续记录vue项目插件的升级及打包优化… over~有问题留言 如果本文对你有帮助的话,请不要忘记给我打call哦~o( ̄▽ ̄)do
前言
一、vuecil2如何升级到vuecil3+
卸载旧版本
node配置
全局安装包
npm install -g @vue/cli # OR yarn global add @vue/cli
创建一个项目
vue create vue-web-cil4
安装所需选择配置:可参考官方配置
二、vuecil3/vuecil4的配置语法
2.1 目录结构
├── README.md # 说明 |-- dist # 打包后文件夹 ├── babel.config.js # babel语法编译 ├── package-lock.json ├── public # 静态文件夹,这类资源将会直接被拷贝,而不会经过 webpack 的处理。 │ ├── favicon.ico │ └── index.html #入口页面 └── src # 源码目录 ├── App.vue - 页面 ├── assets - 静态目录,这类引用会被 webpack 处理。 │ └── logo.png ├── components 组件 │ └── HelloWorld.vue └── main.js # 入口文件,加载公共组件 │—— vue.config.js # 配置文件,需自行配置 │—— .gitignore # git忽略上传的文件格式 │—— babel.config.js # babel语法编译 │—— package.json # 项目基本信息 │—— .env # 环境变量和模式,需自行配置 │—— .eslintrc.js # ES-lint校验
2.2 vue.config.js 配置
// vue.config.js const path = require('path'); const resolve = (dir) => path.join(__dirname, dir); const CompressionWebpackPlugin = require("compression-webpack-plugin"); // 开启gzip压缩(可选) const productionGzipExtensions = /.(js|css|json|txt|html|ico|svg)(?.*)?$/i; // 开启gzip压缩(可选) const BundleAnalyzerPlugin = require("webpack-bundle-analyzer").BundleAnalyzerPlugin; // 打包分析,(可选) const IS_PRODUCTION = ['production', 'prod'].includes(process.env.NODE_ENV);//判断是否是生产环境 /** 正式配置项,以下参数 都是可选**/ module.exports = { publicPath: process.env.NODE_ENV === 'production' ? '/site/vue-demo/' : '/', // 打包公共路径 indexPath: 'index.html' , // 相对于打包路径index.html的路径 outputDir: process.env.outputDir || 'dist', // 'dist', 生产环境构建文件的目录 assetsDir: 'static', // 相对于outputDir的静态资源(js、css、img、fonts)目录 lintOnSave: false, // 是否在开发环境下通过 eslint-loader 在每次保存时 lint 代码,false不需要 runtimeCompiler: true, // 是否使用包含运行时编译器的 Vue 构建版本 productionSourceMap: !IS_PRODUCTION, // 生产环境的 source map, parallel: require("os").cpus().length > 1, // 是否为 Babel 或 TypeScript 使用 thread-loader。该选项在系统的 CPU 有多于一个内核时自动启用,仅作用于生产构建。 pwa: {}, // 向 PWA 插件传递选项。 chainWebpack: config => { config.resolve.symlinks(true); // 修复热更新失效 // 如果使用多页面打包,使用vue inspect --plugins查看html是否在结果数组中 config.plugin("html").tap(args => { // 修复 Lazy loading routes Error args[0].chunksSortMode = "none"; return args; }); config.resolve.alias // 添加别名 .set('@', resolve('src')) .set('@assets', resolve('src/assets')) .set('@components', resolve('src/components')) .set('@views', resolve('src/views')) .set('@store', resolve('src/store')); // 压缩图片 // 需要 npm i -D image-webpack-loader config.module .rule("images") .use("image-webpack-loader") .loader("image-webpack-loader") .options({ mozjpeg: { progressive: true, quality: 65 }, optipng: { enabled: false }, pngquant: { quality: [0.65, 0.9], speed: 4 }, gifsicle: { interlaced: false }, webp: { quality: 75 } }); // 打包分析, 打包之后自动生成一个名叫report.html文件(可忽视) if (IS_PRODUCTION) { config.plugin("webpack-report").use(BundleAnalyzerPlugin, [ { analyzerMode: "static" } ]); } }, //webpack的配置项 configureWebpack: config => { // 开启 gzip 压缩 // 需要 npm i -D compression-webpack-plugin const plugins = []; if (IS_PRODUCTION) { plugins.push( new CompressionWebpackPlugin({ filename: "[path].gz[query]", algorithm: "gzip", test: productionGzipExtensions, threshold: 10240, minRatio: 0.8 }) ); } config.plugins = [...config.plugins, ...plugins]; }, css: { extract: IS_PRODUCTION, requireModuleExtension: false,// 去掉文件名中的 .module loaderOptions: { // 给 less-loader 传递 Less.js 相关选项 less: { // `globalVars` 定义全局对象,可加入全局变量 globalVars: { primary: '#333' } } } }, devServer: { overlay: { // 让浏览器 overlay 同时显示警告和错误 warnings: true, errors: true }, host: "localhost", port: 8080, // 端口号 https: false, // https:{type:Boolean} open: false, //配置后自动启动浏览器 hotOnly: true, // 热更新 // proxy: 'https://localhost:8080' // 配置跨域处理,只有一个代理 proxy: { //配置多个跨域 "/api": { target: "https://197.0.0.1:8088", changeOrigin: true, ws: true,//websocket支持 secure: false, pathRewrite: { "^/api": "/" } }, "/api2": { target: "https://197.0.0.2:8088", changeOrigin: true, //ws: true,//websocket支持 secure: false, pathRewrite: { "^/api2": "/" } }, } } }
2.3 环境变量的配置
.env
.env.development
或.env.production
文件并书写相关键值对,此文件优先级大于.env
文件;VUE_APP_*
才会生效;
.env
文件配置及使用//.env VUE_APP_TITLE=MY VUE APP VUE_APP_NAME= JCAT_李小黑
console.log(process.env.VUE_APP_TITLE)//"MY VUE APP" console.log(process.env.VUE_APP_NAME) // "JCAT_李小黑"
三、vuecil3中的启动打包命令
3.1 package.json文件
"scripts": { "serve": "vue-cli-service serve", //启动 "build": "vue-cli-service build", //打包 "lint": "vue-cli-service lint" //eslint },
3.2 命令
//启动项目 npm run serve //打包项目 npm run build
3.3 更多命令配置
npm run serve
,可以配置继续使用npm run dev
来启动项目; "scripts": { "dev": "vue-cli-service serve", //启动 },
"scripts": { "serve": "vue-cli-service serve --host 0.0.0.0", //启动 },
小结
本网页所有视频内容由 imoviebox边看边下-网页视频下载, iurlBox网页地址收藏管理器 下载并得到。
ImovieBox网页视频下载器 下载地址: ImovieBox网页视频下载器-最新版本下载
本文章由: imapbox邮箱云存储,邮箱网盘,ImageBox 图片批量下载器,网页图片批量下载专家,网页图片批量下载器,获取到文章图片,imoviebox网页视频批量下载器,下载视频内容,为您提供.
阅读和此文章类似的: 全球云计算