html如何打包文件发送,手把手教你webpack如何打包才能输出最优生产文件

前言

webpack打包大多数前端工程师们都已经用过,然后今天我想和大家分享的是webpack如何打包才能输出最优生产环境文件,主要针对两种人群:未自己手把手配置过webpack的人、配置过webpack但是不熟悉或者不知所以然的的人。如果fe大神看到请勿略此文,谢谢!

准备工作

在做讲解之前,我希望大家先去我的github上clone下我的demo项目,然后按照我的讲解亲自code一边!

最基本的打包构建

这是项目目录结构:

squares.svg

ps:先来看下最简单的打包,这边为了模拟打包文件大点,index.js引入了一些用不到的模块,然后webpack只做了最简单的js压缩处理。

//index.js

import React from 'react';

import { render } from 'react-dom';

import { Router, Route, IndexRoute, hashHistory } from 'react-router';

import Redux from 'redux';

import reactRedux from 'react-redux';

import App from './app/App';

import antd from 'antd';

import 'antd/dist/antd.min.css';

import './assets/common.scss';

import './index.scss';

render(, document.getElementById("app"));

//webpack

....

plugins: [

new webpack.optimize.UglifyJsPlugin({

output: {

comments: false

},

compress: {

warnings: false

}

})]

在webpack刚出来的时候,大多数人使用webpack其实和用grunt、gulp一样,把项目中的引用到的模块、样式文件等都打包成一个js文件。这样做的缺点:项目越庞大,打包出来的js文件越大,打包时间越长,最关键的是在单页面应用当中,会很大程度加大首屏加载时间,用户体验不好

squares.svg

上图可以看出打包时间7s左右,一个app.js文件达到352kb。然后这边还不包括antd.min.css(大概400kb antd-ui框架样式),你要想这仅仅是我这边只加了react开发需要用的一些基本模块,业务逻辑和业务css样式基本没有的情况下的数据。实际项目这个数据肯定还要来的大得多。

开始优化

首先我们考虑的是单个文件过大,拆分成多个打包。

css与js分离

把一个超大文件,先按js和css拆分成两个文件,然后页面并行加载这两文件肯定比加载一个文件来的快的,然后文件体积大小肯定也是有所缩小的。

extract-text-web

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值