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

宿州做企业网站公司怎么开一个网站平台

宿州做企业网站公司,怎么开一个网站平台,国内最大的几个手游加盟平台,晚上睡不着看b站正常吗在 Vue CLI 项目中进行构建优化,是前端性能提升的重要手段。它涉及到 Webpack 配置、代码分包、懒加载、依赖优化、图片压缩等多个方面。 🧱 基础构建优化 设置生产环境变量 NODE_ENVproduction Vue CLI 会自动在 npm run build 时开启以下优化&…

在 Vue CLI 项目中进行构建优化,是前端性能提升的重要手段。它涉及到 Webpack 配置、代码分包、懒加载、依赖优化、图片压缩等多个方面。

🧱 基础构建优化

设置生产环境变量

NODE_ENV=production

Vue CLI 会自动在 npm run build 时开启以下优化:

  • 压缩 JS / CSS
  • 移除 console 和 debugger
  • 自动分离 vendor 文件(依赖包)

开启 gzip 压缩

使用 compression-webpack-plugin:

npm install compression-webpack-plugin -D
// vue.config.js
const CompressionWebpackPlugin = require('compression-webpack-plugin')module.exports = {configureWebpack: {plugins: [new CompressionWebpackPlugin({algorithm: 'gzip',test: /\.(js|css|html|svg)$/,threshold: 10240,minRatio: 0.8})]}
}

去除 map 文件

module.exports = {productionSourceMap: false
}

📦 代码层优化

路由懒加载(代码分割)

const Home = () => import(‘@/views/Home.vue’)

打包时,每个路由页面都会单独分包。

使用 CDN 加载库文件

把 Vue、Vuex、Vue Router 等用 CDN 引入:

// vue.config.js
module.exports = {configureWebpack: {externals: {vue: 'Vue','vue-router': 'VueRouter',vuex: 'Vuex'}}
}

然后在 public/index.html 中引入 CDN:

<script src="https://cdn.jsdelivr.net/npm/vue@3/dist/vue.global.prod.js"></script>

Tree Shaking & 按需引入

避免全量引入组件库,例如:

// ❌ 错误
import ElementPlus from 'element-plus'
app.use(ElementPlus)// ✅ 推荐
import { ElButton, ElSelect } from 'element-plus'
app.use(ElButton).use(ElSelect)

🧠 Webpack 配置层优化(Vue CLI 内部使用 Webpack)

使用缓存

// vue.config.js
module.exports = {chainWebpack: config => {config.cache(true)}
}

分析包体积

npm install webpack-bundle-analyzer -D
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPluginmodule.exports = {configureWebpack: {plugins: [new BundleAnalyzerPlugin()]}
}

🖼 资源层优化

图片压缩

使用 image-webpack-loader:

npm install image-webpack-loader -D
module.exports = {chainWebpack: config => {config.module.rule('images').use('image-webpack-loader').loader('image-webpack-loader').options({mozjpeg: { progressive: true, quality: 65 },pngquant: { quality: [0.65, 0.90], speed: 4 }})}
}

图片懒加载

npm install vue-lazyload
import VueLazyload from 'vue-lazyload'
app.use(VueLazyload, { loading: 'loading.png' })

🧊 缓存优化(浏览器缓存策略)

文件名加 hash(默认支持)

Vue CLI 打包后文件名默认带有 [hash],有助于浏览器缓存:

app.234d7f.js

静态资源持久缓存(使用 CDN + Cache-Control)

在 nginx 或服务端配置:

Cache-Control: max-age=31536000

✅ 总结表格

优化项方法效果
路由懒加载import() 异步组件减少初始加载体积
CDN 加载依赖externals + script 标签减少 bundle 体积
gzip 压缩compression-webpack-plugin减少传输体积
移除 consoleterser 插件自动处理减少无用代码
图片压缩image-webpack-loader优化图片大小
分析构建webpack-bundle-analyzer找出最大依赖
map 文件移除productionSourceMap: false避免泄露源代码
资源缓存hash 文件名 + Cache-Control浏览器缓存优化

示例

以下是一个Vue CLI 项目中的完整优化配置文件 vue.config.js,包含以下功能:
• 关闭 source map
• 使用 CDN 外部引入 Vue、Vuex、Vue Router
• gzip 压缩
• 图片压缩
• 移除 console/debugger
• 打包分析器(可选)

✅ vue.config.js

const CompressionWebpackPlugin = require('compression-webpack-plugin')
const TerserPlugin = require('terser-webpack-plugin')
const isProd = process.env.NODE_ENV === 'production'module.exports = {productionSourceMap: false, // 关闭 source mapconfigureWebpack: config => {const plugins = []// gzip 压缩if (isProd) {plugins.push(new CompressionWebpackPlugin({algorithm: 'gzip',test: /\.(js|css|html|svg)$/,threshold: 10240,minRatio: 0.8}))}// CDN 依赖(在 index.html 中引入)config.externals = isProd? {vue: 'Vue','vue-router': 'VueRouter',vuex: 'Vuex'}: {}config.plugins = [...config.plugins, ...plugins]},chainWebpack: config => {// 图片压缩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 }})// 打包分析(按需启用)if (process.env.ANALYZE) {config.plugin('webpack-bundle-analyzer').use(require('webpack-bundle-analyzer').BundleAnalyzerPlugin)}},// 移除 console/debugger(可选)configureWebpack: config => {if (isProd) {config.optimization = {minimizer: [new TerserPlugin({terserOptions: {compress: {drop_console: true,drop_debugger: true}},extractComments: false})]}}}
}

✅ 还需要在 public/index.html 中引入 CDN(用于生产环境)

<!-- public/index.html -->
<head><title>Vue App</title><% if (process.env.NODE_ENV === 'production') { %><script src="https://cdn.jsdelivr.net/npm/vue@3/dist/vue.global.prod.js"></script><script src="https://cdn.jsdelivr.net/npm/vuex@4.1.0/dist/vuex.global.prod.js"></script><script src="https://cdn.jsdelivr.net/npm/vue-router@4.1.0/dist/vue-router.global.prod.js"></script><% } %>
</head>
http://www.dtcms.com/wzjs/256169.html

相关文章:

  • 除了Joomla用什么做网站好广州竞价托管
  • 网站开发工程师工作描述青岛网站制作
  • 做网站如何挑选服务器厦门seo外包服务
  • 网站建立于网页设计搜索关键词排名优化服务
  • 南阳做玉器网站软文营销策划
  • 网上作业网站怎么做的提交链接
  • 轻松学做网站seo是什么软件
  • 宜昌 医院 网站建设头条新闻 最新消息条
  • 住房和城乡建设厅官方网站网络营销推广的方式
  • 前端开发工程师招聘信息seo短期课程
  • 做法城乡建设部网站提高工作效率总结心得
  • 网站建设书凡科建站多少钱
  • 网站忘记备案百度本地推广
  • 天津建站模板网站发布
  • 我在学校志愿队做网站的经历潮州网站建设
  • 安阳建设网站游戏推广怎么做引流
  • 微信网站开发源代码重庆网站seo诊断
  • 东莞网站建设方案推广网站制作公司高端
  • 有没有做网站的软件友情链接检测结果
  • 张家港市凤凰镇建设局网站seo西安
  • 咪咪做网站短视频营销推广方式
  • java 框架用来做网站seo网络排名优化方法
  • 网页微信版官网登录密码登录uc浏览器关键词排名优化
  • 专门做卫生间效果图的网站网络营销策划步骤
  • 网站访客跟踪微信软文模板
  • 岳麓做网站的公司营销课程培训
  • dedecms蓝色企业网站模板免费下载产品软文范例
  • b站推广网站mmm换脸企业宣传方式有哪些
  • 制作一个自适应网站源码业务推广方式有哪些
  • 莱芜金点子最新招聘信息招聘网北京seo全网营销