利用browserify和gulp来构建react应用

简介:

JS的世界发展的非常快,有很多好用的框架,工具层出不穷,今天就来说说怎么结合browserify,gulp,react来构建前端应用.


下面我们先一一简单介绍下browserify,gulp,react

Browserify

browserify是一个以commonjs规范来定义模块的打包工具.

browserify是一个开发工具,它允许我们以nodejs的代码风格来定义我们的模块,使用module.exports来导出模块功能,使用require来请求某个模块,跟amd规范不一样的是,我们不需要在模块外层包装一个define,可以完全跟nodejs后端模块通用,保持单个功能模块的重用性.

下面以一个简单的使用例子来说明下browserify的用法,假定下面两文件为兄弟关系

  • module.js, 定义一个模块
module.exports = {
    name: 'feenan'
};
  • app.js, 来使用上面的模块
var mod = require('./module');
console.log(mod.name);
  • 使用,运行bowserify app.js>bundle.js

  • 最后建立一个静态页面,只需引用上面的bundle.js文件就可以.

Gulp

gulp是一个流构建工具,不同于grunt的是,前者是以代码优于配置的,而且不像grunt那样需要中间文件目录来方便后续任务的调用,gulp利用流和管道思想,极大的提高了构建效率,下面以一个简单的Gulpfile.js来说明它的用法

  • 下面的任务是用来预处理.styl样式文件为.css文件
// 加载gulp模块
var gulp = require('gulp');
// 加载stylus gulp插件
var stylus = require('gulp-stylus');
// 定义要处理的文件路径信息.
var paths = {
  css: ['src/css/**/*.styl']
};
// 开始定义任务
gulp.task('css', function() {
  return gulp.src(paths.css)
    .pipe(stylus())
    .pipe(gulp.dest('./src/css'));
});
// 定义默认任务,方便使用 gulp命令直接调用
gulp.task('default', ['css']);
  • 运行上面命令直接用 gulp就可以

React

reactfacebook发起创建的一个UI框架,通常被认为是MVC框架里的V,不过我喜欢把它理解为MVVM里的VM,因为它支持自动更新视图,利用内部的state属性,跟angularjs不一样的是,react更关注视图的渲染,所以它不是一个框架,只是一个ui库,可以非常方便的嵌入到第三方MVV*框架中去.

然后react使用了一个叫JSX的语法库来支持html元素的编写,下面放上一个简单的例子让大家对react有一个大概的了解

/** @jsx React.DOM */
var HelloMessage = React.createClass({
  render: function() {
    return <div>Hello {this.props.name}</div>;
  }
});

React.renderComponent(<HelloMessage name="John" />, mountNode);

上面的代码应该放在<script type="text/jsx"></script>里,这里的type=text/jsx当里面的代码没有预处理的话是需要加上的,然后/** @jsx React.DOM */这个注释也是必填项,格式也得按照这个来写

下面以一个完整的例子来讲解三者之前的运用

完整的例子

主要分以下几步:

  • 先以jsxjs规格来定义commonjs规范的模块
  • 编写Gulpfile.js来预处理jsx文件,然后利用browserify来打包文件,最后压缩

一个普通的cjs规范的模块,data.js

module.exports = {
    name: 'hello tina!',
    getName: function(){
        var r = Math.floor(Math.random() * 40 + 10);
        return 'hello ' + r;
    }
}

一个JSX格式的cjs规范的模块,module.jax,它依赖react,以及上面定义的普通模块

/** @jsx React.DOM */
var React = require('react');  // Browserify!
var data = require('./data');
var HelloMessage = React.createClass({  // Create a component, HelloMessage.
      render: function() {
        return <div>Hello {data.getName()}</div>;  // Display a property.
      }
});

module.exports = {
    invoke: function(){
        React.renderComponent(  // Render HelloMessage component at #name.
          <HelloMessage name="feenan" />,
          document.querySelector('body'));
    }
}

一个启动应用的app.js文件

var app = require('./module.jsx');
app.invoke();

然后我们来编写我们Gulpfile.js

/* gulpfile.js */

// Load some modules which are installed through NPM.
var gulp = require('gulp');
var browserify = require('browserify');  // Bundles JS.
var del = require('del');  // Deletes files.
var reactify = require('reactify');  // Transforms React JSX to JS.
var source = require('vinyl-source-stream');
var streamify = require('gulp-streamify');
var uglify = require('gulp-uglify');

// Define some paths.
var paths = {
  app_js: ['./src/js/app.js']
};

// An example of a dependency task, it will be run before the css/js tasks.
// Dependency tasks should call the callback to tell the parent task that
// they're done.
gulp.task('clean', function(done) {
  del(['build'], done);
});


// Our JS task. It will Browserify our code and compile React JSX files.
gulp.task('js', ['clean'], function() {
  // Browserify/bundle the JS.
  browserify(paths.app_js)
    .transform(reactify)
    .bundle()
    .pipe(source('bundle.js'))
    // .pipe(streamify(uglify()))
    .pipe(gulp.dest('./src/'));
});

// Rerun tasks whenever a file changes.
gulp.task('watch', function() {
  gulp.watch(paths.js, ['js']);
  gulp.watch(paths.app_js, ['js']);
});

// The default task (called when we run `gulp` from cli)
gulp.task('default', ['watch', 'js']);

上面的脚本实现了自动监听文件改变,然后自动预处理jsx文件,browserify打包文件,uglify压缩文件

关于例子里的npm模块依赖都可以从文件里找出来,然后使用命令npm install [module_name]安装就可以

总结

react是一个不错的UI库,可以方便的与backbone结合从而解决它里面视图功能的薄弱性,结合browserify,可以实现前后端js代码的重用性,gulp相比grunt来说性能与配置代码量就能得到很大的提升,有兴趣的话大家可以多用用它们.

相关参考资料:

目录
相关文章
|
2月前
|
前端开发 JavaScript 开发者
使用React和Redux构建高效的前端应用
使用React和Redux构建高效的前端应用
60 1
|
2月前
|
前端开发 JavaScript 开发者
从零开始构建你的第一个React应用
从零开始构建你的第一个React应用
39 2
|
2月前
|
资源调度 前端开发 数据可视化
构建高效的数据可视化仪表板:D3.js与React的融合之道
【10月更文挑战第25天】在数据驱动的时代,将复杂的数据集转换为直观、互动式的可视化表示已成为一项至关重要的技能。本文深入探讨了如何结合D3.js的强大可视化功能和React框架的响应式特性来构建高效、动态的数据可视化仪表板。文章首先介绍了D3.js和React的基础知识,然后通过一个实际的项目案例,详细阐述了如何将两者结合使用,并提供了实用的代码示例。无论你是数据科学家、前端开发者还是可视化爱好者,这篇文章都将为你提供宝贵的洞见和实用技能。
83 5
|
2月前
|
前端开发 JavaScript Android开发
掌握React Native,构建跨平台移动应用的利器
掌握React Native,构建跨平台移动应用的利器
|
2月前
|
前端开发 JavaScript API
React Native实战:构建跨平台移动应用
React Native实战:构建跨平台移动应用
56 0
|
2月前
|
前端开发 JavaScript 网络架构
从零开始构建你的第一个React应用
从零开始构建你的第一个React应用
28 0
|
2月前
|
前端开发 JavaScript 开发者
从零构建你的第一个React应用
从零构建你的第一个React应用
24 0
|
8月前
|
设计模式 前端开发 数据可视化
【第4期】一文了解React UI 组件库
【第4期】一文了解React UI 组件库
421 0
|
8月前
|
存储 前端开发 JavaScript
【第34期】一文学会React组件传值
【第34期】一文学会React组件传值
89 0
|
8月前
|
资源调度 前端开发 JavaScript
React 的antd-mobile 组件库,嵌套路由
React 的antd-mobile 组件库,嵌套路由
146 0