Weex 從0到1_iOS(一)

問(wèn)渠那得清如許搓谆,為有源頭活水來(lái)

作為一枚coder怪得,一直在不斷的挖坑填坑中徘徊夫偶。
今天我簡(jiǎn)單來(lái)總結(jié)下項(xiàng)目中用到的Weex框架湾碎。這個(gè)框架主要是用來(lái)解決跨平臺(tái)開發(fā)中web在移動(dòng)端的性能體驗(yàn)問(wèn)題厕宗。具體他有什么好處画舌,是怎么個(gè)原理,[官網(wǎng)](http://weex.apache.org/cn/guide/)上都有說(shuō)到已慢。我這里主要是說(shuō)一下我踩過(guò)的坑骗炉。(不得不說(shuō)的是官方文檔寫的是在是太“耐人尋味”)
  • 集成
    我理解的是文檔是給了2種方式,都是依賴cocoaPods(感覺(jué)還有一種源碼依賴蛇受,因?yàn)檫€要配置各種環(huán)境句葵,所以有待待驗(yàn)證)
    1.源碼集成:直接將GitHub上下載的源碼遷移到工程中,然后在Podfile中添加以下內(nèi)容兢仰,最后pod install(親測(cè)好使)


    源碼集成

    2.frameWork集成:跳過(guò)源碼遷移的步驟乍丈,Podfile 添加完成以后,pod install(更為方便把将,個(gè)人傾向這中方式)

framework集成
  • 初始化Weex環(huán)境(*是必須初始化的,(3)(4)初始化會(huì)在下一篇文章中提到轻专,在這里先不必進(jìn)行(3)(4)的初始化)
    如果只看文檔,會(huì)發(fā)現(xiàn)他在APPdelegate的初始化方法里面寫了好多東西察蹲。首先
    *(1)business configuration(暫且叫他基礎(chǔ)配置)

      [WXAppConfiguration setAppGroup:@"BZGJ"];//可以為空
      [WXAppConfiguration setAppName:@"項(xiàng)目的名字"]];
      [WXAppConfiguration setAppVersion:@"應(yīng)用版本"];
    

    *(2)init sdk environment(初始化sdk環(huán)境)

      [WXSDKEngine initSDKEnvironment];
    

    (3)register custom module and component请垛,optional(注冊(cè)自定義的組件,module...)
    (4)register the implementation of protocol, optional(注冊(cè)相關(guān)的協(xié)議...)
    (5)set the log level(設(shè)置log的級(jí)別)

  • 渲染(僅整理加載遠(yuǎn)程的js)

在開始渲染之前洽议,我先簡(jiǎn)單說(shuō)一下我踩過(guò)的坑宗收。因?yàn)槲沂怯梅绞蕉傻乃晕夷玫街皇且恍╊^文件,看不到.m的實(shí)現(xiàn)亚兄,但是混稽,weex本身就是一個(gè)開源的框架,我們可以來(lái)研究下weex里面其中的一個(gè)的類文件。

WXBaseViewController

就像是一個(gè)存放h5頁(yè)面的容器匈勋,里面有渲染的方法礼旅,weex狀態(tài)的監(jiān)聽等。
我們?cè)谧约旱捻?xiàng)目中一般不會(huì)直接用這個(gè)控制器洽洁,而是會(huì)自定義一個(gè)類似的控制器痘系,這樣的話方便我們控制很多東西,例如URL的格式饿自,傳遞給js的值等等汰翠。。

下面切入主題
我們需要?jiǎng)?chuàng)建一個(gè)存放h5頁(yè)面的控制器(WeexBaseVC)
(1)聲明2個(gè)變量

@property (nonatomic, strong) WXSDKInstance *instance;
@property (nonatomic, strong) UIView *weexView;

(2)實(shí)現(xiàn)渲染的方法及回調(diào)

- (void)render
{
    [_instance destroyInstance];
    _instance = [[WXSDKInstance alloc] init];
    if([WXPrerenderManager isTaskExist:[self.url absoluteString]]){
        _instance = [WXPrerenderManager instanceFromUrl:self.url.absoluteString];
    }
    
    _instance.viewController = self;
    _instance.frame = CGRectMake(0, 20, self.view.bounds.size.width, self.view.bounds.size.height);
    
    __weak typeof(self) weakSelf = self;
    _instance.onCreate = ^(UIView *view) {
        [weakSelf.weexView removeFromSuperview];
        weakSelf.weexView = view;
        [weakSelf.view addSubview:weakSelf.weexView];
        UIAccessibilityPostNotification(UIAccessibilityScreenChangedNotification, weakSelf.weexView);
    };
    _instance.onFailed = ^(NSError *error) {
        //失敗
    };
    
    _instance.renderFinish = ^(UIView *view) {
        //渲染完成
         WXLogDebug(@"%@", @"Render Finish...");
        [weakSelf updateInstanceState:WeexInstanceAppear];
    };
    
    _instance.updateFinish = ^(UIView *view) {
        //更新完成
        WXLogDebug(@"%@", @"Update Finish...");
    };
    if (!self.url) {
        WXLogError(@"error: render url is nil");
        return;
    }
    if([WXPrerenderManager isTaskExist:[self.url absoluteString]]){
        WX_MONITOR_INSTANCE_PERF_START(WXPTJSDownload, _instance);
        WX_MONITOR_INSTANCE_PERF_END(WXPTJSDownload, _instance);
        WX_MONITOR_INSTANCE_PERF_START(WXPTFirstScreenRender, _instance);
        WX_MONITOR_INSTANCE_PERF_START(WXPTAllRender, _instance);
        [WXPrerenderManager renderFromCache:[self.url absoluteString]];
        return;
    }
    [_instance renderWithURL:[NSURL URLWithString:@"http://192.168.1.55:8080/dist/hoteldetail.js"] options:@{@"paramKey":@"paramValue"} data:nil];
}

Tip:

  • (void)renderView:(NSString *)source options:(NSDictionary *)options data:(id)data;
    options:The params passed by user.(需要傳遞給js使用的參數(shù)璃俗,例如id等)
    data:The data the bundle needs when rendered. Defalut is nil.

(3)weexInstance狀態(tài)更新,以觸發(fā)weex的事件悉默,和ViewController的聲明周期一致

- (void)viewDidAppear:(BOOL)animated{
  [super viewDidAppear:animated];
  [self updateInstanceState:WeexInstanceAppear];
}
   
- (void)viewDidDisappear:(BOOL)animated{
  [super viewDidDisappear:animated];
  [self updateInstanceState:WeexInstanceDisappear];
}
   
//觸發(fā)相應(yīng)的事件   
- (void)updateInstanceState:(WXState)state{
 if (_instance && _instance.state != state) {
     _instance.state = state;
     
     if (state == WeexInstanceAppear) {
         [[WXSDKManager bridgeMgr] fireEvent:_instance.instanceId ref:WX_SDK_ROOT_REF type:@"viewappear" params:nil domChanges:nil];
     }
     else if (state == WeexInstanceDisappear) {
         [[WXSDKManager bridgeMgr] fireEvent:_instance.instanceId ref:WX_SDK_ROOT_REF type:@"viewdisappear" params:nil domChanges:nil];
     }
 }
}

(4)銷毀掉 weexInstance城豁,釋放內(nèi)存,避免造成內(nèi)存泄露

- (void)dealloc{
    [self.instance destroyInstance];
}

到這一步抄课,基本的頁(yè)面已經(jīng)出來(lái)了唱星,但是如果js頁(yè)面上有圖片的話,你會(huì)發(fā)現(xiàn)OC頁(yè)面上卻沒(méi)有圖片跟磨,于是乎间聊,則需要我們來(lái)實(shí)現(xiàn)圖片的加載

<---------圖片加載,JS與OC交互and others請(qǐng)往后翻--------->

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末抵拘,一起剝皮案震驚了整個(gè)濱河市哎榴,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌僵蛛,老刑警劉巖尚蝌,帶你破解...
    沈念sama閱讀 206,311評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異充尉,居然都是意外死亡飘言,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,339評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門驼侠,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)姿鸿,“玉大人,你說(shuō)我怎么就攤上這事倒源】猎ぃ” “怎么了?”我有些...
    開封第一講書人閱讀 152,671評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵笋熬,是天一觀的道長(zhǎng)碟渺。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么苫拍? 我笑而不...
    開封第一講書人閱讀 55,252評(píng)論 1 279
  • 正文 為了忘掉前任芜繁,我火速辦了婚禮,結(jié)果婚禮上绒极,老公的妹妹穿的比我還像新娘骏令。我一直安慰自己,他們只是感情好垄提,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,253評(píng)論 5 371
  • 文/花漫 我一把揭開白布榔袋。 她就那樣靜靜地躺著,像睡著了一般铡俐。 火紅的嫁衣襯著肌膚如雪凰兑。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,031評(píng)論 1 285
  • 那天审丘,我揣著相機(jī)與錄音吏够,去河邊找鬼。 笑死滩报,一個(gè)胖子當(dāng)著我的面吹牛锅知,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播脓钾,決...
    沈念sama閱讀 38,340評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼售睹,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了可训?” 一聲冷哼從身側(cè)響起昌妹,我...
    開封第一講書人閱讀 36,973評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎握截,沒(méi)想到半個(gè)月后捺宗,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,466評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡川蒙,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,937評(píng)論 2 323
  • 正文 我和宋清朗相戀三年蚜厉,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片畜眨。...
    茶點(diǎn)故事閱讀 38,039評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡昼牛,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出康聂,到底是詐尸還是另有隱情贰健,我是刑警寧澤,帶...
    沈念sama閱讀 33,701評(píng)論 4 323
  • 正文 年R本政府宣布恬汁,位于F島的核電站伶椿,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜脊另,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,254評(píng)論 3 307
  • 文/蒙蒙 一导狡、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧偎痛,春花似錦旱捧、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,259評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至谓谦,卻和暖如春贫橙,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背反粥。 一陣腳步聲響...
    開封第一講書人閱讀 31,485評(píng)論 1 262
  • 我被黑心中介騙來(lái)泰國(guó)打工卢肃, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人星压。 一個(gè)月前我還...
    沈念sama閱讀 45,497評(píng)論 2 354
  • 正文 我出身青樓践剂,卻偏偏與公主長(zhǎng)得像鬼譬,于是被迫代替她去往敵國(guó)和親娜膘。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,786評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容