webpack学习笔记之代码分割和按需加载的实例详解


Posted in Javascript onJuly 20, 2017

本文介绍了webpack学习笔记之代码分割和按需加载的实例详解,分享给大家,也给自己留个笔记

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

代码分割就是我们根据实际业务需求将代码进行分割,然后在合适的时候在将其加载进入文档中。

举个简单的例子:

1.一个HTML中存在一个按钮

2.点击按钮出现一个包着图片的div

3.点击关闭按钮图片消失

Demo目录:

webpack学习笔记之代码分割和按需加载的实例详解

一.当未点击按钮时浏览器只加载了对入口文件打包后的js

webpack学习笔记之代码分割和按需加载的实例详解

二.点击按钮会对组件进行异步加载

webpack学习笔记之代码分割和按需加载的实例详解

这个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。

webpack学习笔记之代码分割和按需加载的实例详解 

?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定义的第三个参数

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Prototype Selector对象学习
Jul 23 Javascript
jQuery下通过$.browser来判断浏览器.
Apr 05 Javascript
javascript实现促销倒计时+fixed固定在底部
Sep 18 Javascript
JavaScript动态创建div属性和样式示例代码
Oct 09 Javascript
多引号嵌套的变量命名的问题
May 09 Javascript
js代码实现的加入收藏效果并兼容主流浏览器
Jun 23 Javascript
js控制TR的显示隐藏
Mar 04 Javascript
jQuery中iframe的操作(点击按钮新增窗口)
Apr 20 Javascript
JavaScript中String对象的方法介绍
Jan 04 Javascript
react-router4 配合webpack require.ensure 实现异步加载的示例
Jan 18 Javascript
koa+jwt实现token验证与刷新功能
May 30 Javascript
解决vant中 tab栏遇到的坑 van-tabs
Nov 04 Javascript
node+vue实现用户注册和头像上传的实例代码
Jul 20 #Javascript
深入探究AngularJs之$scope对象(作用域)
Jul 20 #Javascript
通过命令行创建vue项目的方法
Jul 20 #Javascript
基于BootStrap实现简洁注册界面
Jul 20 #Javascript
AngularJS实现的JSONP跨域访问数据传输功能详解
Jul 20 #Javascript
深入探究node之Transform
Jul 20 #Javascript
微信小程序“摇一摇”的实例代码
Jul 20 #Javascript
You might like
php 正则表达式小结
2009/08/31 PHP
PHP中操作ini配置文件的方法
2013/04/25 PHP
destoon首页调用求购供应信息的地区名称的方法
2014/08/21 PHP
使用php从身份证号中获取一系列线索(星座、生肖、生日等)
2016/05/11 PHP
mysqli扩展无法在PHP7下升级问题的解决
2019/09/10 PHP
jQuery ready函数滥用分析
2011/02/16 Javascript
javascript模版引擎-tmpl的bug修复与性能优化分析
2011/10/23 Javascript
使用JavaScript脚本无法直接改变Asp.net中Checkbox控件的Enable属性的解决方法
2015/09/16 Javascript
JavaScript设计模式开发中组合模式的使用教程
2016/05/18 Javascript
基于ES6作用域和解构赋值详解
2017/11/03 Javascript
Vue项目使用CDN优化首屏加载问题
2018/04/01 Javascript
详解微信小程序-获取用户session_key,openid,unionid - 后端为nodejs
2019/04/29 NodeJs
js实现随机数小游戏
2019/06/28 Javascript
原生js实现碰撞检测
2020/03/12 Javascript
RxJS在TypeScript中的简单使用详解
2020/04/13 Javascript
[01:16:01]VGJ.S vs Mski Supermajor小组赛C组 BO3 第一场 6.3
2018/06/04 DOTA
使用Python3中的gettext模块翻译Python源码以支持多语言
2015/03/31 Python
python计算时间差的方法
2015/05/20 Python
Python将阿拉伯数字转换为罗马数字的方法
2015/07/10 Python
Python实战购物车项目的实现参考
2019/02/20 Python
基于PyQt4和PySide实现输入对话框效果
2019/02/27 Python
Python字符串和正则表达式中的反斜杠('\')问题详解
2019/09/03 Python
python字符串替换re.sub()实例解析
2020/02/09 Python
Python requests设置代理的方法步骤
2020/02/23 Python
python IDLE添加行号显示教程
2020/04/25 Python
美国著名手表网站:Timepiece
2017/11/15 全球购物
台湾家适得:Homeget
2019/02/11 全球购物
计算机毕业大学生推荐信
2013/12/01 职场文书
学生党员思想汇报
2013/12/28 职场文书
《陈毅探母》教学反思
2014/05/01 职场文书
省级优秀毕业生主要事迹
2014/05/29 职场文书
小学班主任培训方案
2014/06/04 职场文书
2014广电局实施党的群众路线教育实践活动方案思想汇报
2014/09/22 职场文书
营销与策划实训报告
2014/11/05 职场文书
关于感恩的作文
2019/08/26 职场文书
Nginx优化服务之网页压缩的实现方法
2021/03/31 Servers