欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript的React Web庫的理念剖析及基礎(chǔ)上手指南

 更新時間:2016年05月10日 15:34:09   作者:于江水  
這篇文章主要介紹了JavaScript的React Web庫的理念剖析及基礎(chǔ)上手指南,React Web的目的即是把本地的React Native應(yīng)用程序項目變?yōu)閃eb應(yīng)用程序,需要的朋友可以參考下

React Web的目的及意義非常明確: 讓React Native代碼跑在Web上 讓一套代碼運行在各個移動終端,對前端及業(yè)務(wù)來說,這是開發(fā)效率中一個質(zhì)的提升。在項目初期,我們也曾向 React團(tuán)隊咨詢過類似的問題,他們團(tuán)隊的核心同學(xué) @vjeux 也認(rèn)為這是非??岬氖虑?,也是他們未來想做的事情。也許在發(fā)布React Native for Android的時候,也會發(fā)布React Web也說不定。(YY一下)
技術(shù)架構(gòu)
基于React Native的適配方案,有幾個:
1.制定一個Bridge標(biāo)準(zhǔn),RN與RW 各自用最優(yōu)的方式實現(xiàn)這套標(biāo)準(zhǔn)。
比如基于Flex布局,我們實現(xiàn)一套一致的 Flex Component, <Flex> 、<Cell> 等。
2.完全向RN看齊,RW實現(xiàn)RN的所有能實現(xiàn)的API。
在討論中,最終選擇了后者。
因為React Web的理念,讓React Native代碼跑在Web端,那么就決定了RW只是一個構(gòu)建及打包工具,脫離RN,RW的實現(xiàn)則沒有太大的意義,那么整體的技術(shù)方向就非常明確了: 實現(xiàn)RN一致的Style、Component及API,最終通過構(gòu)建工具編譯成web版本。

2016510152622276.png (550×307)

示例

下面我們來看一下React Web項目的創(chuàng)建過程:
第一步:安裝 React web 并進(jìn)行相關(guān)配置
這一步操作主要是安裝 react-web 包以及相關(guān)依賴,并配置 webpack 打包腳本等。
為了簡化這一步操作,我們開發(fā)了命令行工具 react-web-cli 只需要執(zhí)行兩行命令即可。同時命令行工具還支持啟動調(diào)試服務(wù)器、打包等功能,在后面介紹。
安裝 cli 工具:

npm install react-web-cli -g

安裝配置 React web 等:

react-web init <當(dāng)前項目目錄>

執(zhí)行完成之后,會在你項目目錄下面 npm install 相關(guān)庫,并自動創(chuàng)建 web/webpack.config.js 文件,里面有一份寫好的配置。此時目錄結(jié)構(gòu)為:

.
├── README.md
├── android/
├── index.android.js
├── index.ios.js
├── ios/
├── package.json
└── web/
 └── webpack.config.js

第二步:添加入口文件并進(jìn)行相關(guān)配置
每個項目都需要有一個入口文件,通常用來引入調(diào)用其他組件并初始化項目,比如 index.ios.js 表示 iOS 平臺上的該項目的入口文件。為了符合 React Native 的文件命名規(guī)范,我們創(chuàng)建一個 index.web.js 作為入口文件,并且需要在 webpack 中指定該文件為入口文件。打開 web/webpack.config.js 文件,修改 config 變量:

var config = {
 paths: {
 src: path.join(ROOT_PATH, '.'),
 index: path.join(ROOT_PATH, 'index.web'),
 },
};

然后我們創(chuàng)建 index.web.js 文件。這個文件其實跟 index.ios.js 非常像,只是略有不同。主要區(qū)別在于:iOS 只需要 AppRegistry.registerComponent('Awes', () => Awes); 即可讓 Xcode 的 Native 代碼接收處理你的 JS 代碼,而 Web 端是需要插入到 DOM 節(jié)點中才可以用。因此我們需要在 index.web.js 最下面添加如下代碼:

AppRegistry.registerComponent('Awes', () => Awes);
if (Platform.OS == 'web') {
 var app = document.createElement('div');
 document.body.appendChild(app);
 AppRegistry.runApplication('Awes', {
 rootTag: app
 });
}

然后在最上面 require 部分需要引入 Platform 組件。這樣配置部分就已經(jīng)處理完成了,執(zhí)行 react-web start 命令即可啟動調(diào)試服務(wù)器啦!

2016510152827702.jpg (832×1388)

可以隨便修改試下,跟 React Native 模擬器里面的體驗幾乎一樣。
第三步:測試并打包 Web 版本代碼
當(dāng)你修改開發(fā)完,并對 Web 端也測試好了,就可以打包發(fā)布了。react-web-cli 工具打包的命令是:

react-web bundle

打包完成后,文件會存放在 web/output/ 目錄下面,可以直接打開 index.html (如果 app 有請求操作,需要起本地服務(wù)器查看),再檢查一下就可以發(fā)布了。
這個過程中發(fā)生了什么?
好奇的同學(xué)看到這里可能會有一些疑問,上面命令行工具的一些命令做了什么事情?為什么 React web 將 React Native 代碼打包出一份用在 Web 端的代碼?React web 安全可靠嗎,里面都是什么東西?
這里簡單的介紹下 React web 的實現(xiàn)原理和上面步驟實際做的事情。
React Web 將 React Native 組件做了 Web 端的實現(xiàn)
React 將代碼與平臺環(huán)境分離,多了一層,這樣開發(fā)者可以在平臺環(huán)境層面做一些處理,使得同樣一份代碼適應(yīng)更多的平臺環(huán)境等。
比如 react-canvas 按照 React 的語法書寫代碼,在平臺環(huán)境層面做一些處理(將你 React 代碼運行并用 canvas 渲染),然后實現(xiàn)特定目標(biāo)(在移動端提高性能)。
React Native 中,一份代碼能同時跑在 iOS 和 Android 上面,也是一樣的道理。React Native 團(tuán)隊在對應(yīng)平臺的 Native app 上面做了一些處理,使其可以解析執(zhí)行 React 語法的代碼。
還有同構(gòu)(isomorphic)的應(yīng)用,服務(wù)器端使用 React + Node.js 生成 HTML,客戶端使用 React 獲取進(jìn)行客戶端相關(guān)交互和功能,也是一樣的道理。
為此, React v0.14.x 版本開始,專門分成兩個庫 react 和 react-dom ,其實是把對瀏覽器平臺的特殊處理剝離了出來,單獨變成了 react-dom 庫。
React Native 比較特殊的地方在于,組件最底層的實現(xiàn)是 Native 的實現(xiàn),所以就不支持 span、div 等標(biāo)簽。而動畫等,也是直接調(diào)用 Native 進(jìn)行界面渲染。所以不支持 Web 端,但是絕大部分組件,都是可以用 Web 技術(shù)進(jìn)行模擬實現(xiàn)。動畫可以用 CSS3 、基礎(chǔ)元素可以用同等 HTML 標(biāo)簽?zāi)M、布局以及兼容性問題可以用 CSS 來處理,所以 React web 只需要把 React Native 的組件用 Web 技術(shù)重新實現(xiàn)一遍,借助 React 這一層,即可實現(xiàn)一份代碼運行在多個平臺上面。
舉一個非常簡單的例子,Text 組件:
React Native 的實現(xiàn) 是調(diào)用了很多 React Native 底層的代碼實現(xiàn)的。
對于 Web 端,輸出一行文本使用 <span> 標(biāo)簽即可,所以 React web 的實現(xiàn) 就直接搞一個 <span> 標(biāo)簽,綁一些事件什么的就 OK 了。
在 UI Explorer demo 中能跑起來的 React Native 組件,你都可以放心的用。
webpack 幫你切換打包目標(biāo)
做出了兼容 Web 端的組件,那打包的時候豈不是要把所有要打包的組件中的 require('react-native') 全部更換成 require('react-web')?不然怎么用的我的 Web 組件打包?
強(qiáng)大的 webpack 附帶了 alias 配置項可以幫你解決這個問題:

resolve: {
 alias: {
 'react-native': 'react-web',
 'ReactNativeART': 'react-art',
 },
 extensions: ['', '.js', '.jsx'],
},

這樣在打包時,但凡 require('react-native') 的地方全都用 react-web 包替換,而 react-web 的 module.exports 與 react-native 的保持一致即可讓代碼不替換也可以工作。
此外配合插件還可以實現(xiàn)另外一種引入方法,請看下面。
通過 Haste 方法引入組件以提高性能
webpack 以及其他的支持 CommonJS 規(guī)范的打包工具,都會把文件中 require 的所有組件都打包在一起。對于 React Native 來說代碼體積大小無關(guān)緊要,而在 Mobile web 來說,就要稍微重要一些了。特別是如果你的項目只需要 Text 組件,但由于 require('react-web') 結(jié)果把所有的組件全部打包進(jìn)來了,就比較傷感。
基于 webpack 插件,還可以用另一種方式引入組件以解決這個問題,你可以叫它 Haste 方式。使用這種方式需要加載 webpack 插件 haste-resolver-webpack-plugin,默認(rèn)的 webpack 配置已經(jīng)幫你加載好了,你可以直接在組件里面這樣用:

var Text = require('ReactText');

而不是以前那樣:

var {Text} = require('react-native');

這樣 webpack 打包時,對于前者,只會把那一個組件內(nèi)容打包進(jìn)來,因此可以減小體積、提升性能。這是怎么實現(xiàn)的呢?
加載了插件的 webpack 打包時,會先掃描所有組件并讀取組件頭部 @providesModule 的信息(比如 Text 組件的信息),然后當(dāng)其他文件中 require 了這個組件名稱,就會自動定位到這個文件進(jìn)行打包。同時還可以區(qū)分平臺,即便是同一個名字,打包時會區(qū)分平臺去打包對應(yīng)的文件(根據(jù) index.xxx.js 的命名規(guī)則確定文件)。

相關(guān)文章

  • React實現(xiàn)pc端的彈出框效果

    React實現(xiàn)pc端的彈出框效果

    這篇文章主要為大家詳細(xì)介紹了React實現(xiàn)pc端的彈出框效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • React官方團(tuán)隊完善原生Hook閉包陷阱

    React官方團(tuán)隊完善原生Hook閉包陷阱

    這篇文章主要為大家介紹了React官方團(tuán)隊出手,補(bǔ)齊原生Hook短板閉包陷阱的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • React觸發(fā)render的實現(xiàn)方法

    React觸發(fā)render的實現(xiàn)方法

    這篇文章主要介紹了React觸發(fā)render的實現(xiàn)方法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • React 的調(diào)和算法Diffing 算法策略詳解

    React 的調(diào)和算法Diffing 算法策略詳解

    React的調(diào)和算法,主要發(fā)生在render階段,調(diào)和算法并不是一個特定的算法函數(shù),而是指在調(diào)和過程中,為提高構(gòu)建workInProcess樹的性能,以及Dom樹更新的性能,而采用的一種策略,又稱diffing算法
    2021-12-12
  • React state狀態(tài)屬性用法講解

    React state狀態(tài)屬性用法講解

    React將組件(component)看成一個狀態(tài)機(jī)(State Machines),通過其內(nèi)部自定義的狀態(tài)(State)和生命周期(Lifecycle)實現(xiàn)并與用戶交互,維持組件的不同狀態(tài)
    2022-11-11
  • 在Create React App中啟用Sass和Less的方法示例

    在Create React App中啟用Sass和Less的方法示例

    這篇文章主要介紹了在Create React App中啟用Sass和Less的方法示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • React組件的應(yīng)用介紹

    React組件的應(yīng)用介紹

    React組件分為函數(shù)組件與class組件;函數(shù)組件是無狀態(tài)組件,class稱為類組件;函數(shù)組件只有props,沒有自己的私有數(shù)據(jù)和生命周期函數(shù);class組件有自己私有數(shù)據(jù)(this.state) 和 生命周期函數(shù)
    2022-09-09
  • React應(yīng)用中使用Bootstrap的方法

    React應(yīng)用中使用Bootstrap的方法

    本篇文章主要介紹了React應(yīng)用中使用Bootstrap的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08
  • React.js綁定this的5種方法(小結(jié))

    React.js綁定this的5種方法(小結(jié))

    this在javascript中已經(jīng)相當(dāng)靈活,這篇文章主要介紹了React.js綁定this的5種方法(小結(jié)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • React報錯Type '() => JSX.Element[]' is not assignable to type FunctionComponent

    React報錯Type '() => JSX.Element[]&apos

    這篇文章主要為大家介紹了React報錯Type '() => JSX.Element[]' is not assignable to type FunctionComponent解決,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12

最新評論