Vue前端进行打包的具体操作过程是什么
Admin 2022-07-07 群英技术资讯 503 次浏览
package.json
中添加配置
npm run build
发布到线上的代码 不便于调试
命令:
"build:dev": "vue-cli-service build --mode dev", "build:prod": "vue-cli-service build --mode prod"
不可直接双击dist/index.html
需要放在http容器中运行:
serve tomcat nginx iis
本次使用
serve
下载serve: npm i -g serve
报错:
Error: EPERM: operation not permitted, mkdir ‘C:\Program Files\nodejs\node global\node_modules.staging'
解决: 用户—>个人用户—>删除.npmrc
文件
启动打包后的目录: serve dist
添加环境变量:
.env.dev
文件(与package.json中mode对应).env.prod
文件(与package.json中mode对应)在需要动态指定变量的位置使用process.env.NODE_ENV
等
// .env.dev ##开发环境 NODE_ENV=development ##变量以VUE_APP_开头 VUE_APP_URL=http://www.dev.com // .env.prod ##生产环境 NODE_ENV=production VUE_APP_URL=http://www.prod.com
vuecli
是基于webpack
vue.config.js
npm run build:prod
少了注释、空行、压缩等
代码细分:
vue elementui axios
等移出三方包: 使用三方提供cdn
(免费、收费)
步骤:
cdn
资源,添加到public/index.html
import
导入的删除vue.config.js
配置排除三方包module.exports = { // 打开文件访问的相对路径 独立项目 通过项目根目录访问 publicPath: './', // 开发时需要 线上不需要 map-->提供代码映射 方便调试代码 productionSourceMap: process.env.NODE_ENV == 'development' ? true: false, // 配置webpack configureWebpack: config =>{ // config---vuecli默认配置 Object.assign(config, { // 排除依赖包 externals: { vue: 'Vue' } }) }, }
下载 npm i -D compression-webpack-plugin
ERROR TypeError: Cannot read property ‘tapPromise' of undefined
TypeError: Cannot read property ‘tapPromise' of undefined错误原因: 脚手架配置gzip打包不支持这个版本
解决: 使用npm install compression-webpack-plugin@6.1.1 --save-dev
在vue.config.js配置
打包会生成gz结尾的文件:
let CompressionWebpackPlugin = require('compression-webpack-plugin') configureWebpack: config =>{ let plugins = [ new CompressionWebpackPlugin({ // 压缩方式 algorithm: 'gzip', // 匹配压缩文件 test: /\.js$|\.css$/, // 对于大于10k压缩 threshold: 10240 }) ] if(process.env.NODE_ENV == 'production') { config.mode = "production" config.plugins = [...config.plugins, ...plugins] } else { config.mode = 'development' } },
浏览器查看:
Accept-Encoding: gzip, deflate, br
Content-Encoding: gzip
打包部署模式:
hash: 打包后dist直接在http容器中运行 线上一致
history: 打包后脚手架刷新不会404 线上会404
解决方案:需要前端代码与后端一起部署 由后端负责跳转前端
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
用jQuery怎样验证输入是不是数字?在登录注册页面,我们通常需要对输入验证,那么我们怎样知道输入的是不是数字呢?下文给大家分享一个简单的验证数字示例,有一定参考价值,需要的朋友可以参考看看。
React是用于构建用户界面的JavaScript库,本文主要介绍了如何创建自己的第一个React页面,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
这篇文章给大家分享的是React请求远程数据的相关内容,React中请求远程数据的方式有四种,具体怎样实现呢?文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
这篇文章主要为大家介绍了前端JavaScript算法找出只出现一次的数字的算法示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
本文介绍了 基于 XMLHttpRequest、Promise、async/await 等三种异步网络请求 的写法,其中 async/await 写法允许我们以类似于同步的方式编写异步程序,摆脱繁琐的回调函数。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008