转载

集成 Weex 注意事项

撰写本文时,Weex 还没有完全开源, 这是官方的文档中心 , 这是 Weex 团队放在 Github 上的一些文章 ,你可以上 官网 申请访问 Weex 的 Github 页面。

这篇文章介绍一下如何快速集成 Weex 到你的 iOS Project 里面。

如果你还没有 Weex 的 SDK,你可以下载一下这个官方给的 WeexSample ,工程里面有 WeexSDK.framework 这个文件,这样如果你惯用 Objective-C 的话,参考 这篇文章 ,你就可以清晰明了地知道这个 Sample 是怎么写出来的,但是这篇文章没有告诉你这些事:

  • 这里面有两个文件 SRWebSocket.h 和 SRWebSocket.m,这是 facebook 的开源项目 SockerRocket ,运行这个项目必须有这个东西(至少暂时是这样,或许以后 Weex 团队会尝试自己搞个类似的东西出来?)
  • 官方目前没有 Swift 版本的 Sample,这里有个来自第三方的 示例 ,可以参考一下,这个示例有一点点问题,代码风格不太 Swifty,问题我写在下面了,其他诸如 print 写成 NSLog 这种,无伤大雅,好歹是用 Swift 运行起来了
  • Weex 是用 OC 写的,Swift 项目集成它,里面需要桥接文件,如果你不知道这个是什么,可以参考我 之前的一篇文章 ,这个文件里面只需要写这些(不需要 import SRWebSocket):
#import <WeexSDK/WXSDKEngine.h> #import <WeexSDK/WXSDKInstance.h> #import <WeexSDK/WXLog.h> #import <WeexSDK/WXAppConfiguration.h> 
  • 官方展示的 OC 版本的这段代码:
- (void)dealloc {     [_instance destroyInstance]; } 

在 Swift 里面的写法是:

// Deprecated //    override func finalize() { //        instance.destroyInstance() //    }  deinit {     instance.destroyInstance() } 
  • 虽然官方在很多地方都提到这一点,为了防止还是有人忽略,再写一遍:请在 Build Settings 的 Other Link Flags 里面加入 -ObjC

  • 官网开源的代码中,没有把 SDK 做成 .framework,而是直接一个文件夹,工程通过 Pod 来把这个 SDK 集成到项目中,顺便也通过 Pod 集成了其他内容,这是 Podfile 里的内容(可以看到 WeexSDK 是通过本地路径加进来的):

    source 'https://github.com/CocoaPods/Specs.git' platform :ios, '7.0' #inhibit_all_warnings!  target 'WeexDemo' do   pod 'WeexSDK', :path=>'../sdk/'   pod 'SDWebImage', '3.7.5'   pod 'SocketRocket', '0.4.2'   pod 'ATSDK-Weex', '0.0.1' end 
原文  http://kyxu.tech/2016/06/19/集成-Weex-注意事项/
正文到此结束
Loading...