webpack打包时使用import引入element,element地址信息不会被打包到budle中而axios就会呢?

Webpack 打包时,对于 import 引入的库(例如 element),其地址信息不会被打包到 bundle 中,这是因为库的地址信息是在运行时动态解析的,而不是在编译时确定的。

当你在代码中使用 import 引入一个库时,Webpack 会将其转换为一个动态的 require 语句,而这个 require 语句会在运行时解析并加载库的模块。因此,库的地址信息不会直接出现在最终的 bundle 中。

相比之下,Axios 是一个提供 HTTP 请求功能的库,它需要在编译时确定其地址信息,因为 HTTP 请求是发生在编译期间而不是运行期间的操作。因此,Axios 的地址信息会被打包到 bundle 中。

总结来说,Webpack 打包时是否将库的地址信息打包到 bundle 中,取决于库的使用方式和编译时的需求。对于运行时动态加载的库,其地址信息不会被打包到 bundle 中;而对于需要在编译时确定地址信息的库(如 Axios),其地址信息会被打包到 bundle 中。

那么webpack打包时如何引入将编译时的库的地址信息不被打包到bundle中??

方式一:在index.html中引入,webpack打包时排除axios打包

复制代码
<script src="https://unpkg.com/axios/dist/axios.min.js"></script>

externals: {
        'axios': 'axios'
    },

方式二:使用import方式引入axios,使用Webpack的alias配置选项来设置库的别名,这样在代码中就可以使用别名来引入模块,而不需要直接使用完整的路径。这样,即使库的地址信息在编译时被解析,也不会被打包到bundle中。

复制代码
import axios from 'axios'

resolve: {
        alias: {
            '@': resolve('src'),
            'axios': resolve('node_modules/axios/dist/axios.min.js'),
        }
    },
相关推荐
小杨升级打怪中1 小时前
前端面经-webpack篇--定义、配置、构建流程、 Loader、Tree Shaking、懒加载与预加载、代码分割、 Plugin 机制
前端·webpack·node.js
Dontla20 小时前
Webpack DefinePlugin插件介绍(允许在编译时创建JS全局常量,常量可以在源代码中直接使用)JS环境变量
运维·javascript·webpack
隐含1 天前
webpack打包,把png,jpg等文件按照在src目录结构下的存储方式打包出来。解决同一命名的图片资源在打包之后,重复命名的图片就剩下一个图片了。
前端·webpack·node.js
胡桃夹夹子1 天前
【前端优化】vue2 webpack4项目升级webpack5,大大提升运行速度
前端·javascript·vue.js·webpack·性能优化
GISer_Jing3 天前
编译原理AST&以Babel为例进行解读、Webpack中自定义loader与plugin
前端·webpack·node.js
GISer_Jing3 天前
Webpack中Compiler详解以及自定义loader和plugin详解
前端·webpack·node.js
cdcdhj4 天前
vue用通过npm的webpack打包编译,这样更适合灵活配置的项目
vue.js·webpack·npm
augenstern4165 天前
webpack重构优化
前端·webpack·重构
Dontla5 天前
何时需要import css文件?怎么知道需要导入哪些css文件?为什么webpack不提示CSS导入?(导入css导入规则、css导入规范)
前端·css·webpack
积极向上的龙6 天前
首屏优化,webpack插件用于给html中js自动添加异步加载属性
javascript·webpack·html