日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

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

發(fā)布時間:2025/5/22 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 听说,当使用Reactjs的时候,Gulp和Browserify很配哦 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

在生產(chǎn)環(huán)境中如果依靠前端引用JSXTransformer.js文件來實現(xiàn)JSX向JavaScript的轉(zhuǎn)換,那是絕對不靠譜的。所以,使用Reactjs的童鞋就需要使用更有逼格的方式來完成這項任務。作為現(xiàn)在最常用的前端構(gòu)建工具gulp搭配上Browserify來搞定這個問題那真是拉風的不要不要的 :)

廢話不多說,咱們來點直接的吧。

源代碼

我們這次的任務就是讓這段滿目瘡痍的源代碼變得更優(yōu)化,千里之行,這是開始。如果有童鞋看不懂這段代碼是用來做神馬的,那么我只能說,“媽媽叫你回家看基礎(chǔ)了。”回家之路(看不懂代碼的,請猛戳)。

<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>

優(yōu)化

前面把兩個組件都寫到一塊了,現(xiàn)在來分割成獨立的文件。其中一個命名為js/components/Parent.jsx,內(nèi)容如下:

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中,內(nèi)容如下:

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

寫到這里,我們已經(jīng)將兩個組件做了初步的拆分,如果有童鞋對module.exports是神馬還是一知半解或者根本不懂這是要搞什么飛機,那么請去百度自行谷歌commonjs,相信度娘會很嫵媚的幫你解惑。

如果要真正讓元器件顯示在頁面上需要執(zhí)行React.render函數(shù),這個是寫在js/app.js中的,內(nèi)容如下:

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

做到這里,我們還順帶了做了一件很有意義的事情,就是對文件文件目錄做了優(yōu)化,組件放置在/components文件夾中,啟動放置在根目錄/js下,清晰明了。

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

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

所有依賴的js內(nèi)容未來都會被編譯到bundle.js文件中。

安裝 Browserify

工欲善其事,必先利其器。如果還沒有安裝gulp的童鞋可以參考我曾經(jīng)寫的《這年頭,不用點道具(gulp),你都不好意思說你是做前端的》來安裝一下(名字略長略長,但有沒有很貼心,服務就是要做全套嘛)。

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

gulp -v

輸出結(jié)果大概如下面這個這樣子的話,那就說明你已經(jīng)成功安裝了gulp。

CLI version 3.9.0 Local version 3.9.0

在這個基礎(chǔ)上,進入項目目錄還需要來局部安裝 gulp ,browserify 以及相關(guān)的輔助工具:

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

使用Mac的童鞋不要忘記加sudo喲。

說一下上面四個包的各自作用:

  • gulp 是任務運行環(huán)境,用來進行任務調(diào)度

  • browserify 用來 require js 的模塊

  • vinyl-source-stream 把 browserify 輸出的數(shù)據(jù)進行準換,使之流符合 gulp 的標準

  • reactify 使用它來實現(xiàn) JSX 編譯功能

然后到 gulpfile.js 中,填寫如下內(nèi)容:

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 寫的包,所有它輸出的數(shù)據(jù)流并不能直接 pipe 給 gulp 使用,所以,需要用到 source()接口,也就是 vinyl-source-stream 這個工具來處理一下,然后 pipe 給 gulp ,gulp.dest 會把輸出的 bundle.js 文件保存到 js 文件夾中。

任務寫好了,在命令行執(zhí)行:

gulp jsx

這樣就生成了 js/bundle.js 文件了。由于這個文件的標簽已經(jīng)添加到 index.html 中了,所以直接用 chrome 打開就可以看到運行效果了。

文章改編自《當 React 遇見 Gulp 和 Browserify》

總結(jié)

以上是生活随笔為你收集整理的听说,当使用Reactjs的时候,Gulp和Browserify很配哦的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。