據說,當使用Reactjs的時候,Gulp和Browserify很配哦

在生產環境中若是依靠前端引用JSXTransformer.js文件來實現JSXJavaScript的轉換,那是絕對不靠譜的。因此,使用Reactjs的童鞋就須要使用更有逼格的方式來完成這項任務。做爲如今最經常使用的前端構建工具gulp搭配上Browserify來搞定這個問題那真是拉風的不要不要的 :)html

廢話很少說,我們來點直接的吧。前端

源代碼

咱們此次的任務就是讓這段滿目瘡痍的源代碼變得更優化,千里之行,這是開始。若是有童鞋看不懂這段代碼是用來作神馬的,那麼我只能說,「媽媽叫你回家看基礎了。」回家之路(看不懂代碼的,請猛戳)。react

<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,內容以下:chrome

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中,內容以下:npm

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

module.exports = Child;

寫到這裏,咱們已經將兩個組件作了初步的拆分,若是有童鞋對module.exports是神馬仍是隻知其一;不知其二或者根本不懂這是要搞什麼飛機,那麼請去百度自行谷歌commonjs,相信度娘會很嫵媚的幫你解惑。gulp

若是要真正讓元器件顯示在頁面上須要執行React.render函數,這個是寫在js/app.js中的,內容以下:segmentfault

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

作到這裏,咱們還順帶了作了一件頗有意義的事情,就是對文件文件目錄作了優化,組件放置在/components文件夾中,啓動放置在根目錄/js下,清晰明瞭。app

使用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》

相關文章
相關標籤/搜索