美文网首页weexWeex开发前端小栈
native给weex页面传值以及Weex调用native方法(

native给weex页面传值以及Weex调用native方法(

作者: voidxin | 来源:发表于2016-09-22 16:50 被阅读5496次

    今天凌晨微信小程序(应用号)对外发送内侧邀请,瞬间在广大前端和移动端界炸开了锅。恩,H5或者说JS的又一个春天来了。
    原归正传,这里要说的是在iOS端集成Weex时我们如何给weex页面传值,以及weex页面如何调用iOS的native方法呢?且听我慢慢道来。
    其实我这几天一直在寻找native端往weex页面传值的解决方法,只是资料太少,于是乎我去github提Issues:https://github.com/alibaba/weex/issues/1270
    (汗,链接居然404,google搜“【PR】请教下iOS 端 native怎么传值到js”吧)
    很快得到回复。看了中文文档之后,我大致知道应该使用callback回调:https://github.com/weexteam/article/issues/17
    但是按照文档来写之后愣是没成功,于是我又在qq群里提问,老司机说是作用域不一样,要在外部先声明var self = this,像这样:

    var self = this
    eventModule.openURL('', function(ret){
        self.nativeLog(ret)
    })
    

    所以接下来就是我的代码了
    1:新建WXEventModule类:

    #import <Foundation/Foundation.h>
    #import <WeexSDK/WXEventModuleProtocol.h>
    #import <WeexSDK/WXModuleProtocol.h>
    #import <WeexSDK/WXNetworkProtocol.h>
    #import <WeexSDK/WXUtility.h>
    @interface WXEventModule : NSObject <WXEventModuleProtocol, WXModuleProtocol,WXNetworkProtocol>
    - (void)testAction;
    @end
    
    #import "WXEventModule.h"
    #import "WGWeexTestViewController.h"
    #import "WGWeexDemoViewController.h"
    #import <WeexSDK/WXBaseViewController.h>
    
    @implementation WXEventModule
    
    @synthesize weexInstance;
    
    //这里记得添加这个宏,这样weex才能识别native的方法
    WX_EXPORT_METHOD(@selector(openURL:callback:))
    
    
    - (void)openURL:(NSString *)url callback:(WXModuleCallback)callback
    {
       callback(@{@"result":@"1"});
    }
    
    @end
    

    2:然后在Appdelegate方法中通过调用 WXSDKEngine 中的 registerModule:withClass方法来注册自己的module

    [WXSDKEngine registerModule:@"event" withClass:[WXEventModule class]];
    

    3:在weex中:
    这里的 require 里面的event 就是在 上一步调用registerModule: 注册module 时候的name(我就直接复制文档上的原话了-)。

    methods: {
                
                updateHandler : function(e){
                    //千万记得这句(先在外部声明),不能在回调中直接使用this.function(),不然不执行
                     var self = this;
                     var eventModule = require('@weex-module/event'); 
    
                       eventModule.openURL('test.js',function(ret) { 
                                          //回调执行
                         self.loadVersionData(ret.result);
                                       
    
                       });
                },
    

    恩,这样就成功了,weex调用原生的方法,然后原生通过callback传参数到weex页面,这里要说明下,callback(data)中这样 data 支持的参数类型可以是 NSDictionary, NSString, NSArray, Int, Float, Bool ,具体可以看Issues:https://github.com/alibaba/weex/issues/866
    由于weex刚开源不久,资料比较少,所以解决问题的话还是直接去github上提Issues或者看别人的回答吧(使用百度的朋友请哭吧,百度基本没有任何线索,请google吧)。
    由于我是直接在公司项目中用的,本文的demo就不放github了,有什么问题可以留言。

    相关文章

      网友评论

      • YJoo:麻烦问下。最上面说的外部声明具体是要是在哪声明
      • _安迪_:是不是Native无法直接传值给Weex,一定需要Weex这边来调用原生方法然后用WXModuleCallback来回调?这样的话其实用WX_EXPORT_METHOD_SYNC这个宏也可以达到一样的效果,就是带返回值的方法,可以直接返回值给Weex,两者应该适用不同场景吧。
        夜3033:原生可以直接传值给Weex,fireGlobalEvent和原生的通知都可以发送给Weex,然后Weex以globalEvent去接收消息:yum:
        voidxin:@jiabin87428 对的
      • JohnQ:能不能把项目中代码补全点啊 真的看不是太懂 很多地方不知道该如何去弄
      • 1cdf380f2cf4:你好,现在 在weex项目里面加了微信登陆支付的功能,怎么才能把登陆成功后的信息通知到weex
      • 机智的猪:OC中新建的类没写完整.....看不懂唉
      • 爵起而已:对,不好意思,回迟了,主要是针对native段回传,一个回传事件就要建立一个module吗?接收回传的js是自己新建吗?
        427054c080e0:@voidxin 就是native给weex页面传值以及Weex调用native方法 和 week 给 native 传值
        voidxin:@哈哈哈小管 交互是指什么?
        427054c080e0: 您好 ,有交互传值的 demo 么
      • 爵起而已:请问回调的js是自己新建的吗?
        voidxin:@爵起而已 你是指代码中的test.js吗?是的

      本文标题:native给weex页面传值以及Weex调用native方法(

      本文链接:https://www.haomeiwen.com/subject/pamzettx.html