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'),
        }
    },
相关推荐
小明记账簿17 小时前
项目启功需要添加SKIP_PREFLIGHT_CHECK=true该怎么办?
webpack·打包
拉不动的猪1 天前
webpack编译中为什么不建议load替换ast中节点删除consolg.log
前端·javascript·webpack
PAQQ2 天前
ubuntu22.04 搭建 Opencv & C++ 环境
前端·webpack·node.js
老前端的功夫3 天前
Webpack打包机制与Babel转译原理深度解析
前端·javascript·vue.js·webpack·架构·前端框架·node.js
LYFlied4 天前
Webpack 深度解析:从原理到工程实践
前端·面试·webpack·vite·编译原理·打包·工程化
LYFlied4 天前
从循环依赖检查插件Circular Dependency Plugin源码详解Webpack生命周期以及插件开发
前端·webpack·node.js·编译原理·plugin插件开发
AI_56784 天前
前端工程化巅峰实践:Webpack5性能优化全攻略
webpack·tree shaking
一念之间lq5 天前
Elpis Webpack工程化·自我学习总结
webpack·前端工程化
LYFlied5 天前
浅谈前端构建工具核心理解&&主流工具对比
前端·webpack·软件构建·rollup·vite·开发工具·工程化
LYFlied5 天前
Webpack详细打包流程解析
前端·面试·webpack·node.js·打包·工程化