首页 > 其他分享 >前端【打包相关的配置项】【项目打包后本地查看配置】【去掉打包后js的map文件】【生成打包报告】【替换组件js为cdn导入方式】

前端【打包相关的配置项】【项目打包后本地查看配置】【去掉打包后js的map文件】【生成打包报告】【替换组件js为cdn导入方式】

时间:2024-04-09 12:33:43浏览次数:24  
标签:map vue cli 文件 js echarts 打包

1、打包后会生成dist目录,里面的index.html双击打开是空白的,需要部署到服务器上才能看到项目内容,此时可以通过vue.config.js中配置一个参数,这样本地打包完就可以看到效果

  vue.config.js

1 const { defineConfig } = require('@vue/cli-service')
2 module.exports = defineConfig({
3   transpileDependencies: true,
4   // 允许打包的结果,以文件方式访问(允许双击打开)
5   publicPath: './'
6 })

2、打包之后dist目录下,js目录会存放项目用到的js文件,但是会发现存在很多xxx.map的文件(用于映射js文件与原始js的内容),想要打包的时候去掉这些文件,也在vue.config.js中配置

1 const { defineConfig } = require('@vue/cli-service')
2 module.exports = defineConfig({
3   transpileDependencies: true,
4   // 允许打包的结果,以文件方式访问(允许双击打开)
5   publicPath: './',
6   // 去掉map文件
7   productionSourceMap: false,
8 })

 3、分析项目的打包哪些文件占用大小

  在package.json文件中,执行脚本中添加--report,例如下面的配置,执行pnpm run build打包的时候,就会在项目目录下生成report.html报告文件

 1 {
 2   "name": "mj-pc",
 3   "version": "0.1.0",
 4   "private": true,
 5   "scripts": {
 6     "serve": "vue-cli-service serve",
 7     "build": "vue-cli-service build --report",
 8     "lint": "vue-cli-service lint"
 9   },
10   "dependencies": {
11     "axios": "^1.4.0",
12     "core-js": "^3.8.3",
13     "echarts": "^5.4.3",
14     "element-ui": "^2.15.13",
15     "vue": "^2.6.14",
16     "vue-quill-editor": "^3.0.6",
17     "vue-router": "^3.5.1",
18     "vuex": "^3.6.2"
19   },
20   "devDependencies": {
21     "@babel/core": "^7.12.16",
22     "@babel/eslint-parser": "^7.12.16",
23     "@vue/cli-plugin-babel": "~5.0.0",
24     "@vue/cli-plugin-eslint": "~5.0.0",
25     "@vue/cli-plugin-router": "~5.0.0",
26     "@vue/cli-plugin-vuex": "~5.0.0",
27     "@vue/cli-service": "~5.0.0",
28     "@vue/eslint-config-standard": "^6.1.0",
29     "eslint": "^7.32.0",
30     "eslint-plugin-import": "^2.25.3",
31     "eslint-plugin-node": "^11.1.0",
32     "eslint-plugin-promise": "^5.1.0",
33     "eslint-plugin-vue": "^8.0.3",
34     "sass": "^1.32.7",
35     "sass-loader": "^12.0.0",
36     "vue-template-compiler": "^2.6.14"
37   }
38 }

4、由于某些包打包之后比较大,不将这些组件打包到项目中,使用对应的CDN导入这些组件

  1、去哪里找第三方包:

    https://www.jsdelivr.com/     -->      <script src="https://cdn.jsdelivr.net/npm/echarts@5.5.0/dist/echarts.min.js"></script>    -->  网站有对应搜索框搜索组件

    https://unpkg.com/               -->     引入方式:unpkg.com/:package@:version/:file     -->  网站搜索方式,   https://unpkg.com/axios 回车    (网站域名后拼接要查找的组件名)    

  2、例如echarts查找地址:https://www.jsdelivr.com/package/npm/echarts

  3、替换项目中的引入

    例如之前导入echarts

1 import * as echarts from 'echarts'

    在入口文件public/index.html文件中,使用CDN导入

1 <script src="https://cdn.jsdelivr.net/npm/echarts@5.5.0/dist/echarts.min.js"></script>

  4、项目中大部分能换成cdn的全都换成了cdn方式

 1 <!DOCTYPE html>
 2 <html lang="">
 3   <head>
 4     <meta charset="utf-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width,initial-scale=1.0">
 7     <link rel="icon" href="<%= BASE_URL %>favicon.ico">
 8     <title><%= htmlWebpackPlugin.options.title %></title>
 9     <link rel="stylesheet" href="https://unpkg.com/element-ui@2.15.9/lib/theme-chalk/index.css">
10     <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/quill@1.3.7/dist/quill.core.css">
11     <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/quill@1.3.7/dist/quill.snow.css">
12     <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/quill@1.3.7/dist/quill.bubble.css">
13   </head>
14   <body>
15     <noscript>
16       <strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
17     </noscript>
18     <div id="app"></div>
19     <!-- built files will be auto injected -->
20     <!-- 引入网络当中的echarts -->
22     <script src="https://unpkg.com/vue@2.6/dist/vue.min.js"></script>
23     <script src="https://unpkg.com/vue-router@3.5.4/dist/vue-router.js"></script>
24     <script src="https://unpkg.com/axios@0.27.2/dist/axios.min.js"></script>
25     <script src="https://unpkg.com/vuex@3.6.2/dist/vuex.js"></script>
26     <script src="https://unpkg.com/element-ui@2.15.9/lib/index.js"></script>
27     <script src="https://unpkg.com/echarts@5.4.3/dist/echarts.js"></script>
28     <script src="https://unpkg.com/quill@1.3.7/dist/quill.js"></script>
29     <script src="https://unpkg.com/vue-quill-editor@3.0.6/dist/vue-quill-editor.js"></script>
30   </body>
31 </html>

  5、当使用了网络资源引入方式,则项目打包的时候要排除这些组件,不打包这些组件,需要在vue.config.js中配置排除这些组件

 1 const { defineConfig } = require('@vue/cli-service')
 2 module.exports = defineConfig({
 3   transpileDependencies: true,
 4   // 允许打包的结果,以文件方式访问(允许双击打开)
 5   publicPath: './',
 6   // 去掉map文件
 7   productionSourceMap: false,
 8   // 打包时,排除哪些组件
 9   configureWebpack: {
10     externals: {
11       // 键(包名): '引入echarts.js后,window中多了什么'
12       axios: 'axios',
13       vue: 'Vue',
14       'vue-router': 'VueRouter',
15       vuex: 'Vuex',
16       echarts: 'echarts',
17       'element-ui': 'ELEMENT',
18       'vue-quill-editor': 'VueQuillEditor'
19     }
20   }
21 })

 

标签:map,vue,cli,文件,js,echarts,打包
From: https://www.cnblogs.com/wang1001/p/18123676

相关文章

  • Elasticsearch之-mapping 映射管理
    目录Elasticsearch之-mapping映射管理一、映射介绍1.1字段数据类型1.2映射参数二、创建索引时指定映射2.16.x的版本写法2.27.x版本以后2.3插入数据测试三、查看索引Elasticsearch之-mapping映射管理在Elasticsearch6.0.0或更高版本中创建的索引只包含一个mappingtype......
  • CEF编译报错:ValueError: path is on mount '\\\\tab_group_types.mojom-webui.js'
    F:\code\chromium_git\chromium\src>autoninja-Cout\Debug_GN_x64cef"f:\code\depot_tools\bootstrap-2@3_11_6_chromium_30_bin\python3\bin\python3.exe"F:\code\depot_tools\ninja.py-Cout\Debug_GN_x64cef-j10ninja:Enteringdirec......
  • 在Linux中,什么是端口扫描?如何使用工具如nmap进行端口扫描?
    在Linux中,端口扫描是一种网络诊断和安全审计技术,通过该技术可以发现远程或本地主机上运行的服务及其所使用的网络端口的状态。端口扫描器发送特定类型的网络数据包到目标主机的不同端口号,根据返回的响应判断端口是否开放、关闭或被防火墙屏蔽。端口扫描可以帮助系统管理员检查自......
  • 【DVWA】20. SQL Injection (Blind)SQL注入盲注(全等级Sqlmap版)
    文章目录0.盲注介绍0.1布尔盲注0.2时间盲注0.3常用函数if()length()substr()、substring()ascii()、ord()1.Low1.1源码分析1.2实操2.Medium2.1源码分析2.2实操3.High3.1源码分析3.2实操4.Impossible4.1源码分析0.盲注介绍盲注,有两种主要类型,包......
  • JS数组方法
    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录@[TOC](文章目录)一、改变数组内容的方法1、push():向数组的末尾添加一个或多个元素,并返回新的长度。2、pop():删除并返回数组的最后一个元素。3、shift():删除并返回数组的第一个元素。4、un......
  • 免费开源多客全新4.0版本圈子校园社交论坛系统,可打包小程序,于TP6+uni-app全开源,可打包
    校园跑腿服务的好处与优势+Vff06020161.提供便捷的生活服务校园跑腿服务通过线上平台与线下服务人员结合,为学生提供一站式的生活服务,包括代购、快递、送餐等,方便学生处理日常小事。这项服务不仅节省了学生的时间,还大大减轻了他们的负担,使他们能够更好地专注于学习和个人发展......
  • 基于SpringBoot+MySQL+SSM+Vue.js的生鲜在线销售系统(附论文)
    演示视频基于SpringBoot+MySQL+SSM+Vue.js的生鲜在线销售系统技术描述开发工具:Idea/Eclipse数据库:MySQLJar包仓库:Maven前端框架:Vue/ElementUI后端框架:Spring+SpringMVC+Mybatis+SpringBoot文字描述基于SpringBoot+MySQL+SSM+Vue.js的生鲜在线销售系统(附......
  • 用vue.js写案例——ToDoList待办事项 (步骤和全码解析)
     目录 一.准备工作二.编写各个组件的页面结构三.实现初始任务列表的渲染四.新增任务五.删除任务六.展示未完成条数七.切换状态-筛选数据八.待办事项(全)代码 一.准备工作在开发“ToDoList”案例之前,需要先完成一些准备工作,包括创建项目、引入BootStrap样式文......
  • Node.js毕业设计基于的校园闲置交易分享平台(Express+附源码)
    本系统(程序+源码)带文档lw万字以上  文末可获取本课题的源码和程序系统程序文件列表系统的选题背景和意义选题背景:随着互联网技术的飞速发展,人们的生活方式发生了翻天覆地的变化,特别是在校园环境中,学生们的生活节奏加快,学习压力增大。在这样的背景下,校园内产生的闲置物品......
  • 基于SpringBoot+MySQL+SSM+Vue.js的招聘系统(附论文)
    演示视频基于SpringBoot+MySQL+SSM+Vue.js的招聘系统技术描述开发工具:Idea/Eclipse数据库:MySQLJar包仓库:Maven前端框架:Vue/ElementUI后端框架:Spring+SpringMVC+Mybatis+SpringBoot文字描述基于SpringBoot+MySQL+SSM+Vue.js的招聘系统(附论文),用户,管理员......