npm + webpack +react

踏上征途

在开始之前,你需要把你的 Node.js 和 NPM 都更新到最新的版本。访问 nodejs.org 查看安装详情。我们将会使用 NPM 安装一些工具。

开始使用 Webpack 非常简单,我会展示给你看使用它的一个简单的项目。第一步,为你的项目新建一个文件夹,然后输入 npm init,然后填写相关问题。这样会为你创建了 package.json,不用担心填错,你可以之后修改它。

安装 Webpack

接下来我们安装 Webpack,我们要把它安装在本地,然后把它作为项目依赖保存下来。这样你可以在任何地方编译(服务端编译之类的)。输入 npm i wepack --save-dev。如果你想运行它,就输入 node_modules/.bin/webpack

目录结构

项目的目录结构长这样:

  • /app

    • main.js
    • component.js
  • /build
    • bundle.js (自动创建)
    • index.html
  • package.json
  • webpack.config.js

我们会使用 Webpack 在我们的 /app 里来自动创建 bundle.js 。接下来,我们来设置 webpack.config.js

设置 Webpack

Webpack 的配置文件长这样:

webpack.config.js

var path = require(‘path‘);

module.exports = {
    entry: path.resolve(__dirname, ‘app/main.js‘),
    output: {
        path: path.resolve(__dirname, ‘build‘),
        filename: ‘bundle.js‘,
    },
};

运行你的第一个编译

现在我们有了一个最简单的配置,我们需要有什么东西去编译,让我们开始一个经典的 Hello World,设置 /app 像这样:

app/component.js

‘use strict‘;

module.exports = function () {
    var element = document.createElement(‘h1‘);

    element.innerHTML = ‘Hello world‘;

    return element;
};

app/main.js

‘use strict‘;
var component = require(‘./component.js‘);

document.body.appendChild(component());

现在在你的命令行运行 webpack,然后你的应用会开始编译,一个 bundle.js 文件就这样出现在你的 /build 文件夹下,需要在build/ 下的 index.html 去启动项目。

build/index.html

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8"/>
  </head>
  <body>
    <script src="bundle.js"></script>
  </body>
</html>

这个文件可以用 html-webpack-plugin 来生成。如果你觉得冒险,那就把剩下的工具交给它来做。使用它就只有一个配置的问题。一般来说使用 Webpack 来工作就是这么个套路。

运行应用

只要双击 index.html 或者设置一个 Web 服务指向 build/ 文件夹。

设置 package.json scripts

npm 是一个非常好用的用来编译的指令,通过 npm 你可以不用去担心项目中使用了什么技术,你只要调用这个指令就可以了,只要你在 package.json 中设置 scripts 的值就可以了。

在这个案例中我们把编译步骤放到 npm run build 中是这样:

  1. npm i webpack --save - 如果你想要把 Webpack 作为一个项目的开发依赖,就可以使用 --save-dev,这样就非常方便地让你在开发一个库的时候,不会依赖工具(但不是个好方法!)。
  2. 把下面的内容添加到 package.json中。
  "scripts": {
    "build": "webpack"
  }

现在你可以输入 npm run build 就可以编译了。

当项目越发复杂的时候,这样的方法会变得越来越有效。你可以把所有复杂的操作隐藏在 scripts 里面来保证界面的简洁。

不过潜在的问题是这种方法会导致如果你使用一些特殊的指令的时候只能在 Unix 环境中使用。所以如果你需要考虑一些未知的环境中的话,那么 gulp-webpack 会是一个好的解决方案。

注意 NPM 会找到 Webpack,npm run 会把他临时加到 PATH来让我们这个神奇的命令工作。

工作流

如果需要一直输入 npm run build 确实是一件非常无聊的事情,幸运的是,我们可以把让他安静的运行,让我们设置 webpack-dev-server

设置 webpack-dev-server

第一步,输入 npm i webpack-dev-server --save,此外,我们需要去调整 package.json scripts 部分去包含这个指令,下面是基本的设置:

package.json

{
  "scripts": {
    "build": "webpack",
    "dev": "webpack-dev-server --devtool eval --progress --colors --hot --content-base build"
  }
}

当你在命令行里运行 npm run dev 的时候他会执行 dev 属性里的值。这是这些指令的意思:

  1. webpack-dev-server - 在 localhost:8080 建立一个 Web 服务器
  2. --devtool eval - 为你的代码创建源地址。当有任何报错的时候可以让你更加精确地定位到文件和行号
  3. --progress - 显示合并代码进度
  4. --colors - Yay,命令行中显示颜色!
  5. --content-base build - 指向设置的输出目录

总的来说,当你运行 npm run dev 的时候,会启动一个 Web 服务器,然后监听文件修改,然后自动重新合并你的代码。真的非常简洁!

访问 http://localhost:8080 你会看到效果。

浏览器自动刷新

当运行 webpack-dev-server 的时候,它会监听你的文件修改。当项目重新合并之后,会通知浏览器刷新。为了能够触发这样的行为,你需要把你的 index.html 放到 build/ 文件夹下,然后做这样的修改:

build/index.html

<!DOCTYPE html>
<html>
  <head>
    <meta charset="UTF-8"/>
  </head>
  <body>
    <script src="http://localhost:8080/webpack-dev-server.js"></script>
    <script src="bundle.js"></script>
  </body>
</html>

我们需要增加一个脚本当发生改动的时候去自动刷新应用,你需要在配置中增加一个入口点。

var path = require(‘path‘);

module.exports = {
    entry: [‘webpack/hot/dev-server‘, path.resolve(__dirname, ‘app/main.js‘)],
    output: {
        path: path.resolve(__dirname, ‘build‘),
        filename: ‘bundle.js‘,
    },
};

就是这样!现在你的应用就可以在文件修改之后自动刷新了。

默认环境

在上面的例子中我们创建了 index.html 文件来获取更多的自由和控制。同样也可以从 http://localhost:8080/webpack-dev-server/bundle 运行应用。这会触发一个默认的你不能控制的 index.html ,它同样会触发一个允许iFrame中显示重合并的过程。

引入文件

模块

Webpack 允许你使用不同的模块类型,但是 “底层”必须使用同一种实现。所有的模块可以直接在盒外运行。

ES6 模块

import MyModule from ‘./MyModule.js‘;

CommonJS

var MyModule = require(‘./MyModule.js‘);

AMD

define([‘./MyModule.js‘], function (MyModule) {

});

理解文件路径

一个模块需要用它的文件路径来加载,看一下下面的这个结构:

  • /app

    • /modules
    • MyModule.js
    • main.js (entry point)
    • utils.js

      踏上征途

      在开始之前,你需要把你的 Node.js 和 NPM 都更新到最新的版本。访问 nodejs.org 查看安装详情。我们将会使用 NPM 安装一些工具。

      开始使用 Webpack 非常简单,我会展示给你看使用它的一个简单的项目。第一步,为你的项目新建一个文件夹,然后输入 npm init,然后填写相关问题。这样会为你创建了 package.json,不用担心填错,你可以之后修改它。

      安装 Webpack

      接下来我们安装 Webpack,我们要把它安装在本地,然后把它作为项目依赖保存下来。这样你可以在任何地方编译(服务端编译之类的)。输入 npm i wepack --save-dev。如果你想运行它,就输入 node_modules/.bin/webpack

      目录结构

      项目的目录结构长这样:

      • /app

        • main.js
        • component.js
      • /build
        • bundle.js (自动创建)
        • index.html
      • package.json
      • webpack.config.js

      我们会使用 Webpack 在我们的 /app 里来自动创建 bundle.js 。接下来,我们来设置 webpack.config.js

      设置 Webpack

      Webpack 的配置文件长这样:

      webpack.config.js

      var path = require(‘path‘);
      
      module.exports = {
          entry: path.resolve(__dirname, ‘app/main.js‘),
          output: {
              path: path.resolve(__dirname, ‘/build‘),
              filename: ‘bundle.js‘,
          },
      };
      

      运行你的第一个编译

      现在我们有了一个最简单的配置,我们需要有什么东西去编译,让我们开始一个经典的 Hello World,设置 /app 像这样:

      app/component.js

      ‘use strict‘;
      
      module.exports = function () {
          var element = document.createElement(‘h1‘);
      
          element.innerHTML = ‘Hello world‘;
      
          return element;
      };
      

      app/main.js

      ‘use strict‘;
      var component = require(‘./component.js‘);
      
      document.body.appendChild(component());
      
      

      现在在你的命令行运行 webpack,然后你的应用会开始编译,一个 bundle.js 文件就这样出现在你的 /build 文件夹下,需要在build/ 下的 index.html 去启动项目。

      build/index.html

      <!DOCTYPE html>
      <html>
        <head>
          <meta charset="UTF-8"/>
        </head>
        <body>
          <script src="bundle.js"></script>
        </body>
      </html>
      

      这个文件可以用 html-webpack-plugin 来生成。如果你觉得冒险,那就把剩下的工具交给它来做。使用它就只有一个配置的问题。一般来说使用 Webpack 来工作就是这么个套路。

      运行应用

      只要双击 index.html 或者设置一个 Web 服务指向 build/ 文件夹。

      设置 package.json scripts

      npm 是一个非常好用的用来编译的指令,通过 npm 你可以不用去担心项目中使用了什么技术,你只要调用这个指令就可以了,只要你在 package.json 中设置 scripts 的值就可以了。

      在这个案例中我们把编译步骤放到 npm run build 中是这样:

      1. npm i webpack --save - 如果你想要把 Webpack 作为一个项目的开发依赖,就可以使用 --save-dev,这样就非常方便地让你在开发一个库的时候,不会依赖工具(但不是个好方法!)。
      2. 把下面的内容添加到 package.json中。
        "scripts": {
          "build": "webpack"
        }
      

      现在你可以输入 npm run build 就可以编译了。

      当项目越发复杂的时候,这样的方法会变得越来越有效。你可以把所有复杂的操作隐藏在 scripts 里面来保证界面的简洁。

      不过潜在的问题是这种方法会导致如果你使用一些特殊的指令的时候只能在 Unix 环境中使用。所以如果你需要考虑一些未知的环境中的话,那么 gulp-webpack 会是一个好的解决方案。

      注意 NPM 会找到 Webpack,npm run 会把他临时加到 PATH来让我们这个神奇的命令工作。

      工作流

      如果需要一直输入 npm run build 确实是一件非常无聊的事情,幸运的是,我们可以把让他安静的运行,让我们设置 webpack-dev-server

      设置 webpack-dev-server

      第一步,输入 npm i webpack-dev-server --save,此外,我们需要去调整 package.json scripts 部分去包含这个指令,下面是基本的设置:

      package.json

      {
        "scripts": {
          "build": "webpack",
          "dev": "webpack-dev-server --devtool eval --progress --colors --hot --content-base build"
        }
      }
      

      当你在命令行里运行 npm run dev 的时候他会执行 dev 属性里的值。这是这些指令的意思:

      1. webpack-dev-server - 在 localhost:8080 建立一个 Web 服务器
      2. --devtool eval - 为你的代码创建源地址。当有任何报错的时候可以让你更加精确地定位到文件和行号
      3. --progress - 显示合并代码进度
      4. --colors - Yay,命令行中显示颜色!
      5. --content-base build - 指向设置的输出目录

      总的来说,当你运行 npm run dev 的时候,会启动一个 Web 服务器,然后监听文件修改,然后自动重新合并你的代码。真的非常简洁!

      访问 http://localhost:8080 你会看到效果。

      浏览器自动刷新

      当运行 webpack-dev-server 的时候,它会监听你的文件修改。当项目重新合并之后,会通知浏览器刷新。为了能够触发这样的行为,你需要把你的 index.html 放到 build/ 文件夹下,然后做这样的修改:

      build/index.html

      <!DOCTYPE html>
      <html>
        <head>
          <meta charset="UTF-8"/>
        </head>
        <body>
          <script src="http://localhost:8080/webpack-dev-server.js"></script>
          <script src="bundle.js"></script>
        </body>
      </html>
      

      我们需要增加一个脚本当发生改动的时候去自动刷新应用,你需要在配置中增加一个入口点。

      var path = require(‘path‘);
      
      module.exports = {
          entry: [‘webpack/hot/dev-server‘, path.resolve(__dirname, ‘app/main.js‘)],
          output: {
              path: path.resolve(__dirname, ‘/build‘),
              filename: ‘bundle.js‘,
          },
      };
      

      就是这样!现在你的应用就可以在文件修改之后自动刷新了。

      默认环境

      在上面的例子中我们创建了 index.html 文件来获取更多的自由和控制。同样也可以从 http://localhost:8080/webpack-dev-server/bundle 运行应用。这会触发一个默认的你不能控制的 index.html ,它同样会触发一个允许iFrame中显示重合并的过程。

      引入文件

      模块

      Webpack 允许你使用不同的模块类型,但是 “底层”必须使用同一种实现。所有的模块可以直接在盒外运行。

      ES6 模块

      import MyModule from ‘./MyModule.js‘;
      

      CommonJS

      var MyModule = require(‘./MyModule.js‘);
      

      AMD

      define([‘./MyModule.js‘], function (MyModule) {
      
      });
      

      理解文件路径

      一个模块需要用它的文件路径来加载,看一下下面的这个结构:

      • /app

        • /modules
        • MyModule.js
        • main.js (entry point)
        • utils.js

      打开 main.js 然后可以通过下面两种方式引入 app/modules/MyModule.js

      app/main.js

      // ES6
      import MyModule from ‘./modules/MyModule.js‘;
      
      // CommonJS
      var MyModule = require(‘./modules/MyModule.js‘);
      

      最开始的 ./ 是 “相对当前文件路径”

      让我们打开 MyModule.js 然后引入 app/utils:

      app/modules/MyModule.js

      // ES6 相对路径
      import utils from ‘./../utils.js‘;
      
      // ES6 绝对路径
      import utils from ‘/utils.js‘;
      
      // CommonJS 相对路径
      var utils = require(‘./../utils.js‘);
      
      // CommonJS 绝对路径
      var utils = require(‘/utils.js‘);
      

      相对路径是相对当前目录。绝对路径是相对入口文件,这个案例中是 main.js

打开 main.js 然后可以通过下面两种方式引入 app/modules/MyModule.js

app/main.js

// ES6
import MyModule from ‘./modules/MyModule.js‘;

// CommonJS
var MyModule = require(‘./modules/MyModule.js‘);

最开始的 ./ 是 “相对当前文件路径”

让我们打开 MyModule.js 然后引入 app/utils:

app/modules/MyModule.js

// ES6 相对路径
import utils from ‘./../utils.js‘;

// ES6 绝对路径
import utils from ‘/utils.js‘;

// CommonJS 相对路径
var utils = require(‘./../utils.js‘);

// CommonJS 绝对路径
var utils = require(‘/utils.js‘);

相对路径是相对当前目录。绝对路径是相对入口文件,这个案例中是 main.js

时间: 2024-10-10 22:55:35

npm + webpack +react的相关文章

npm搭建React项目

转自:http://blog.csdn.net/u012859720/article/details/70597119 要想使用npm,首先安装Node.js 一.安装全局包 $ npm install babel -g $ npm install webpack -g $ npm install webpack-dev-server -g 二.创建根目录 创建一个根目录,目录名为:myApp,再使用npm init初始化,生成package.json文件: $ mkdir myApp $ cd

webpack+react+antd 单页面应用实例

webpack+react+antd 单页面应用实例 React框架已经火了好长一段时间了,再不学就out了! 对React还没有了解的同学可以看看我之前的一篇文章,可以快速简单的认识一下React.React入门最好的实例-TodoList 自己从开始接触react一窍不通,到慢慢的似懂非懂,通过各种途径学习也有一阵了.学习过程中还会接触到很多新的东西,比如ES6.webpack,过程艰辛谁人懂,见坑填坑慢慢来.今天把学习过程过滤了一下,只说项目实际需要用的东西,总结了一套能看到的东西,分享给

使用 webpack + react + redux + es6 开发组件化前端项目

因为最近在工作中尝试了 webpack.react.redux.es6 技术栈,所以总结出了一套 boilerplate,以便下次做项目时可以快速开始,并进行持续优化. 项目结构规划 每个模块相关的 css.img.js 文件都放在一起,比较直观,删除模块时也会方便许多.测试文件也同样放在一起,哪些模块有没有写测试,哪些测试应该一起随模块删除,一目了然. build |-- webpack.config.js # 公共配置 |-- webpack.dev.js # 开发配置 |-- webpac

前端新手如何搭建webpack+react的开发环境

步骤: 首先保证有node 和 npm环境.运行node -v 和npm -v查看版本号来确定 注意: 初始化npm环境并安装插件: 没有项目:想在Window命令下创建项目 有项目:cd 到相应的项目 进入之后,运行npm init (初始化)按照步骤依次确认 yes 最终生成package.json文件. 所有使用npm做的依赖管理项目,根目录下都会有一个这个文件,该文件 描述了项目的基本信息以及一些第三方依赖插件 安装插件 使用 webpack 作为构建工具,需要安装相应插件,运行 npm

通过npm使用React

要想使用npm,请先安装nodejs. 第一步.安装全局包$ npm install babel -g$ npm install webpack -g$ npm install webpack-dev-server -g第二步.创建根目录创建一个根目录,目录名为:reactApp,再使用 npm init 初始化,生成 package.json 文件: $ mkdir reactApp$ cd reactApp/$ npm initname: (reactApp) runoob-react-te

webpack+react+redux+es6

一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入门教程   redux middleware 详解   Redux研究 React 入门实例教程 webpack学习demo NPM 使用介绍 三.工程搭建 之前有写过 webpack+react+es6开发模式 ,文章里介绍了一些简单的配置,欢迎访问. 1.可以npm init, 创建一个新的工程

webpack+react+redux+es6开发模式

一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入门教程   redux middleware 详解   Redux研究 React 入门实例教程 webpack学习demo NPM 使用介绍 三.工程搭建 之前有写过 webpack+react+es6开发模式 ,文章里介绍了一些简单的配置,欢迎访问. 1.可以npm init, 创建一个新的工程

webpack+react 环境

0,  node+npm 1,npm install webpack -g 2,npm install webpack-dev-server -g 3,npm install react react-dom --save 4,npm install jquery --save 5,npm install babel-core babel-loader babel-preset-es2015 babel-preset-react --save-dev   //es6 6,npm install u

手把手教你如何使用webpack+react

上一篇随笔讲述了新手入门入门前端 里面提到的第四阶段跟上当前前端的发展需要入门一个框架和自动化工具,当时推荐的是webpack+react 今天正好有空,也把自己入门webpack + react 的艰辛过程写下来, 现在想起来真是一脸泪.过程不表了, 现在将我看到的一些教程总结一下,挑选出对新手比较友好的学习过程.   第一步: webpack 和 react  是要配合node.js 一起使用的. 去node.js官网下载当前node, 官网会根据你的环境匹配你适合的版本,直接下载安装就好了