最近由于公司的需要,初步研究了Weex,Weex是阿里开发的一个web的框架,官方的介绍如下:

Weex 是一套简单易用的跨平台开发方案,能以 web 的开发体验构建高性能、可扩展的 native 应用,
为了做到这些,Weex 与 Vue 合作,使用 Vue 作为上层框架,并遵循 W3C 标准实现了统一的 JSEngine 和 DOM API,这样一来,
你甚至可以使用其他框架驱动 Weex,打造三端一致的 native 应用。

总的来说,它是一个跨平台的框架,以Web的形式构建具有原生性能的native的应用。

首先,项目环境的搭建:奉上官方链接

1、node.js的安装。

  要求:基本没啥要求,就是版本要5.x+ 可升不可降,现在node.js官网一般来说有两个,一个是6.10.2的稳定版,一个是最新版。

  安装没啥要注意的,直接下一步咯,最后安装好后,相应的npm的包管理工具也会随之安装好。

  最后一步就是检测是否安装成功,这个和简单嘛,命令如下:

$ node -v

$ npm -v

  一看就明白这两是什么命令了,前面那条是打印node.js的版本号,后面那条是打印npm包管理工具的版本号。

  如果都能正常的打印出来,那就OK咯。

2、Weektools的安装

  这里需要注意的是:weex-toolkit 在 1.0.1 之后才支持初始化 Vue 项目,使用前请确认版本是否正确。

  然后,安装,命令如下:

npm install -g weex-toolkit

  这就是安装命令了,但是,它是从https://registry.npmjs.org/这里下载安装源的,所以需要梯子,既然这个是国产的阿里的框架,那么阿里肯定就有提供啦,所以,我们不需要去这里下载。直接从阿里的镜像里面去下载就好。

  官方是这样给出的:

npm install -g cnpm --registry=https://registry.npm.taobao.org

cnpm install -g weex-toolkit

sudo cnpm install -g weex-toolkit

  这两条命令也很简单,一条是从阿里上下载安装源,第二条是利用cnpm来安装刚才下载的。贴心的阿里还给出了一个安装错误的常见情况,就是如果提示安装失败,且失败的原因是由于权限的话,那么就使用sudo这个命令去安装。

  但是,但是,但是我无论怎样都安装失败,但并不是由于权限,具体原因不明,同时也很奇怪,当你打印版本号的时候可以出来,但是你直接weex的时候,就出错了,所以我也不知道是为啥,知道的兄弟麻烦告知一声,谢谢!

  最后,倒腾了许久,找到了这篇博客,使用如下的两条命令,居然安装成功了。

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

npm install -g weex-toolkit

  这两条命令, 一条是更改下载源,一条是安装,和最初的那条安装命令是一样的,不同的是,这个更改下载源后就不再从国外的服务器上下载,而是在阿里的镜像里面下载,所以,效果是一样的,省心。

  最后一步:检验是否安装成功

weex -v

weex

当你这两条命令都能出来如下结果的时候,就说明安装成功了。

至此,安装weex结束,下面就来个Helloworld。哈哈

Helloworld:

1、找个地方,新建一个文件夹作为项目的根目录。这个直接windows下完成就好了。建好之后,打开cmd,进入刚才新建的项目。

2、执行 weex init

3、安装依赖,npm install

4、运行项目和服务器,分别是 npm run dev  和  npm run serve

5、打开:http://localhost:8080/index.html

最后需要解释一下的是,项目里面的package.json里面的-->serve -p 8080,这个就是服务器的端口号了,如果你项目运行不成功的话,先打开这个看一下,端口号写对了没有,没有你就更改一下。

下面,来跑自己试试,先在src下新建一个we文件,文件内容你可以自己写,不会就用下面这段吧:

<template>
<div class="wrapper">
<text class="weex">Hello Weex !</text>
<text class="vue">Hello Vue !</text>
</div>
</template>
<style scoped>
.wrapper {
flex-direction: column;
justify-content: center;
}
.weex {
font-size: 60px;
text-align: center;
color: #1B90F7;
}
.vue {
font-size: 60px;
text-align: center;
margin-top: 30px;
color: #41B883;
}
</style>

  完了之后,直接cmd到项目的src目录,执行weex FileName 就可以了,例如你的文件名是demo.we,那么你就敲 weex demo.we 就可以了,执行完后回自动的打开浏览器,自动的打开刚才这个页面。

这里还需要介绍一条命令是:weex demo.we --output demo.js

这条命令和上面那条差不多,只不过多了一步,执行输出相应的js,一般来说,相应的js文件会是在:C:\Users\userName\.weex_tmp\

至此,环境的搭建和Helloworld已经跑成功了,下面来看看怎么把Weex集成到Android。

Weex集成到Android

先奉上官网链接、集成到android上有两种不同的方式,SDK依赖和源码依赖,这里只讲SDK的依赖,源码依赖的方式先放下。

1、创建Android项目,这个和我们平时创建的时候一样,没什么差别。

2、添加依赖,和我们平时一样,在gradle里面直接添加就好了。需要的依赖包如下:

compile 'com.android.support:recyclerview-v7:23.1.1'
compile 'com.android.support:support-v4:23.1.1'
compile 'com.android.support:appcompat-v7:23.1.1'
compile 'com.alibaba:fastjson:1.1.46.android'
compile 'com.taobao.android:weex_sdk:0.5.1@aar'

3、这些准备工作都做好了,就对着官网抄就可以了。

package com.weex.sample;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import com.taobao.weex.IWXRenderListener;
import com.taobao.weex.WXSDKInstance;
import com.taobao.weex.common.WXRenderStrategy;
import com.taobao.weex.utils.WXFileUtils;
public class MainActivity extends AppCompatActivity implements IWXRenderListener {
WXSDKInstance mWXSDKInstance;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
mWXSDKInstance = new WXSDKInstance(this);
mWXSDKInstance.registerRenderListener(this);
/**
* WXSample 可以替换成自定义的字符串,针对埋点有效。
* template 是.we transform 后的 js文件。
* option 可以为空,或者通过option传入 js需要的参数。例如bundle js的地址等。
* jsonInitData 可以为空。
* width 为-1 默认全屏,可以自己定制。
* height =-1 默认全屏,可以自己定制。
*/
mWXSDKInstance.render("WXSample", WXFileUtils.loadFileContent("hello.js", this), null, null, -1, -1, WXRenderStrategy.APPEND_ASYNC);
}
@Override
public void onViewCreated(WXSDKInstance instance, View view) {
setContentView(view);
}
@Override
public void onRenderSuccess(WXSDKInstance instance, int width, int height) {
}
@Override
public void onRefreshSuccess(WXSDKInstance instance, int width, int height) {
}
@Override
public void onException(WXSDKInstance instance, String errCode, String msg) {
}
@Override
protected void onResume() {
super.onResume();
if(mWXSDKInstance!=null){
mWXSDKInstance.onActivityResume();
}
}
@Override
protected void onPause() {
super.onPause();
if(mWXSDKInstance!=null){
mWXSDKInstance.onActivityPause();
}
}
@Override
protected void onStop() {
super.onStop();
if(mWXSDKInstance!=null){
mWXSDKInstance.onActivityStop();
}
}
@Override
protected void onDestroy() {
super.onDestroy();
if(mWXSDKInstance!=null){
mWXSDKInstance.onActivityDestroy();
}
}
}

  这个是MainActivity的代码,自己补齐相应的代码吧。这个不多说了,都很简单。需要说明的是,代码里面的 hello.js  这个js文件是在我们android项目的assets目录下的。如果在子目录下,那么相应的 fiilefloder/filename.js 就可以。

  最后 我hello.js从哪里来呢?我们前面跑helloworld的时候,最后不是跑自己的文件么,对对对,当你使用weex xx.we --output xx.js 的时候,就会生成js文件了,去相应的目录下拷贝过来就可以了。

  上面这种是加载本地的,还有一种方式,是夹在网络上的一段js,其实都一样,使用如下方式即可:

        //Sample 2:load js from internet
Map<String, Object> options = new HashMap<>();
options.put(WXSDKInstance.BUNDLE_URL, JS_URL);
mWXSDKInstance.renderByUrl("WXSample", JS_URL, options, null, -1, -1, WXRenderStrategy.APPEND_ONCE);

  温馨提示,不要忘了在android上加 internet 的权限。

自此,到此结束,从环境的搭建,helloworld,和集成到android都可以了。

但是,你发现没,如果你的项目里面有图片。是不成功的。对对对,没错,就是这样,这个属于扩展功能,图片属于adapter扩展,是weex扩展方式中3种的其中一种。下面就来看看adapter的实现。

实现也很简单,直接新建一个ImageAdapter类,代码如下。

public class ImageAdapter implements IWXImgLoaderAdapter {
@Override
public void setImage(final String url, final ImageView view, WXImageQuality quality, WXImageStrategy strategy) {
WXSDKManager.getInstance().postOnUiThread(new Runnable() {
@Override
public void run() {
if(view==null||view.getLayoutParams()==null){
return;
}
if (TextUtils.isEmpty(url)) {
view.setImageBitmap(null);
return;
}
String temp = url;
if (url.startsWith("//")) {
temp = "http:" + url;
}
if (view.getLayoutParams().width <= 0 || view.getLayoutParams().height <= 0) {
return;
}
Picasso.with(WXEnvironment.getApplication())
.load(temp)
.into(view);
}
},0);
}
}

  下面打开你的Application,如果没有,就新建一个,新建的时候,要在Manifest.xml里面注册,指定name为这个Application。

InitConfig config=new InitConfig.Builder().setImgAdapter(new ImageAdapter()).build();
WXSDKEngine.initialize(this,config);

  在自定义的Application中添加上面两行代码即可,上面两行代码的意思无非就是注册一个Adapter。

附上github上的sampleWeexmarket

 OK,大功告成。就此记录,,,2017-4-18 深圳

Weex的环境搭建以及集成到Android项目的更多相关文章

  1. Cocos2dx-3.0版本 从开发环境搭建(Win32)到项目移植Android平台过程详解

    作为重量级的跨平台开发的游戏引擎,Cocos2d-x在现今的手游开发领域占有重要地位.那么问题来了,作为Cocos2dx的学习者,它的可移植特性我们就需要掌握,要不然总觉得少一门技能.然而这个时候各种 ...

  2. Django项目: 项目环境搭建 ---- 一、创建django项目

    项目环境搭建 一.创建django项目 1.创建python虚拟环境 在虚拟机上创建python虚拟环境,因为实际项目部署,实在linux mkvirtualenv -p /usr/bin/pytho ...

  3. 跨平台开发之阿里Weex框架环境搭建(一)

    转载自:http://www.cnblogs.com/fozero/p/5995122.html 一.介绍 Weex是阿里今年6月份推出的跨平台解决方案,6月底正式开源.官网 https://alib ...

  4. Ubuntu环境搭建系列—Chrome/JDK/Android篇

    其实每次重装Ubuntu系统的时候都要进行一次基本到环境配置,而且每次总会忘记一些环境配置到东西,所以就写下这个博文,方便自己以后重装系统的时候回顾,同时也给大家做为重装系统后基本环境搭建的参考. 因 ...

  5. android开发环境搭建日记和嵌入式Android开发环境初探

    非常感谢博客园的各位,按照你们的博文,还有利用百度和谷歌逐渐建立了android的开发环境,只是给自己备份参考查看,看过的人可以忽略这篇文章. 本文章大部分参考了:http://www.cnblogs ...

  6. Android开发环境搭建(jdk+eclip+android sdk)

    在开启Android 开发之旅之前,首先要把准备工作做好---搭建开发环境 一.环境搭建: 1.Java JDK 安装 2.Eclipse 安装 3.Android SDK 安装 4.ADT安装 5. ...

  7. Android基础之用Eclipse搭建Android开发环境和创建第一个Android项目(Windows平台)

    一.搭建Android开发环境 准备工作:下载Eclipse.JDK.Android SDK.ADT插件 下载地址:Eclipse:http://www.eclipse.org/downloads/ ...

  8. 秒杀系统(一)----环境搭建及集成Mybatis、Redis

    1.1 环境搭建--pom文件 <?xml version="1.0" encoding="UTF-8"?> <project xmlns=& ...

  9. vue环境搭建以及使用vue-cli创建项目

    我要跑vue项目,所以我要搞vue. 1.环境搭建 进入node官网下载对应版本的node,一步步安装即可. 安装会自动配置路径和npm包管理环境,通过node -v进行验证 2.安装vue-cli脚 ...

随机推荐

  1. JavaWeb:JSTL

    JSTL 说明 什么是JSTL? JSP标准标签库(JavaServer Pages Standard Tag Library,JSTL)是一个定制的标签库的集合,用来解决像遍历map或者集合.条件测 ...

  2. Jquery之JSON的用法

    今天讲了Jquery里面JSON的用法,下面是今天讲课给的例子: <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" &quo ...

  3. Visual Studio 2017 ASP.NET Core开发

    Visual Studio 2017 ASP.NET Core开发,Visual Studio 2017 已经内置ASP.NET Core 开发工具. 在选择.NET Core 功能安装以后就可以进行 ...

  4. Linux基础命令操作实例

    1.开启Linux操作系统,要求以root用户登录GNOME图形界面,语言支持选择为汉语 2.使用快捷键切换到虚拟终端2,使用普通用户身份登录,查看系统提示符 使用快捷键Ctrl+Alt+F2切换到终 ...

  5. c/c++重定向输入输出

    #define Local #include <iostream> #include <cstdio> //#include <stdio.h> using nam ...

  6. python安装插件包注意事项

    注意!注意!注意!安装以来lib库时强烈建议使用pip安装:原因:nu1:用exe安装会出现各种意想不到让您惊讶的错误!!!nu2:这种错误很难解决且花费无用功!!! 使用pip安装: nu1:使用. ...

  7. AOP执行增强-Spring 源码系列(5)

    AOP增强实现-Spring 源码系列(5) 目录: Ioc容器beanDefinition-Spring 源码(1) Ioc容器依赖注入-Spring 源码(2) Ioc容器BeanPostProc ...

  8. NIO(三、Channel)

    目录 NIO(一.概述) NIO(二.Buffer) NIO(三.Channel) Channel 上文说了描述了Buffer的实现机制,那么这个章节就主要描述数据是如何进入缓冲区的,并且又是如何从缓 ...

  9. VAO VBO IBO大乱炖

    最近对程序中绘制卡顿的问题忍无可忍,终于决定下手处理了.程序涉及的绘制比较多,除了点.线.三角形.多边形.圆柱体之外,还有自组格式模型.开始想全部采用显示列表优化,毕竟效率最高,虽然显示列表存在编译之 ...

  10. js面向对象-原型链

    var Person = function (name) { this.name = name; } Person.prototype.say = function () { console.log( ...