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
中是这样:
npm i webpack --save
- 如果你想要把 Webpack 作为一个项目的开发依赖,就可以使用--save-dev
,这样就非常方便地让你在开发一个库的时候,不会依赖工具(但不是个好方法!)。- 把下面的内容添加到
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 属性里的值。这是这些指令的意思:
webpack-dev-server
- 在 localhost:8080 建立一个 Web 服务器--devtool eval
- 为你的代码创建源地址。当有任何报错的时候可以让你更加精确地定位到文件和行号--progress
- 显示合并代码进度--colors
- Yay,命令行中显示颜色!--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
scriptsnpm
是一个非常好用的用来编译的指令,通过npm
你可以不用去担心项目中使用了什么技术,你只要调用这个指令就可以了,只要你在package.json
中设置scripts
的值就可以了。在这个案例中我们把编译步骤放到
npm run build
中是这样:npm i webpack --save
- 如果你想要把 Webpack 作为一个项目的开发依赖,就可以使用--save-dev
,这样就非常方便地让你在开发一个库的时候,不会依赖工具(但不是个好方法!)。- 把下面的内容添加到
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 属性里的值。这是这些指令的意思:webpack-dev-server
- 在 localhost:8080 建立一个 Web 服务器--devtool eval
- 为你的代码创建源地址。当有任何报错的时候可以让你更加精确地定位到文件和行号--progress
- 显示合并代码进度--colors
- Yay,命令行中显示颜色!--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。
- /app
打开 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。
转载于:https://www.cnblogs.com/cshi/p/5643110.html
npm + webpack +react相关推荐
- webpack+react多页面开发架构
项目已经升级为最新版本参考react-multi-page-app webpack在单页面打包上应用广泛,以create-react-app为首的脚手架众多,单页面打包通常指的是将业务js,css打包 ...
- webpack+react+redux+es6开发模式---续
一.前言 之前介绍了webpack+react+redux+es6开发模式 ,这个项目对于一个独立的功能节点来说是没有问题的.假如伴随着源源不断的需求,前段项目会涌现出更多的功能节点,需要独立部署运行 ...
- webpack+react+redux+es6开发模式
一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入 ...
- webpack+react+es6开发模式
一.前言 实习了两个月,把在公司用到的前端开发模式做个简单的整理.公司里前端开发模式webpack+react+redux+es6,这里去掉了redux. webpack, react, redux等 ...
- 从零开始搭建webpack+react开发环境
环境主要依赖版本 webpack@4.8.1 webpack-cli@2.1.3 webpack-dev-server@3.1.4 react@16.3.2 babel-core@6.26.3 bab ...
- npm搭建React项目
注:该教程出自于极客学院,教程地址:http://www.imooc.com/article/6219 要想使用npm,首先安装node.js 一.安装全局包 $ npm install babel ...
- (二)使用npm搭建React项目
一.在内地npm预设是连线到国外的registry,我们可已更改为taobao代理的registry,这样安装包的速度可已加快 npm config set registry https://regi ...
- 从零开始一个webpack+react项目
从零开始一个webpack+react项目 最近在做react组件化的分享,从项目中抽离组件,那么第一步自然是搭建相关的环境 本篇旨在从零开始,用最少的配置.最少的代码.最少的依赖来搭建一个最简单的w ...
- 如何使用webpack+react+redux从头搭建Todolist应用
webpack环境配置 应用整体框架设计 代码实现 Container Components Actions Reducers indexjs 测试 总结 一言不和先上demo: https://ms ...
最新文章
- Android 使用CornerPathEffect绘制圆角矩形
- angularjs获取上一个元素的id_三男子非法获取苹果ID账号买卖,交易数万条,价格从一毛到上百元不等...
- 如何读取resources目录下的文件路径(九种方式)
- 深度学习——卷积神经网络 的经典网络(LeNet-5、AlexNet、ZFNet、VGG-16、GoogLeNet、ResNet)
- android初学之退出应用程序
- Windows桌面任务栏透明化
- 拖拽报表设计香不香—JimuReport 1.4.0新特性
- Spring Boot基础学习笔记19:自定义RedisTemplate与RedisCacheManager
- 2018年面试准备汇总
- webpack4打包vue前端多页面项目
- xmlns:app=http://schemas.android.com/apk/res-auto
- 哲理故事300篇 下
- 星上SAR实时处理调研2-典型应用
- 用户用户组,与密码管理,su,sudo命令,限制root远程登陆
- MySQL数据库系统基础_wuli大世界_新浪博客
- Office-008 文字转公式:word公式输入
- 矩阵和矢量的点乘推导及其简单应用
- 主成分分析 (一): 基本思想与主成分估计方法
- android webrtc教程,WebRTC 入门教程(一)| 搭建WebRTC信令服务器
- 阿里云高防服务器多少钱?提供CC和WEB漏洞DDOS防护