标签:
你有没有遇见过垂直居中的问题?有没有听说过flex弹性布局?没听过的赶紧点了解Flex布局,看看flex布局是有多么强大!!!还在发愁flexbox布局不兼容最新的浏览器?点击兼容IE9+、UCBroswer的FlexLayout,获取兼容性的flexlayout react组件。
最近在学习Amazeui-react的开发,发现react着实是一个好东西,但是蛋疼的是webpack这个东西好难配置,稍不注意就会导致自动编译失败,会出现一堆的问题,下面就请跟我一起从零开始学习React+webpack配置,并且如何在webstorm中很好的运用它们。
1、下载webstorm11和nodejs。
下载太慢?直接百度云打包分享吧~~windows mac osx
由于我的电脑的MacBook不是windows,因此可能安装和操作过程会有略微差异,但是差异不大,下面操作基本通用,不通用的我会指明。或者下面留言即可。
npm config set registry https://registry.npm.taobao.org
sudo npm install webpack webpack-dev-server babel -g
sudo npm install react react-dom babel-loader less-loader css-loader style-loader url-loader file-loader babel-preset-es2015 babel-preset-react --save-dev
安装结果会显示一些WARN,无视!但是千万别有Error。参数解释:
-g:允许包全局使用
--save-dev:将依赖信息写入package.json的devdependencies。
安装的每个组件解释:
babel:能将es6语法解析成es5(什么是es??ECMAScript*6*入门自己看去,js是它的子集,说白了就是最新的javascript语法),以前是使用jsx-loader来解析着,现在直接用babel替代就行了。
babel-preset-es2015和babel-preset-react:让babel支持es2015语法和jsx语法的两个预设值。
webpack:这个还用说吗?
react-dom:依赖于react,现在都是通过ReactDOM.render()方法来渲染而不是React.render(),facebook官方已经说了。
webpack-dev-server:webpack开发服务器,帮助开发者实时监控webpack项目的文件更改并反映到浏览器上。这样你就能实时地进行预览啦~
babel-loader css-loader babel-loader style-loader url-loader file-loader:几种webpack需要用到的加载器,方便解析css、es6/jsx、和其他静态文件。
小提示:
全局安装支持直接在命令行中启用安装包的命令,例如:你安装了webpack,那么在命令行输入webpack就会出现相应执行,但是非全局不支持使用这个命令的哦。
var webpack=require(‘webpack‘);
var commonsPlugin=new webpack.optimize.CommonsChunkPlugin(‘common.js‘);
module.exports={
entry:{index:‘./src/js/entry.js‘},
output:{
path:‘dist‘,
filename:‘bundle.js‘
},
module:{
loaders:[
{
test:/\.css$/,
loader:‘style-loader!css-loader‘
},
{
test:/\.jsx?$/,
loader:‘babel‘,
exclude: /node_modules/,
query:{
presets:[‘es2015‘,‘react‘]
}
},
{
test:/\.(png|jpg)$/,
loader:‘url-loader?limit=8192‘
},
{
test:/\.less$/,
loader:‘style-loader!css-loader!less-loader‘
},
{
test: /\.woff(2)?(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: "url-loader?limit=10000&mimetype=application/font-woff"
},
{
test: /\.(ttf|eot|svg)(\?v=[0-9]\.[0-9]\.[0-9])?$/,
loader: "file-loader"
}
],
plugins:[
commonsPlugin
]
},
resolve:{
root:‘‘,
extensions:[‘‘,‘.js‘,‘.json‘,‘.less‘],
alias:{
AppStore:‘js/stores/AppStores.js‘
}
}
}
然后在当前工程目录创建一个src文件夹,在src里面创建一个js文件夹,在js文件夹中新建一个entry.js文件,文件内容如下:
var React=require(‘react‘);
var ReactDOM=require(‘react-dom‘);
ReactDOM.render(<div>Hello world!</div>, document.getElementById("test"));
接下来再在当前工程目录中新建一个dist文件夹,dist文件夹中新建一个index.html文件。内容如下:
<html>
<meta charset="utf-8">
<title>React webpack test</title>
</head>
<body>
<div id="test"></div>
</div>
<script type="text/javascript" src="./bundle.js" charset="utf-8"></script>
</body>
</html>
最后一步,最后一步了哦~~加入package.json文件,使之成为一个可以用npm命令执行的工程。
{
"name": "react_webpack_test",
"version": "1.0.0",
"description": "just webpack and react hello world project!",
"scripts": {
"build": "webpack --progress --profile --colors",
"watch": "webpack-dev-server --port 63340 --content-base ./dist/",
"test": "echo \"Error: no test specified\" && exit 1"
}
}
其中最重要的是script标签。npm run build
然后,在你的Terminal里面会显示如下的东东
> react_webpack_test@1.0.0 build /Users/你的工程所在目录/react_webpack_test
> webpack \--progress \--profile \--color 2m0ms op1ms optimiz12ms emit
Hash: 292766b53fb3969afd55
Version: webpack 1.12.14
Time: 5109ms
Asset Size Chunks Chunk Names
bundle.js 676 kB 0 [emitted] index
\+ 159 hidden modules
如果里面出现了红色的Error那么就说明你的工程配置还有一些问题,如果OK的话,打开浏览器,在里面运行你的dist/index.html文件,看看是否有:hello world!输出http://localhost:63340/webpack-dev-server/
省略这部分……
webpack: bundle is now VALID.
输入:http://localhost:63340/webpack-dev-server/,应该就可以看到你想要的结果,结果如下:喝杯茶~
……
到了这可以说你的项目就已经完成了,如果你想跟我一样使用Amazeui-react组件,那么就继续跟我这样继续下去吧~
npm install amazeui amazeui-react --save-dev
var React=require(‘react‘);
var ReactDOM=require(‘react-dom‘);
var AMUI=require(‘amazeui/dist/css/amazeui.min.css‘);
var AMUIReact = require(‘amazeui-react‘);
var button=(
<AMUIReact.Button>这是一个按钮</AMUIReact.Button>
);
ReactDOM.render(button,document.getElementById("test"));
下面是我的测试工程链接,自己下载下来拿去用吧.
react_webpack_test
整整连写带测试折腾了我一下午,为了保证每一处写的没有疏漏,我现卸载掉我电脑上的webstorm和nodejs~~
标签:
原文地址:http://www.cnblogs.com/xiaoshitou188/p/5868557.html
_yuchen震
请问一下为什么webpack. config. js里不用require (‘path‘)
还有请问一下package. json里的watch里 /.dist/是什么作用的呢??????
小黄人大侠: @_yuchen震 您好,webpack.config.js 里面用到了require,开头这句,var webpack=require(‘webpack‘);所有的nodejs依赖如果需要引用外部类,require是不可避免的。watch里的./dist/指的是webpack-dev-server 监听的目录,一直监听当前位置下地dist目录,可以保证当dist目录下有文件改动时实时的从浏览器中能够刷新出来,具体webpack-dev-server的用法请查看http://webpack.github.io/docs/webpack-dev-server.html,他对于webpack并不是必须的,只是辅助开发实时查看预览效果而已。
_yuchen震: @小黄人大侠 好的谢谢博主回答~~ 请问还有木有AmazeUI+react+webpack的项目例程呢,希望能像博主学习一下
_yuchen震: 能请问下AMUIReact的模态框怎样写吗?
>var modal = <AMUIReact.Modal title="Amaze UI Modal">这一个 Modal 窗口。</AMUIReact.Modal>;
module.exports =React.createClass ({
render: function() {
return (
<AMUIReact.ModalTrigger modal={modal}>
<AMUIReact.Button amStyle=‘primary‘>打开 Modal 窗口</AMUIReact.Button>
</AMUIReact.ModalTrigger>
);
}
});
这样写只能展示按钮,没有模态框0 0
hstonel
学习,谢谢
霓源阁
@小黄人大侠 博主,我是后端转前端的,我用的一直是Intellij IDEA,然后我看了一些前端的教程,好多都是自动化的东西 yeomen,grunt,还要webpack等等,但是我觉得Intellij IDEA或者webstorm貌似都能替代他们吗?我一直很疑惑,请博主帮忙解答。
还要博主写的文章我很喜欢,方便留个联系方式吗 qq或者邮箱?
小黄人大侠: @霓源阁 不能说代替,就像nodejs不能指望完全代替java、php一样,我们必须知道这些技术擅长的领域,只需要取其所长即可。而且我觉得你可能说的是不是这些开发工具替代你以前用的开发工具?开发工具永远是朝着更加智能,功能强大和方便发展,多学习新的东西会不断提高自己的开发效率~
708d0f26b105
webstorm是自动保存的 但是自动保存 那react的自动刷新就不能用
小黄人大侠: @708d0f26b105 你可以把自动保存功能关闭,设置成ctrl+S快捷键手动保存。
小黄人大侠: @708d0f26b105 我这个好像发错了,react自动刷新是使用的webpack-dev-server来测试的~
aafff584fec2: 设置成手动保存以后,再命令行输入npm run watch 只能检测一次,切换界面后就不起作用了
JYoung
特意注册了个账号来感谢一下,上午搞了半天没搞明白配置,还好群里的人推荐查一下这篇文章啦~ 现在已经可以愉快的撸码啦~
小黄人大侠: @JYoung 呵呵,不用客气,你的诚意已收到,好好地享受webpack和react给你带来的乐趣吧~
AlbertBreeze
生成的bundle.js文件有700多KB大小,有办法进行压缩么?
小黄人大侠: @AlbertBreeze 关于压缩请去webpack官网查看code spliting部分。
vargent
按照你这个配置,还是没有配置成功,找不到webpack 本人新手
小黄人大侠: @vargent webpack没装成功
小黄人大侠: @vargent 使用全局安装 npm install -g webpack
Chozo
Error: Cannot find module ‘webpack‘
这是什么情况
Failed at the react_webpack_test@1.0.0 build script ‘webpack --progress --profile --colors‘.还有这个
我也是mac出错了
小黄人大侠: @Chozo 你没有安装webpack,使用全局命令:npm install webpack webpack-dev-server -g --save-dev 安装一次即可
秋夜已凉
这个就是用来充数的,光棍节快乐!! 可见作者是个大神,写的很好!??
小黄人大侠: @秋夜已凉 ??