二:Weex 实时更新实现

一:写在前面

用过RN的都知道,RN有HotReload技术。而且修改一下RCTSocket.m(具体什么文件忘记了)文件中的localhost地址即可实现。但是Weex官方文档中并没有提及Weex 热加载的技术。是不是并不能实现呢?答案是否定的。在我翻阅了很多过时的陈旧的资料,以及Weexdemo后发现,weex也是可以实现热加载的。不知道是不是叫做hot reload,还是说只有RN的才是hot reload。我们暂时叫做实时更新吧。严谨一些。

二:什么是Hot reload?以及实现原理。

这里借鉴React Native 热加载(Hot Reload)原理简介 ,不知道weex的实时更新是否使用的和RN同样的技术。
warning:这一点埋个坑,以后来补。

三:Weex的实时更新实现

3.1 需求

我们要使用Weex在原有项目实现部分界面,但是总是拿手机去扫码感觉很low,为什么不能像RN一样,修改了js文件,界面直接在真机刷新呢?但是官方并没有提供相关的技术支持(也可能是我没找到)。简而言之,今天要把weex的实时加载(RN的hot reload)这个功能开启一下,分享给大家。这方法比较笨。如果有更好的办法,希望下方留言。谢谢。

3.2 过程

3.2.1 前期准备

首先,要有一个集成了weex项目的iOS 项目,具体的搭建流程可以参考这篇文章First:WEEX环境搭建+iOS现有项目集成;

3.2.2 过程

前面有很多过程,就不细谈了,大家都比较关心如何开启实时刷新,那就直接上干货。
前提:手机和电脑在同一个局域网内。

  • 1.首先我们需要在pod中集成SRWebSocket,这个是为了加一个监听,监听文件的修改,并发送文件修改时的通知。在pod中复制以下代码.
pod 'SocketRocket', '0.4.2'
  • 2.然后我们需要在Viewcontroller中导入SocketRocket的库,并导入代理方法。端口我发现都是8082,weexdemo中写的也是8082,代码如下
- (void)openHotReload{
    
    NSURL *socketURL = [NSURL URLWithString:[NSString stringWithFormat:@"ws://%@:%@", /*后面会说这个ip地址的由来*/, @"8082"]];
    self.hotReloadSocket = [[SRWebSocket alloc] initWithURL:socketURL protocols:@[@"echo-protocol"]];
    self.hotReloadSocket.delegate = self;
    [self.hotReloadSocket open];
}
  • 3.实现SocketRocket的代理方法
- (void)webSocket:(SRWebSocket *)webSocket didReceiveMessage:(id)message{
    
    if ([@"refresh" isEqualToString:message]) {
        [self initWeexView];//这里是要自己初始化的weexview,下面给一个简单的weexview的实现
    }
}

- (void)initWeexView{
    _instance = [[WXSDKInstance alloc]init];
    _instance.viewController = self;
    _instance.frame = self.view.bounds;
    
    
    __weak typeof(self) weakSelf = self;
    _instance.onCreate = ^(UIView *view) {
        [weakSelf.weexView removeFromSuperview];
        weakSelf.weexView = view;
        [weakSelf.view addSubview:weakSelf.weexView];

    };
    
    _instance.onFailed = ^(NSError *error) {
        //process failure
    };
    
    _instance.renderFinish = ^ (UIView *view) {

    };
    ;
    //实时刷新,注意这个地方的后面的dist/App.weex.js,是你的vue文件的路径和名字。
    [_instance renderWithURL:[NSURL URLWithString:@"http:///*这个地址后面会说*//dist/App.weex.js"] options:nil data:nil];

}
  • 4.实现hot reload,我们需要一个ip地址。
1. 首先cd到你自己写的vue文件。
2. 在终端输入 weex preview /*你的vue文件*/
这时会看到弹出一个浏览器。
3.这个浏览器前面的ip地址就是我们需要的ip地址。那么文件的路径是什么呢?点击那个大的二维码,看一下url,里面有文件路径。
  • 5.替换上面提到的路径以及ip地址。

  • 6.运行程序。随便修改vue文件,command+s保存一下,不出意外手机就会跟着刷新了。

四: 踩坑

4.1 IP地址

1.要同一个局域网下。
2.如果实在不知道路径,可以点一下那个大大的二维码,上面的URL就是本地编译的jsbundle文件路径。
3.websocket监听的是8082端口。render的是8081。别搞错。
修正:这里的监听的端口是会变化的。不一定是8082,8081。render的端口就在URL中,监听的端口比较隐蔽。我有必要说一下如何确定监听端口。

还记的之前输入weex preview ..vue那个命令行么?
会弹出一个页面,我们用chrome,进入调试界面。
我们点击NetWork,在header中可以找到类似于
Request URL: ws://192.168.10.238:8083/这样的东西。
后面的8083就是socket监听的端口。

五:预告

下一章节:JS与Native的交互--iOS篇

我是二毛,一个集智慧和逗比于一身的iOSer

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,504评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,434评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,089评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,378评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,472评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,506评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,519评论 3 413
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,292评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,738评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,022评论 2 329
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,194评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,873评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,536评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,162评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,413评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,075评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,080评论 2 352

推荐阅读更多精彩内容