zoukankan      html  css  js  c++  java
  • 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 lodash@2.4.2: lodash@<3.0.0,

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

    npm uninstall lodash

    npm install lodash@latestnpm 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扫描这个二维码 即可。

  • 相关阅读:
    第四次作业
    第三次
    第十次作业
    第九次作业
    第八次作业
    10.29第七次
    15
    14
    13 this
    12 电视机
  • 原文地址:https://www.cnblogs.com/aeexiaoqiang/p/6531689.html
Copyright © 2011-2022 走看看