webpack 基本配置

大纲:
1、webpack 是什么,为什么需要webpack
2、模块化
3、webpack的基本配置

webpack是什么

我们先引入一段官网的解释

本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler)。当 webpack 处理应用程序时,它会递归地构建一个依赖关系图(dependency graph),其中包含应用程序需要的每个模块,然后将所有这些模块打包成一个或多个 bundle。

理解一下,那就是 webpack 是一个打包模块化 JavaScript 程序的工具。webpack 处理应用程序时,会从配置的入口文件开始,识别出模块化导入语句,然后递归找出入口文件的所有模块依赖,将这些依赖统统打包进一个或多个独立文件中(即bundle文件)。

为什么需要模块化打包工具

那么我们为什么要使用它,模块化究竟有什么好处呢?试想一下,在没有模块化之前,代码是怎么样的呢?

  • 变量和方法容易造成全局污染,不容易维护
  • 通过script标签从上自下加载资源
  • 大型项目资源难以维护,多人协作容易造成混乱

我们都知道,在HTML中,可以通过script标签引入js资源。script标签自上而下的加载执行,当然,如果设置了defer 和 async 属性的话,那就另当别论了。但不难看出,js的执行顺序至关重要,资源加载的先后顺序决定了你的项目是否能够成功运行下去。当项目越来越大,逻辑越来越复杂时,就会让维护变得困难和混乱起来,全局污染的可能性就大的多了。

形成独立作用域

在早期,我们通过命名空间的方法,尽量减少全局变量的产生:

// 使用对象字面量的形式形成命名空间
var Lily = {
        name: 'Lily',
        age: 20,
        hello: function() {
            console.log('My name is ' + this.name);
        }
    };

var Tom = {
        name: 'Tom',
        age: 20,
        hello: function() {
            console.log('My name is ' + this.name);
        }
    };

虽然命名空间能够在一定程度上减少全局变量的产生,但它存在另外一个问题。我们很容易就能够对 Lily 和 Tom 的姓名和年龄进行更改,但实际我们只希望暴露 hello 方法,而不希望基础属性被修改。那么我们怎么进行属性私有化呢?

那就是IIFE 立即执行函数,它会形

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值