webpack学习笔记(代码分割,按需加载)

为什么需要代码分割和按需加载

代码分割就是我们根据实际业务需求将代码进行分割,然后在合适的时候在将其加载进入文档中。
举个简单的例子:
1.一个HTML中存在一个按钮
2.点击按钮出现一个包着图片的div
3.点击关闭按钮图片消失

Demo目录:
这里写图片描述

一.当未点击按钮时浏览器只加载了对入口文件打包后的JS
这里写图片描述

二.点击按钮会对组件进行异步加载
这里写图片描述
这个clichunk就是我们打包好的click组件,包括相应的JS逻辑html和css

例子源码记录

1.编辑入口文件

window.onload=function(){
         var _cs=require('./index.css');
         var $=require('jquery');

         $('#_click').on('click',function(){
              require.ensure([],function(require){
                  var _click=require('./_clickWindow.js');
                  if(!_clickEvent){
                      console.log(_click);
                      var _clickEvent=_click._clicks;
                  }
                  new _clickEvent();
              },'cli')
         });
};

webpack将一切视为模块,CSS,js,html,JSX等等。

 var _cs=require('./index.css');

引入对应的css模块。这就需要我们安装css-loder和style-loader。

这里写图片描述
–save -dev的目的是为了在package.json文件的devDependencies写入依赖项。

点击按钮时,加载定义好的组件,当加载完成后执行组件里的方法。

首先要学习require.ensure方法:
在commonjs中有一个Modules/Async/A规范,里面定义了require.ensure语法。webpack实现了它,作用是可以在打包的时候进行代码分片,并异步加载分片后的代码。用法如下:

require.ensure([], function(require){
    var list = require('./list');
    list.show();
});

中括号内写入依赖项

此时list.js会被打包成一个单独的chunk文件,大概长这样:

1.fb874860b35831bc96a8.js。

可读性比较差,此时就需要加入第三个参数

require.ensure([], function(require){
    var list = require('./list');
    list.show();
}, 'list');

此时打包后的js文件名为

list.fb874860b35831bc96a8.js

也可以传入像”question/list”这样带层级的名字,这样webpack会按照层级给你创建文件夹。

require.ensure([], function(require){
    var list = require('./list');
    list.show();
    var edit = require('./edit');
    edit.display();
}, 'list_and_edit');

同时引入两个文件,webpack会将这两个文件和写入的依赖项打包在一起,如果你不希望打包在一起,只能写两require.ensure分别引用这两个文件。

require.ensure([‘./a.js’], function(require){
    var list = require('./list');
    list.show();
});

require.ensure([‘./a.js’], function(require){
    var b = require('./b');
    b.show();
});

如果list和b同时以来a.js那么在打包时a.js会被重复打包两次,如果想解决这样的问题,那么

require.ensure([‘./a.js’], function(require){
    var list = require('./list');
    list.show();
},'list-b');

require.ensure([‘./a.js’], function(require){
    var b = require('./b');
    b.show();
},'list-b');

此时这三个文件就会被打包在一起。

2.组件js

(function(){
   var _html=require('./_clickHtml.html');
   var $=require('jquery');

   function ClickWindow(){
      this.div=$('body').append(_html);
      $('#_tip').append('<img src="./timg.jpg">');
      this.init();
   }
   ClickWindow.prototype.init=function(){
      $('#_tip').append('<button>关闭</button>')
          .on('click',function(){ $('img').animate({'width':0},300); });
   };

   module.exports._clicks=ClickWindow;
})();

引入写好的html同上需要下载html-loader

3.配置文件

var path=require('path');
module.exports={
  entry:__dirname+'/index.js',
  output:{
      path: __dirname,
      filename:'[name]bundle.js',
      chunkFilename:'[name]chunk.js'
  },
    module: {
           loaders: [    //加载器
             {test: /\.css$/, loader: "style!css" },
              {test: /\.html$/, loader: "html" },
             {test: /\.(png|jpg)$/, loader: 'url-loader?limit=8192'}
           ]
    }
};

filename:’[name]bundle.js’,

[name]指向入口文件的name

chunkFilename:’[name]chunk.js’

[name]指向require.ensure定义的第三个参数


demo源码:git@github.com:zhtzjz/webpack-.git

*最后,希望自己写笔记的习惯可以坚持下来。*

  • 2
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Webpack可以通过代码分割来将应用程序的代码拆分成更小的块,以便在要时按加载。这有助于减小初始的加载时间,并提高应用程序的性能。下面是一些常用的代码分割方法: 1. 使用动态导入(Dynamic Import):动态导入是一种在运行时按加载代码块的方法。你可以使用import()函数来实现动态导入。例如,你可以在React组件中使用动态导入来按加载代码块。例如: ```javascript import('./module').then(module => { // 使用导入的模块 }); ``` 2. 使用webpack的splitChunks配置项:Webpack 4及以上版本提供了一个名为splitChunks的配置项,可用于自动代码分割。你可以在webpack配置文件的optimization选项中配置splitChunks来实现代码分割。例如: ```javascript optimization: { splitChunks: { chunks: 'all' } } ``` 上述配置将会根据一些默认策略将代码拆分成多个块。你也可以根据要自定义splitChunks的配置,例如指定拆分的最小块大小、最小引用次数等。 3. 使用webpack的动态导入和splitChunks的结合:你还可以将动态导入与splitChunks配置项结合使用,以更精细地控制代码分割。例如,你可以使用动态导入来按加载某个模块,同时使用splitChunks配置项来将该模块提取为一个单独的代码块。例如: ```javascript import(/* webpackChunkName: "module" */ './module').then(module => { // 使用导入的模块 }); ``` 并在webpack配置中配置splitChunks: ```javascript optimization: { splitChunks: { cacheGroups: { module: { chunks: 'async', name: 'module', test: /[\\/]module

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值