在生产环境中如果依靠前端引用JSXTransformer.js文件来实现JSXJavaScript的转换,那是绝对不靠谱的。所以,使用Reactjs的童鞋就需要使用更有逼格的方式来完成这项任务。作为现在最常用的前端构建工具gulp搭配上Browserify来搞定这个问题那真是拉风的不要不要的 :)

废话不多说,咱们来点直接的吧。

源代码

我们这次的任务就是让这段满目疮痍的源代码变得更优化,千里之行,这是开始。如果有童鞋看不懂这段代码是用来做神马的,那么我只能说,“妈妈叫你回家看基础了。”回家之路(看不懂代码的,请猛戳)。

<div id="app"></div>
<script type="text/jsx">var HelloWorld = React.createClass({ render: function() { return (<div> Hello World </div> );}}); React.render(<HelloWorld />, document.getElementById('app'));
</script>
<script type="text/jsx">var Child = React.createClass({ render: function() { return (<div> The Child </div> );}}); var Parent = React.createClass({ render: function() { return (<div> Hello World </div><Child/> ); } }); React.render(<Parent />, document.getElementById('app'));
</script>

优化

前面把两个组件都写到一块了,现在来分割成独立的文件。其中一个命名为js/components/Parent.jsx,内容如下:

var Child = require('./Child.jsx');var Parent = React.createClass({render: function(){return (<div><div> Hello World </div><Child/></div>)}
});module.exports = Parent;

Parent 的子元器件Child写到js/components/Child.jsx中,内容如下:

var Child = React.createClass({render: function(){return (<div> The Child </div>)}
});module.exports = Child;

写到这里,我们已经将两个组件做了初步的拆分,如果有童鞋对module.exports是神马还是一知半解或者根本不懂这是要搞什么飞机,那么请去百度自行谷歌commonjs,相信度娘会很妩媚的帮你解惑。

如果要真正让元器件显示在页面上需要执行React.render函数,这个是写在js/app.js中的,内容如下:

var Parent = require('./components/Parent.jsx');
React.render(<Parent />, document.getElementById('app'));

做到这里,我们还顺带了做了一件很有意义的事情,就是对文件文件目录做了优化,组件放置在/components文件夹中,启动放置在根目录/js下,清晰明了。

使用Browerify之后,html文件中只需要引入一个自定义script文件就好了 ,如下:

<script src='js/bundle.js'></script>

所有依赖的js内容未来都会被编译到bundle.js文件中。

安装 Browserify

工欲善其事,必先利其器。如果还没有安装gulp的童鞋可以参考我曾经写的《这年头,不用点道具(gulp),你都不好意思说你是做前端的》来安装一下(名字略长略长,但有没有很贴心,服务就是要做全套嘛)。

如果你在命令行敲击如下命令

gulp -v

输出结果大概如下面这个这样子的话,那就说明你已经成功安装了gulp。

CLI version 3.9.0
Local version 3.9.0

在这个基础上,进入项目目录还需要来局部安装 gulp ,browserify 以及相关的辅助工具:

npm install --save-dev gulp browserify vinyl-source-stream reactify

使用Mac的童鞋不要忘记加sudo哟。

说一下上面四个包的各自作用:

  • gulp 是任务运行环境,用来进行任务调度

  • browserify 用来 require js 的模块

  • vinyl-source-stream 把 browserify 输出的数据进行准换,使之流符合 gulp 的标准

  • reactify 使用它来实现 JSX 编译功能

然后到 gulpfile.js 中,填写如下内容:

var gulp = require("gulp"),browserify = require('browserify'),reactify = require('reactify'),source = require('vinyl-source-stream');gulp.task('jsx', function() {browserify('./js/app.js').transform(reactify).bundle().pipe(source('bundle.js')).pipe(gulp.dest('js'));
});

来解释一下上面的脚本流程。首先就是把入口文件 app.js 交给 browserify 进行处理,对于 jsx 的编译,官方推荐使用的就是reactify。下一步,运行 bundle()来把所有依赖都打包成 bundle.js ,但是注意,browserify 不是一个专门为 gulp 写的包,所有它输出的数据流并不能直接 pipe 给 gulp 使用,所以,需要用到 source()接口,也就是 vinyl-source-stream 这个工具来处理一下,然后 pipe 给 gulp ,gulp.dest 会把输出的 bundle.js 文件保存到 js 文件夹中。

任务写好了,在命令行执行:

gulp jsx

这样就生成了 js/bundle.js 文件了。由于这个文件的标签已经添加到 index.html 中了,所以直接用 chrome 打开就可以看到运行效果了。

文章改编自《当 React 遇见 Gulp 和 Browserify》

听说,当使用Reactjs的时候,Gulp和Browserify很配哦相关推荐

  1. 前端构建工具的用法—grunt、gulp、browserify、webpack

    随着前端项目的飞速发展,项目越来越大.文件越来越多,前端工程化的工具也越来越多.下面介绍目前最流行的四种构建工具--grunt.gulp.browserify.webpack 所有的构建工具都是基于N ...

  2. 听说你对 ES6 class 类还不是很了解

    大家好,我是若川.最近组织了源码共读活动,感兴趣的可以加我微信 ruochuan12 参与. 前言 在ES5中是原型函数,到了ES6中出现了"类"的概念.等同于是ES5的语法糖,大 ...

  3. 【玩转数据系列四】听说啤酒和尿布很配?本期教你用协同过滤做推荐

    (本文数据为虚构,仅供实验) 产品地址:https://data.aliyun.com/product/learn?spm=a21gt.99266.416540.102.OwEfx2 一.背景 数据挖 ...

  4. 【天赢金创】探究Gulp的Stream

    来自Gulp的难题 描述Gulp的项目构建过程的代码,并不总是简单易懂的. 比如Gulp的这份recipe: var browserify = require('browserify'); var g ...

  5. 基于 gulp 的 fancybox 源码压缩

    前不久,处理生信分析的网页版自动化报告时候就使用过 fancybox,今天在优化个人博客,为博文增加图片缩放效果,解决一些滚动条问题时,才从 fancybox 的 Github 源码中接触到 gulp ...

  6. 使用gulp进行React任务的构建

    如果你不熟悉gulp的操作,可以看下下面的教程: gulp学习笔记1 gulp学习笔记2 gulp学习笔记3 gulp学习笔记4 对于gulp在react中的构建,找了很多资料,看了很多文章,也根据文 ...

  7. More than React(一)为什么ReactJS不适合复杂交互的前端项目?

    <More than React>系列的文章会一共分为五篇和一则附录.本文是第一篇,介绍用 ReactJS开发时遇到的种种问题.后面四篇文章的每一篇将会分别详细讨论其中一个问题,以及Bin ...

  8. 马上开始写 react ES6 --- 基于gulp 和 Babel 的脚手架

    我对 react 很有兴趣,但是我发现想写 react 不容易. 我需要在开始写代码之前做很多准备工作,我需要编译jsx文件,引入react等等,而最新的react示例,有鼓励ES6来书写代码,可以用 ...

  9. gulp+PC前端静态页面项目开发

    前言: 现在单页面很流行,但是在 PC 端多页面还是常态,所以构建静态页面的工具还有用武之地 gulp构建前言: 如今我们开发web网页的方式主要有几种,使用vue-cli.create-react- ...

最新文章

  1. Leetcode刷题第1题:两数之和(基于Java语言)
  2. Nginx + PHP/PHP-FPM安装配置示例
  3. Python3爬取网页信息乱码怎么解决?(更新:已解决)
  4. FatMouse's Speed hdu 1160(动态规划,最长上升子序列+记录路径)
  5. 补码(为什么按位取反再加一):告诉你一个其实很简单的问题(转自醍醐灌顶)...
  6. Wordfence Premium 安全防护 WordPress插件
  7. FFmpeg进行屏幕录像和录音
  8. Windows驱动开发入门——从这里出发
  9. 分享“消防图纸”识图方法,让你一眼秒懂!
  10. ImageJ的Macro语言实例教程
  11. 归纳法、演绎法、数学归纳法之间的关系
  12. 使用replaceAll()方法替换字符串中的反斜杠:左斜杠(\)和右斜杠(/)
  13. 英语单词速记(一直更新中......)
  14. java合成wav在linux出错,Java audio fails to play wav file in Linux
  15. 华为天才少年火了!刚毕业就拿201万年薪,全球仅4人!又是这个学校的
  16. FENeRF: Face Editing in Neural Radiance Fields
  17. 引用 《大明宫词》经典台词89句
  18. 三种架构模式——MVC、MVP、MVVM
  19. c++ 11 thead
  20. java拆分excel_Java 合并和拆分Word表格中的单元格

热门文章

  1. C六:指针可以比较大小
  2. Logtail提升采集性能
  3. 什么样的GPS定位系统最适合做二次开发
  4. iOS程序健壮性笔记
  5. windows+sublime text3+MINGW编译运行c
  6. Linux apt-get命令
  7. 中国电信发布转型升级新战略 要做领先的综合智能信息服务运营商
  8. Linux操作系统下如何编译安装源码包软件
  9. CentOS使用yum安装Docker
  10. Discuz!UCenter创始人密码重置方法