Weex iOS端的自动刷新和调试

Weex iOS端的自动刷新和调试

大家好,又见面了,我是全栈君。

最近开始接触weex。目前weex尚不成熟,官方文档有些粗糙,初学者难免碰壁。这里分享两条我的初学经验,供参考。

自动刷新

Weex有一个网页版的预览工具,提供了修改代码后自动刷新页面的功能。然而作为移动端开发,网页版工具显然不够,我们需要在模拟器或者真实设备中开发和调试。

原理

监控代码的变化,并通知hot-reload服务器。iOS代码中需要监听来自服务器的通知并重新加载界面。

不难发现,weex脚手架为我们创建的工程中,已经包含了相关的实现:

NSString * hotReloadURL = [[NSBundle mainBundle] objectForInfoDictionaryKey:@"WXSocketConnectionURL"];
_hotReloadSocket = [[SRWebSocket alloc] initWithURL:[NSURL URLWithString:hotReloadURL]];
_hotReloadSocket.delegate = self;
[_hotReloadSocket open];

探索

我先用npm start启动网页预览,然后将info.plist中socket服务器的地址改为自己的ip再编译运行项目。结果是不能自动刷新,socket代理也没有被触发。可能是地址不对!可是文档里没告诉我们如何获取正确的地址。

灵机一动,网页版能够自动刷新,那么我们可以通过Chrome的开发者工具监听socket请求。打开开发者工具,选中Network标签,设置filter为WS,然后修改js代码。果然监听到WS请求:

Chrome网络监听

Chrome网络监听

地址有些奇怪。查看socket代理,发现不是我们想要的数据格式。好讨厌的感觉啊~

- (void)webSocket:(SRWebSocket *)webSocket didReceiveMessage:(id)message {
    if ([@"refresh" isEqualToString:message]) {
        [self render];
    }
    @try {
        NSDictionary * messageDic = [WXUtility objectFromJSON:message];
        NSString *method = messageDic[@"method"];
        if ([method hasPrefix:@"WXReload"]) {
            if ([method isEqualToString:@"WXReloadBundle"] && messageDic[@"params"]) {
                self.url = [NSURL URLWithString:messageDic[@"params"]];
            }
            [self render];
        }
       
    } @catch(NSError * error) {}
}

于是便请求度娘的帮助。有前辈的教程中提到,需要用weex命令+入口文件名的方式启动项目,于是照猫画虎:weex dist/index.js
系统报错并提示了正确的用法,看来教程稍微有些陈旧啦。应该这样:weex preview dist/index.js。执行命令后自动打开了一个预览网页,和之前的页面有些大同小异。

打开开发者工具:

Chrome网络监听

用这个地址替换项目中的地址,模拟器可以自动刷新了!

调试

Weex官方文档告诉我们可以通过weex debug命令和Chrome来调试项目,很好很强大。于是我根据文档的说明集成了WXDevtoolsdk,并添加如下代码:

[WXDevTool setDebug:YES];
[WXDevTool launchDevToolDebugWithUrl:@"ws://127.0.0.1:8089/debugProxy/native"];

执行weex debug命令,成功后弹出一个网页:

调试页面

此时编译运行项目,发现不能正常调试,模拟器展示了一个大白屏。既然给我们一个二维码,说明调试地址一定藏在二维码中。但我不想因此实现一个二维码扫描的功能,所以我借助了微信,然后在浏览器打开。原来地址是这样的:ws://127.0.0.1:8089/debugProxy/native/8e2ea364-e514-45a1-a022-363c793d048a(我用127.0.0.1代替了真实的ip)。

修改代码后,可以调试了!不过地址后的字符串8e2ea364-e514-45a1-a022-363c793d048a在重启调试服务器后会变,有些坑,还是集成一个扫一扫吧~

感受

Weex是国人开源的跨平台框架,前途可量。和ReactNative相比,目前weex在开发调试方面的便利性比较差,而且缺乏一篇融会贯通的基础教程。让我这个“老司机”也折腾了一番,何况一个跨平台新手!希望以后能够改进吧。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107700.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 金税盘组件接口调用方法

    金税盘组件接口调用方法TaxCardX.dll组件接口 开卡 GoldTax:=CreateOleObject(‘TaxCardX.GoldTax’);GoldTax.CertPassWord:=’证书口令’;GoldTax.OpenCard; 发票查询 GoldTax.BatchUpload(‘查询报文’);1.查询体<?xmlversion=”1.0″encoding=”GBK”?><FPFP><DATA>

    2022年4月30日
    116
  • excel截取中间字符串函数_java截取指定字符串

    excel截取中间字符串函数_java截取指定字符串应用场景办公过程中需要使用某一单元格内的特定部分,因此需要对字符串进行截取操作。例如单元格内容是这样的:AAA\aaa我们需要的内容是这样的:aaaExcel实现函数部分如下:=RIGHT(A1,LEN(A1)-FIND(“\”,A1,1))==========================================================个人能力有限,如有谬误欢迎指正!…

    2025年6月15日
    2
  • getenv(php7.0以上版本不不能使用的问题)[通俗易懂]

    getenv(php7.0以上版本不不能使用的问题)[通俗易懂]getenv(php7.0以上版本不不能使用的问题)

    2022年4月24日
    53
  • 机器人控制系统有哪些_abb机器人创建系统

    机器人控制系统有哪些_abb机器人创建系统 一、ROS简介与安装 那么在学习使用ROS之前,首先问一个问题:为什么需要机器人操作系统?机器人操作系统与现有的Linux或Windows操作系统有什么不同呢?大家知道,操作系统的诞生,就是为了提供硬件和软件间的接口,以便程序员编写程序时可以专注于设计算法,而不必关心底层硬件是如何实现的。那么,对于不同的硬件平台,面对不同的功能需求,自然也需要设计不同的操作系统来完成任务。机器…

    2025年5月23日
    3
  • 数组和链表的区别浅析

    数组和链表的区别浅析1.链表是什么链表是一种上一个元素的引用指向下一个元素的存储结构,链表通过指针来连接元素与元素;链表是线性表的一种,所谓的线性表包含顺序线性表和链表,顺序线性表是用数组实现的,在内存中有顺序排列,通过改变数组大小实现。而链表不是用顺序实现的,用指针实现,在内存中不连续。意思就是说,链表就是将一系列不连续的内存联系起来,将那种碎片内存进行合理的利用,解决空间的问题。所以,链表允许插入和删…

    2022年6月15日
    35
  • 使用AnalyticDB MySQL创建数据库及表过程

    使用AnalyticDB MySQL创建数据库及表过程简介目标是让云上数据仓库用户及开发者通过简单的步骤体验基于AnalyticDBMySQL版和DMS构建云原生数据仓库的主要流程,场景将通过实例的开通、结构与数据的初始化、报表的开发、报表可视化等环节,用3个具体的应用场景来体验AnalyticDBMySQL版在新零售场景下的交互查询和ETL计算速度,以及通过DMS进行数据仓库数据报表开发的流程。提供的数据集是一个零售场景的模拟数据,包括客户信息、订单记录、货物信息、国家地域信息等内容,数据总量10GB,最大数据表记录数为5999万条。产品简介云原

    2025年12月13日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号