亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS端React Native差異化增量更新的實現方法

2020-07-26 02:26:48
字體:
來源:轉載
供稿:網友

前言

作為一名iOS原生開發工程師,通過一個禮拜的面試之后發現,原來并不想學的react-native真的是火的一塌糊涂,坐標:杭州,很多公司招聘iOS開發除了原來的OC和Swift,多了一門新語言:react-native,真的是要人老命啊,Swift4.0剛剛看完,又得花時間學RN。入職之后也開始學react-native,算是小白一枚,下面是我的個人總結,有大神看出錯誤,請不要打我或者罵我,聯系我郵箱dadadoubi@qq.com。

RN具有的優勢有很多,跨平臺開發,一套代碼Android和iOS通用,熱更新,不用一直等蘋果爸爸慢吞吞的審核流程,所謂工欲善其事,必先利其器,RN的熱更新部署肯定得學下,今天就總結一下一個剛學RN的小白對熱更新的理解。

個人理解,RN的熱更新有點類似App的版本更新,app內版本號與server端匹配,來判斷是否要更新,替換加載的jsbundle文件,然后加載新的jsbundle文件來實現版本更新,那么實質上就是把app內要加載的jsbundle文件替換掉就OK了。

原理分析

簡單介紹了一下原理,那么廢話不多說,直接開始寫了,這篇文章主要講的是前面兩步:jsbundle的打包命令和差異化的比較

react-native打ios離線包

打包命令說明

react-native bundleOptions:--entry-file <path>   Path to the root JS file, either absolute or relative to JS root(一般為index.js文件)--platform [string]   Either "ios" or "android"(RN入口文件的路徑, 絕對路徑或相對路徑)--transformer [string]  Specify a custom transformer to be used--dev [boolean]    If false, warnings are disabled and the bundle is minified(如果為false, 警告會不顯示并且打出的包的大小會變小,默認為--dev true)--prepack     When passed, the output bundle will use the Prepack format.(當通過時, 打包輸出將使用Prepack格式化,默認為--prepack false)--bridge-config [string]  File name of a a JSON export of __fbBatchedBridgeConfig. Used by Prepack. Ex. ./bridgeconfig.json(使用Prepack的一個json格式的文件__fbBatchedBridgeConfig 例如: ./bridgeconfig.json) --bundle-output <string>  File name where to store the resulting bundle, ex. /tmp/groups.bundle(打包后的文件輸出目錄, 例: /tmp/groups.bundle)--bundle-encoding [string] Encoding the bundle should be written in (https://nodejs.org/api/buffer.html#buffer_buffer).[default: "utf8"](打離線包的格式 可參考鏈接https://nodejs.org/api/buffer.html#buffer_buffer.默認為utf-8格式)---sourcemap-output [string] File name where to store the sourcemap file for resulting bundle, ex. /tmp/groups.map(生成Source Map,但0.14之后不再自動生成source map,需要手動指定這個參數。例: /tmp/groups.map)--assets-dest [string]  Directory name where to store assets referenced in the bundle(打包時圖片資源的存儲路徑)--verbose     Enables logging(顯示打包過程)--reset-cache    Removes cached files(移除緩存文件)--config [string]   Path to the CLI configuration file(命令行的配置文件路徑)

事實上上面打包命令說明不看也沒事,下面是具體操作

1. cd [項目路徑]

2.  在react-native根目錄下的ios目錄下新建bundle文件夾(mkdir ./ios/bundle)(注意:輸入打包命令前必須先新建bundle文件夾)

3. 打包命令:react-native bundle --entry-file index.js --platform ios --dev false --bundle-output ./ios/bundle/index.ios.jsbundle --assets-dest ./ios/bundle/

4. 結果展示![clipboard.png](/img/bV8rS9)

當rn項目中有引用圖片資源時,打包出來為下面示意圖(如果圖片資源是在xcode工程內部時則不會生成)

patches.pad差異化文件終端生成方案

利用google的diff文件(資料查出來,這個比較受歡迎,同時也兼容Objective-C),github地址:https://github.com/google/dif...

1.終端輸入:git clone https://github.com/LiuC520/nodediffpatch.git

2.終端輸入:cd nodediffpatch && npm i

3.終端輸入:sudo npm link

4.把新舊文件放入nodediffpatch/patch目錄下

5.終端輸入:patbundle patch -o test01old.jsbundle -n test01new.jsbundle

這樣,用終端的生成差異化文件就OK了。

iOS實現生成差異化文件

首先,得先把diff-match-patch下載下來,需要集成它

集成有優化方案有大神知道的話跟我說一下,我反正是用很粗糙的做法,將它的類直接拖入你的工程中,不知道的也可以用我的方式。簡單在,直接,嘿嘿!

把這些文件拖入到工程中,選擇create group方式,(別噴,要臉,是在不知道怎么集成)“集成”后的項目結構

然后導入(#import "DiffMatchPatch.h")就可以開始用了,下面演示用l1.txt和l2.txt文件來展示,可以比較直觀的看出效果

l1.txt文本:123

l2.txt文本:12345

- (void)demo1{ // 獲取l1.txt文件路徑 NSString *path01 = [[NSBundle mainBundle]pathForResource:@"l1" ofType:@"txt"]; // 根據l1.txt文件路徑獲取data內容 NSData *data01 = [NSData dataWithContentsOfFile:path01]; // 將data內容轉換成字符串格式 NSString *str01 = [[NSString alloc] initWithData:data01 encoding:NSUTF8StringEncoding]; // 獲取l2.txt文件路徑 NSString *path02 = [[NSBundle mainBundle]pathForResource:@"l2" ofType:@"txt"]; // 根據l2.txt文件路徑獲取data內容 NSData *data02 = [NSData dataWithContentsOfFile:path02]; // 將data內容轉換成字符串格式 NSString *str02 = [[NSString alloc] initWithData:data02 encoding:NSUTF8StringEncoding]; // 創建DiffMatchPatch工具類對象 DiffMatchPatch *patch = [[DiffMatchPatch alloc]init]; // 對比文件內容 // 執行該語句之后會在bundle目錄下生成patches.bat文件(差異補丁文件) NSMutableArray *patchesArr = [patch diff_mainOfOldString:str01 andNewString:str02 checkLines:YES]; // 生成差異補丁包 NSArray *patchesArr1 = [patch patch_makeFromDiffs:patchesArr]; // 解析補丁包 NSArray *newArray = [patch patch_apply:patchesArr1 toString:str01]; //寫入到新文件(注意:這邊為了在PC端更加直觀的看,直接寫入到絕對路徑) BOOL isTrue = [newArray[0] writeToFile:@"/Users/devil/Desktop/自己的/RNPlatForm/ios/l1.txt" atomically:YES encoding:NSUTF8StringEncoding error:nil]; if (isTrue) { NSLog(@"寫入成功"); }else{ NSLog(@"寫入失敗"); }}

執行代碼后:

l1.txt文本:12345

當然,你可以打印一下path01路徑字符串,在這個路徑下會生成patches.pat差異化文件,我執行的時候打斷點發現

NSMutableArray *patchesArr = [patch diff_mainOfOldString:str01 andNewString:str02 checkLines:YES];

執行該語句之后生成,但是用[[NSBundle mainBundle]pathForResource:@"patches" ofType:@"pat"];訪問不到文件,有大神知道什么原因可以跟我說下。

iOS實現patches.pat與舊jsbundle離線包合并得到新的jsbundle離線包

- (void)demo2{ // 獲取l1.txt文件路徑 NSString *path01 = [[NSBundle mainBundle]pathForResource:@"l1" ofType:@"txt"]; // 根據l1.txt文件路徑獲取data內容 NSData *data01 = [NSData dataWithContentsOfFile:path01]; // 將data內容轉換成字符串格式 NSString *str01 = [[NSString alloc] initWithData:data01 encoding:NSUTF8StringEncoding]; // 創建DiffMatchPatch工具類對象 DiffMatchPatch *patch = [[DiffMatchPatch alloc]init]; // 獲取差異化文件包路徑 NSString *patchesPath = [[NSBundle mainBundle]pathForResource:@"patches.pat" ofType:nil]; //獲取差異化文件內容 NSData *patchesData = [NSData dataWithContentsOfFile:patchesPath]; //解析差異化文件內容 NSString *patchesStr = [[NSString alloc]initWithData:patchesData encoding:NSUTF8StringEncoding]; //轉換pat NSMutableArray *patchesArr = [patch patch_fromText:patchesStr error:nil]; // 解析補丁包 NSArray *newArray = [patch patch_apply:patchesArr toString:str01]; //獲取新文件路徑// NSString *newFilePath = [[NSBundle mainBundle]pathForResource:@"text3" ofType:@"txt"]; //寫入到新文件(注意:這邊為了在PC端更加直觀的看,直接寫入到絕對路徑) BOOL isTrue = [newArray[0] writeToFile:@"/Users/devil/Desktop/自己的/RNPlatForm/ios/text3.txt" atomically:YES encoding:NSUTF8StringEncoding error:nil]; if (isTrue) { NSLog(@"寫入成功"); }else{ NSLog(@"寫入失敗"); }}

實現本地更新離線包

//創建兩個按鈕,第一個按鈕跳轉RN界面,加載jsbundle包,第二個按鈕負責更新jsbundle包UIButton *btn4 = [[UIButton alloc]init]; [btn4 setTitle:@"第五個" forState:UIControlStateNormal]; [btn4 setTitleColor:[UIColor blackColor] forState:UIControlStateNormal]; btn4.frame = CGRectMake(40, 170, 60, 30); [btn4 addTarget:self action:@selector(clickFifth) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:btn4];  UIButton *btn5 = [[UIButton alloc]init]; [btn5 setTitle:@"更新第五個界面" forState:UIControlStateNormal]; [btn5 setTitleColor:[UIColor blackColor] forState:UIControlStateNormal]; btn5.frame = CGRectMake(40, 200, 60, 30); [btn5 addTarget:self action:@selector(demo2) forControlEvents:UIControlEventTouchUpInside]; [self.view addSubview:btn5];//btn4按鈕點擊事件- (void)clickFifth{ NSURL *jsCodeLocation; jsCodeLocation = [[NSBundle mainBundle]URLForResource:@"test01old" withExtension:@"jsbundle"]; [self creactRNPath:jsCodeLocation moduleName:@"test01platcode"]; }- (void)creactRNPath:(NSURL *)jsCodeLocation moduleName:(NSString *)moduleName{ RCTRootView *rootView = [[RCTRootView alloc] initWithBundleURL:jsCodeLocation              moduleName:moduleName            initialProperties:nil

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對武林網的支持。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91久久精品视频| 中文字幕日韩av| 亚洲国产另类久久精品| 久久综合伊人77777尤物| 久热在线中文字幕色999舞| 日韩a**站在线观看| 亚洲欧美精品一区二区| 国产z一区二区三区| 国产精品露脸av在线| 欧美性xxxx在线播放| 97色在线播放视频| 精品视频在线播放色网色视频| 欧美激情极品视频| www.xxxx欧美| 亚洲国产精品va在看黑人| 亚洲一区二区三区成人在线视频精品| 成人av在线网址| 国产第一区电影| 91久久久久久久一区二区| 91精品国产综合久久香蕉最新版| 91人人爽人人爽人人精88v| 日本韩国欧美精品大片卡二| 亚洲最新视频在线| 91午夜理伦私人影院| 亚洲国产精品久久久| 国模吧一区二区三区| 一区二区三区回区在观看免费视频| 97国产一区二区精品久久呦| 亚洲最大成人在线| 深夜福利91大全| 欧美性猛交xxxx免费看漫画| 精品偷拍一区二区三区在线看| 日韩成人在线电影网| 中文在线不卡视频| 精品久久香蕉国产线看观看亚洲| 久久久久久久久久久免费精品| 亚洲成人网久久久| 日韩免费在线免费观看| 日韩女优人人人人射在线视频| 美女av一区二区| 国产精品va在线| 亚洲成色777777在线观看影院| 欧美激情一区二区三区成人| 国产精品入口尤物| 久久精品99久久久香蕉| 欧美电影在线免费观看网站| 国产精品一区二区三区在线播放| 国产精品久久久久久久久免费看| 在线精品国产欧美| 一区二区欧美久久| 欧美一区二区三区免费视| 欧美有码在线观看| 日韩中文字幕在线视频| 成人a免费视频| 国产亚洲激情在线| 一本久久综合亚洲鲁鲁| 欧美日韩在线免费| 91丝袜美腿美女视频网站| 日韩精品亚洲视频| 日本精品性网站在线观看| 日韩免费视频在线观看| 国模视频一区二区三区| 午夜精品久久久久久久99热浪潮| 日韩美女视频免费在线观看| 日韩av综合中文字幕| 国产激情久久久久| 国产精品日韩专区| 欧洲精品久久久| 欧美—级a级欧美特级ar全黄| 国产亚洲一区二区在线| 热久久99这里有精品| 亚洲综合日韩中文字幕v在线| 日韩中文娱乐网| 另类视频在线观看| 96pao国产成视频永久免费| 国产伦精品一区二区三区精品视频| 日本一本a高清免费不卡| 国产精品视频成人| 精品国产成人在线| 热99精品只有里视频精品| 国产国语刺激对白av不卡| 欧美日产国产成人免费图片| 国产欧美一区二区白浆黑人| 日本韩国在线不卡| 国产自产女人91一区在线观看| 欧美一区二区.| 神马久久久久久| 国产欧美精品一区二区三区-老狼| 奇米一区二区三区四区久久| 蜜臀久久99精品久久久久久宅男| 欧美国产一区二区三区| 日韩中文字幕第一页| 久久精品电影一区二区| 国产精品老女人精品视频| 日韩av电影在线播放| 色哟哟亚洲精品一区二区| 91超碰中文字幕久久精品| 久久久亚洲国产天美传媒修理工| 亚洲剧情一区二区| 欧美午夜精品久久久久久浪潮| 国产一区二区三区欧美| 久久久久一本一区二区青青蜜月| 日韩精品视频免费专区在线播放| 欧美日韩高清在线观看| 欧美午夜精品伦理| 欧美亚洲另类在线| 色av中文字幕一区| 日韩中文字幕在线观看| 精品国产一区二区三区久久狼黑人| 宅男66日本亚洲欧美视频| 亚洲国产精品女人久久久| 亚洲免费人成在线视频观看| 日韩欧美有码在线| 国产精品视频1区| 久久亚洲电影天堂| 尤物tv国产一区| 2019国产精品自在线拍国产不卡| 伊人一区二区三区久久精品| 精品久久久一区| 成人h猎奇视频网站| 国产不卡av在线免费观看| 欧美日韩爱爱视频| 91精品视频大全| 日本道色综合久久影院| 亚洲国产精品视频在线观看| 欧美日韩国产色| 国产在线视频91| 日本成人黄色片| 国产精品成人一区二区| 97香蕉超级碰碰久久免费的优势| 91精品国产综合久久香蕉| 最新中文字幕亚洲| 欧美日本高清一区| 91亚洲午夜在线| 欧美午夜视频在线观看| 亚洲免费影视第一页| 一区二区在线视频| 91av网站在线播放| 中文字幕免费精品一区高清| 欧美激情精品久久久久久黑人| 欧美成人精品在线视频| 日韩av不卡在线| 亚洲国产精品久久| 欧美日韩人人澡狠狠躁视频| 一区二区三区在线播放欧美| 欧美激情在线有限公司| 国产精品主播视频| 国产免费久久av| 精品福利在线看| 亚洲变态欧美另类捆绑| 大桥未久av一区二区三区| 亚洲自拍偷拍第一页| 久久成年人免费电影| 欧亚精品中文字幕| 97久久精品人人澡人人爽缅北| 久久久国产精彩视频美女艺术照福利| 91久久嫩草影院一区二区| 久久这里只有精品99| 最近2019中文字幕一页二页| 久久69精品久久久久久久电影好| 欧美久久精品一级黑人c片| 欧美另类交人妖| 精品在线欧美视频| 亚洲成人免费在线视频|