如何使用webpack打包前端项目

webpack概述

随着前端体积越来越大,功能越来越丰富,这时候就需要将前端工程化,而

webpack就是用于将前端各种文件打包起来。

一个简单的webpack应该包含以下几个概念

· 入口起点

· 输出

· 配置

· 组件

· 加载器

· 插件

· 模块

· 模块热替换

下面我们一步步的搭建webpack,逐步讲解上诉模块

开发环境

推荐使用JetBrain的Webstorm,有强大的代码提示,支持JSX和ES6语法;

我们将会使用npm来下载和构建依赖,现在网上也有很多人使用yarn来安装,不过没关系,两者都是工具,npm已经够用;

需要提前安装node.js,下载地址https://nodejs.org/en/download/,我这里下载的是node-v6.9.2-x64.msi,一路默认安装即可;

安装完成之后,打开CMD命令行,分别输入node -v和npm -v,两者都能看见版本号即表示安装成功

项目结构

首先,webpack处理流程是entry=> rules(loaders)=> webpack=> output

entry是入口,rules或者loaders是加载器,webpack打包,output输出

下面我们来一步步的执行上诉流程

使用Webstorm新建一个新项目,命名为demo1,

我们先手动建立输出目录文件夹build和并在build文件夹下建立输出文件index.html(最终要呈现的页面文件)

在index.html中添加代码如下

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>demo1</title>
</head>
<body>
</body>
</html>

接下来我们将package.json和webpack安装到我们新建的项目中去

创建package.json文件

package.json是一个标准的npm说明文件,里面蕴含了丰富的信息,包括当前项目的依赖模块,自定义的脚本任务等;
打开cmd命令行,使用cd命令切换到你创建demo1目录下,然后输入

npm init -yes

可以自动创建package.json文件
切换到项目文件夹即可看到package.json文件创建完成

安装webpack

接下来我们需要在本项目中安装webpack作为依赖包,写入项目的package.json文件中

npm install --save-dev webpack

--save-dev是nodejs的一条命令,用于将npm安装的webpack各种依赖信息(dev)保存到(save)到package.json中去

查看项目,出现node_modules文件夹即表示安装成功

node_modules我们可以模糊理解为sdk中的库文件,我们后续用的babel、browserify、require等在该文件夹中都能知道其定义,我们也可以自定义第三方包放在改目录下供我们程序使用

安装好package.json和webpack之后,我们开始搭建我们需要的工程

上述三个步骤后,我们应该出现上图所示工程

创建webpack.config.js

下面,我们上述安装的webpack和建立的demo1工程关联起来
建立src,在其新建文件hello.js,并写入代码

module.exports = function() {
    var hello = document.createElement(‘div‘);
    hello.textContent = "Hi everybody!";
    return hello;
};

新建src/main.js,写入代码

var hello = require(‘./hello.js‘);
document.getElementById(‘content‘).appendChild(hello());

修改index.html代码

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>demo1</title>
</head>
<body>
<!--要插入React组件的位置-->
<div id="content"></div>
<!--引入bundle.js-->
<script src="bundle.js"></script>
</body>
</html>

在项目的根目录下新建webpack.config.js文件,webpack.config.js是webpack的配置文件,与package.json不同是,它是给webpack用的
webpack.config.js代码如下:

//__dirname是node.js中的一个全局变量,它指向当前执行脚本所在的目录
module.exports = {//注意这里是exports不是export
    entry: __dirname + "/src/main.js",//唯一入口文件
    output: {//输出目录
        path: __dirname + ‘/build‘,//打包后的js文件存放的地方
        filename: ‘bundle.js‘//打包后输出的js的文件名
    },
};

bundle.js是src文件夹下的文件经webpack打包后最终生成的供浏览器解析的js文件,这个不需要手动进行配置,甚至你不需要新建它,由webpack自动生成,后续我们会讲解它;

项目打包

这时候已经可以使用webpack进行打包了

在命令行下输入webpack执行打包(这里我们已经切换到项目目录,故可以直接使用webpack)

webpack

看到以上提示说明打包成功了,可以看到build目录下的自动生成了bundle.js,并且多了很多自动生成的代码。

直接双击打开index.html,可以看到,我们在hello.js里写的代码已经显示到页面上了

这里,可以理解为index.html是一个页面,main.js是一个装载器,hello.js是一个组件,通过main将hello组件装载到index页面中

至此,一个最简单的webpack工程已经打包好了,下面我们逐渐丰富webpack的配置

安装并启用webpack-dev-server

我们可以使用webpack-dev-server来搭建本地开发服务器,

文件修改能被监听,并自动刷新浏览器,即模块热替换功能

现在我们需要启动模块热替换,我们先安装webpack-devserver

npm install --save-dev webpack-dev-server

打开文件package.json,发现devDependencies依赖中多了webpack-dev-server配置,即表示安装成功
使用webpack-dev-server后,我们在package.json的scripts中添加如下代码

"scripts": {
  "build": "webpack",
  "dev": "webpack-dev-server"
}

并且且在index.html里加入:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>ReactDemo1</title>
</head>
<body>
<!--要插入React组件的位置-->
<div id="content"></div>
<!--引入bundle.js-->
<script src="http://localhost:8080/webpack-dev-server.js"></script>
<script src="bundle.js"></script>
</body>
</html>

在webpack.config.js中配置webpack-dev-server,在这里需要修改下entry的路径,给它加一个webpack/hot/dev-server,这里会用到Hot Module Replacement(热替换)插件,所以需要增加这个前缀,后文会提到,代码如下:

//__dirname是node.js中的一个全局变量,它指向当前执行脚本所在的目录
module.exports = {//注意这里是exports不是export
    entry: [‘webpack/hot/dev-server‘, __dirname, ‘./src/main.js‘],
    output: {//输出目录
        path: __dirname + "/build",//打包后的js文件存放的地方
        filename: "bundle.js"//打包后的js文件名
    },
   //webpack-dev-server配置
   devServer: {
        contentBase: ‘./build‘,//默认webpack-dev-server会为根文件夹提供本地服务器,如果想为另外一个目录下的文件提供本地服务器,应该在这里设置其所在目录(本例设置到"build"目录)
        historyApiFallback: true,//在开发单页应用时非常有用,它依赖于HTML5 history API,如果设置为true,所有的跳转将指向index.html
        port: 8080//设置默认监听端口,如果省略,默认为"8080"
   }
};

最后执行

npm run dev

你只要在浏览器打开这个地址:

http://localhost:8080/

webpack-dev-server会为你准备好一切,你只要敲一敲键盘,save一下,所见即所得。

这里dev的作用相当于tomacat,是一个基于node.js的小型的服务器,如果需要停止服务,在终端按ctrl+c,按提示输入Y即可。

我们尝试修改下hello.js里的内容,发现并没有变化,按F12查看控制台,发现报以下的错误

这里就需要引入一个HDR插件

Hot Module Replacement插件

Hot Module Replacement(HMR)是webpack里很有用的一个插件,它允许你在修改组件代码后,自动刷新实时预览修改后的效果。

在webpack中实现HMR也很简单,只需要在webpack.config.js中引入HMR插件,并在devServer中将inline设置为true,代码如下:

var webpack = require(‘webpack‘);
//__dirname是node.js中的一个全局变量,它指向当前执行脚本所在的目录
module.exports = {//注意这里是exports不是export
    entry: [‘webpack/hot/dev-server‘, __dirname + ‘/src/main.js‘],
    output: {//输出目录
        path: __dirname + "/build",//打包后的js文件存放的地方
        filename: "bundle.js"//打包后的js文件名
    },
    //webpack-dev-server配置
    devServer: {
        contentBase: ‘./build‘,//默认webpack-dev-server会为根文件夹提供本地服务器,如果想为另外一个目录下的文件提供本地服务器,应该在这里设置其所在目录(本例设置到"build"目录)
        historyApiFallback: true,//在开发单页应用时非常有用,它依赖于HTML5 history API,如果设置为true,所有的跳转将指向index.html
        inline: true,//设置为true,当源文件改变时会自动刷新页面
        port: 8080,//设置默认监听端口,如果省略,默认为"8080"
    },
    plugins: [
        new webpack.HotModuleReplacementPlugin()//热模块替换插件
    ]
};

在webpack中,我们都是使用的plugins来引入插件的使用

执行

npm run dev

返回webstrom,我们去修改hello.js组件中的代码,保存后发现,浏览器的值直接改变了,甚至都不需要我们去刷新页面,相当的方便

扩展

安装React

在加载器、插件、模块中,我们需要使用react来配合使用,首先安装react

这里,我们同时安装React和React-DOM

npm install --save-dev react react-dom

安装配置Babel

它是一个JavaScript编译器。使用它的目的有两个:

· 让代码支持ES6语法

· 支持React的一些特性(如JSX语法)

标准的React组件后缀名为.jsx,而.jsx是默认不被浏览器所支持的;所以需要一个转换器,将不被浏览器识别的.jsx文件转换成浏览器能够正常运行的文件,这个转换器就是Babel。

Babel loader用于文件特定格式的转换

// 安装 babel-core 核心模块 babel-loader ES6 和 React 支持
npm install babel-core babel-loader babel-preset-es2015 babel-preset-react --save-dev

查看package.json,会多出如下代码,表示安装成功
新建src/first.jsx文件,添加如下代码,这里要确保安装了React和React-DOM

const React = require(‘react‘);
const ReactDOM = require(‘react-dom‘);
ReactDOM.render(
  <h1>Hello, world!</h1>,
  document.querySelector(‘#content‘)
);

修改main.js的内容

// var hello = require(‘./hello.js‘);
// document.getElementById(‘content‘).appendChild(hello());
document.write(‘<h1>Hello World</h1>‘);

webpack.config.js中将first.jsx设置为我们的入口文件,并且添加module模块和loader加载器,这里要注意,在webpack1中使用的是babel加载,而在webpack2

中使用babel-loader加载,loader中的两个presets的意思是,告诉Babel,编译代码的时候要用es2015(即ES6)和react规范来编码

var webpack = require(‘webpack‘);
//__dirname是node.js中的一个全局变量,它指向当前执行脚本所在的目录
module.exports = {//注意这里是exports不是export
    // entry: [‘webpack/hot/dev-server‘, __dirname + ‘/src/main.js‘],
    entry: [‘webpack/hot/dev-server‘, __dirname + ‘/src/first.jsx‘],
    output: {//输出目录
        path: __dirname + "/build",//打包后的js文件存放的地方
        filename: "bundle.js"//打包后的js文件名
    },
    //webpack-dev-server配置
    devServer: {
        contentBase: ‘./build‘,//默认webpack-dev-server会为根文件夹提供本地服务器,如果想为另外一个目录下的文件提供本地服务器,应该在这里设置其所在目录(本例设置到"build"目录)
        historyApiFallback: true,//在开发单页应用时非常有用,它依赖于HTML5 history API,如果设置为true,所有的跳转将指向index.html
        inline: true,//设置为true,当源文件改变时会自动刷新页面
        port: 8080//设置默认监听端口,如果省略,默认为"8080"
    },
    plugins: [
        new webpack.HotModuleReplacementPlugin()//热模块替换插件
    ],
    module: {
        loaders:[
            {
                test: /\.js[x]?$/,//以js或者jsx结尾的文件
                exclude: /node_modules/,//排除node_modules文件夹下的所有文件
                loader: ‘babel-loader?presets[]=es2015&presets[]=react‘
            },
        ]
    }
};

配置完成后,cmd命令行中输入npm run dev来启动dev服务器来查看并且修改first.jsx文件的内容,来查看配置是否正确

原文地址:https://www.cnblogs.com/xiaoqi2018/p/10274753.html

时间: 2024-11-02 20:12:44

如何使用webpack打包前端项目的相关文章

gulp+webpack构建前端项目

本文将介绍如何利用gulp+webpack构建一个基本的前端项目.假设你已经安装了node环境并且会使用简单的命令行 1.gulp安装 (1)全局安装 npm install gulp -g (2)查看gulp是否安装成功 gulp -v (3)进入本地目录,新建gulpfile.js 2.安装gulp-webpack插件 基于gulp的插件非常多,建议大家查看npm官网https://www.npmjs.com (1)安装 webpack的用途主要是模块化+打包.安装敲入命令 npm inst

16.如何做到webpack打包vue项目后,可以修改配置文件

问题描述: 前端需要修改restful API的url,但是打包之后,配置文件找不到了,如果在npm run build 生成dist后,这个配置也被写死了,传到运行的前端服务器上后,假设某次,api服务器的ip修改了,改动只是更新下这个url,但是却需要会到前端源码,url后,在重新npm run build,然后再把整个dist再重新传到前端服务器,才可以. 解决方法: 用了generate-asset-webpack-plugin 这个插件,在webpack.prod.conf.js中去生

如何做到在webpack打包vue项目后,在外部动态修改配置文件

在我们做完vue项目后,只需要执行 npm run dist 就可以轻松进行打包转测试,可是如果我们临时需要修改一些配置文件比如域名,这时候我们就有点懵逼了,那就修改了再重新打一次包? NO NO NO,让我们一起来探索如何解决这个问题吧. 首先我们需要借助一个插件 generate-asset-webpack-plugin npm install generate-asset-webpack-plugin --save-dev 其次在build文件夹下建立一个generate-asset.co

解决webpack打包vue项目后,部署完成后,刷新页面页面404

1.url不动式url完全不动,即你的页面怎么改变,怎么跳转url都不会改变.这种情况的原理 就是纯ajax拿到页面后替换原页面中的元素,刷新页面就是首页 2.带hash(#)式这种相对于第一种的话刷新页面页面不会丢失    实现原理写一个window事件我监听url的变化,那我就能实先路由,那样我就可以根据url的变化,来通过ajax请求参数来渲染页面,一个url对应一个页面,就不会重复.window.addEventListener(‘hashchange‘,function(){self.

前端项目自动化构建工具——Webpack入门教程

参考资料:https://www.webpackjs.com/(中文文档)   https://www.webpackjs.com/(官方文档) 首先有必要说明一下,本文侧重讲解webpack基本配置属性,不附带实例,将会以通俗易懂的形式地讲解:如若需要实例进行相关练习,可将本文作为理论基础: Webpack是前端项目自动化构建工具,本质上,webpack 是一个现代 JavaScript 应用程序的静态模块打包器(module bundler).当 webpack 处理应用程序时,它会递归地构

如何解决使用webpack打包之后,font-awsome路径不对的问题,终极解决方法

http://www.cnblogs.com/caimuqing/p/7065694.html 问题描述: 使用webpack打包vue项目,使用font-awsome字体,发现打包之后,font-awsome图标不显示,报错为路径不对 看了下打包的路径,的确路径不对,打包之后font-awsome的文件是存放在static/fonts/下的,而访问的时候static/css/static/fonts/ 原因是: build > webpack.base.conf.js 里面loader的设置

webpack打包文件中的@符号表示什么意思

在看使用webpack打包的项目代码时,经常会看到在路径中引用@符号 import one from '@/views/one.vue' 那这里的@符号到底表示什么意思呢? 这其实利用了webpack的  resolve.alias  特性,webpabk.config.js  的配制代码如下,在webpack打包时,会把路径引用中的@符号,转换为相对应的路径. const path = require("path"); function resolve(dir) { return p

前端项目模块化的实践2:使用 Webpack 打包基础设施代码

以下是关于前端项目模块化的实践,包含以下内容: 搭建 NPM 私有仓库管理源码及依赖: 使用 Webpack 打包基础设施代码: 使用 TypeScript 编写可靠类库 (实现中) 本文是关于前端项目模板化的第2部分 现状 实际项目远远比示例使用的 myGreeting 复杂,比如 为了提高可维护性我们将项目折成了许多功能模板: 我们希望使用 Promise 等语法等,但是顾忌目标环境的支持能力: 可能依赖了多个第三方类库: 为了提高加载速度我们打包时需要进行很多额外工作: 代码压缩: Tre

如何实现vue-cli搭建的前端项目的自动打包

实现vue-cli + webpack +vue项目的自动打包: 后台java代码: public class OpenDirectory { public static void main(String[] args) throws IOException { String url = "F:\\Aomsc\\";        Runtime.getRuntime().exec("cmd /c start "+url+"a.bat");//通