Weex系列构建Weex工程

Posted 我是小强zz

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Weex系列构建Weex工程相关的知识,希望对你有一定的参考价值。

Weex比React Native更简单,更容易学习,并且做到真正的跨平台,一套代码可以多个平台运行。所以建议大家都用Weex吧。

一、安装Node

已经安装Node的,请忽略过去。

检查Node是否安装的命令:

$ node -v

v7.3.0

大家可以看阿里团队的博文,我这里也说下。

1、要先安装Node。在Mac我是用Homebrew来安装的。

安装命令: brew install node

2、接着我们需要安装Weex CLI。

终端中执行: sudo npm install -g weex-toolkit  

3、npm 是 Node 的模块管理器,执行install因为连的是国外的服务器,事件可能会很慢。如果大家运行上面的语句很慢 可以按下面的来做,如果大家已经FQ,就不用按下面的来了。

3.1、删除代理设置:

#npm config delete proxy

#npm config delete https-proxy

然后 终端执行:

npm --registry https://registry.npm.taobao.org info underscore 

也可以用下面2种方法:

3.2、终端执行:

npm config set registry https://registry.npm.taobao.org npm info underscore 

如果上面配置正确这个命令会有字符串response

3.3:编辑 ~/.npmrc 加入下面内容,将配置写死,下次用的时候配置还在registry = https://registry.npm.taobao.org

4、如果安装中遇到下面的警报,可以忽略,不用管,也可以运行命令来修正。

4.1、安装的时候报警报:npm warn deprecated [email protected]: [email protected]<3.0.0,

可以执行下面2句命令行即可:

npm uninstall lodash

npm install [email protected] cache clean

4.2、如果报错:npm ERR! tar.unpack untar error ,可以执行下面命令:sudo  npm cache clean

 

二、引入SDK

1、我们新建一个项目:WeexDemo。

2、从github下载Weex项目后,然后将ios/sdk 文件夹复制到根目录,并新建一个Podfile文件,文件内容为:

source ‘https://github.com/CocoaPods/Specs.git‘

platform :ios, ‘7.0‘

#inhibit_all_warnings!

def common

pod ‘WeexSDK‘, :path=>‘./sdk/‘

end

target ‘WeexDemo‘ do

common

end

3、命令行cd到根目录,然后执行pod install --verbose --no-repo-update

如图:

 


 

三、写代码

我们用最简单的方式来先把代码写出来。

首先我们先做个简单的Demo。已经放到github上了。大家可以下载看看,我们下面讲的就是这个Demo的代码。

1、新建一个项目,初始化SDK。

在AppDelegate文件里的didFinishLaunchingWithOptions方法里 初始化Weex的SDK。如图:


初始化Weex的SDK

上图中,我们先配置了一些信息,也可以不配置。直接 初始化SDK:

[WXSDKEngine initSDKEnvironment];

其中 打印类型 我们设置的为WXLogLevelAll。 该枚举的全部类型为:


WXLogLevel枚举

初始化SDK后,需要调用registerModule方法 注册我们自己写的WXEventModule。Module可以让JS主动调用原生iOS代码。

registerModule我们后面再讲,我们可以先把registerModule这句 给注释掉。先看VC如何加载js 来实现一个页面的。

2、VC页面设置。

我们在ViewController页面 先写个原生的按钮,然后 用指定的 URL 渲染 weex 的 view,把该view添加到VC的view上。

self.view上加上一个原生的UIButton。用render方法来初始化JS的页面。

我们在viewDidLoad里读取了一个helloWeex.js的文件路径,下面我们会讲 这个js是怎么创建生成的。现在大家就当已经创建好了。

addTestBtn方法是用来创建原生UIButton的。


 

3、加载JS文件显示页面

我们先初始化WXSDKInstance,WXSDKInstance可以通过renderWithURL方法根据传入的js来创建相关的UIView,它有一些回调方法:

onCreate:根视图rootView创建的时候

onFailed:处理失败后

renderFinish:视图渲染完成

componentForRef:通过视图索引拿到对应的组件视图


 

我们在onCreate 的block中将WXSDKInstance生成好的UIView add到self.view上。

4、上面代码运行的效果如下:

四、前端页面

Sublime 可以设置weex高亮。大家可以点击去看下。

我们来看下 上面说的js文件 是怎么创建生成的。

我们新建一个helloWeex.we的文件。如图:


helloWeex.we

1、代码分析

上文中的template模板中默认建了一个显示文字为“Hello Weex” 的text。其中class="title",也就是样式为title。onclick="onClickTitle":也就是 点击该文本会调用onClickTitle的js方法。

然后下面设置了title的样式:.title { color: red; }  。所以字体会显示红色。

最下面设置了onClickTitle的js方法。所以当你点击文本的时候 会在控制台打印日志,但是alert方法在iOS中没有执行,这个我们后面再说。 

2、浏览器运行效果

在终端 cd到改文件所在的目录,然后执行: weex helloWeex.we   。

会自动打开浏览器:http://127.0.0.1:8081/weex_tmp/h5_render/?hot-reload_controller&page=helloWeex.js&loader=xhr


 

点击该文本,会提示相关文字:


 

3、生成js文件

然后再终端执行: 

weex helloWeex.we -o helloWeex.js

会生成 js文件,我们把这个js文件拖到项目中。目录如下:


WeexDemo项目文件

 

4、WeexPlayground扫描

如果你想不想引入到自己项目中,而是想直接在手机上看上面helloWeex.we的效果。可以从AppStore下载WeexPlayground,然后 在终端中输入: weex helloWeex.we --qr  。

终端会生成一个二维码(如下图),然后用WeexPlayground 这个APP扫描这个二维码 即可。

以上是关于Weex系列构建Weex工程的主要内容,如果未能解决你的问题,请参考以下文章

Weex系列之Module源码解析

WeexConf 2018干货系列|Weex + Ui

Weex系列之Weex入门准备

Weex开发系列:初识Weex

WEEX系列活动——Weex框架知多少

深入Weex系列Weex渲染流程分析