weex 入门个人全总结

附录::vue2.0 个人demo地址,有一些打包、路由处理的代码可供参考,喜欢的话,给个star,哈哈

一、weex介绍

Weex 是一套简单易用的跨平台开发方案,能以 web 的开发体验构建高性能、可扩展的 native 应用。在最新的weex版本中,已经将vue作为默认的上层框架,并遵循 W3C 标准实现了统一的 JSEngine 和 DOM API,这样一来,你就可以体验到基于vue的webapp的开发体验,打造三端一致的 native 应用。

几种APP开发模式

NativeApp RN weex WebApp Hybird
即传统的原生APP开发模式,Android基于Java语言,底层调用Google的 API;iOS基于OC或者Swift语言,底层调用App官方提供的API。 Facebook发起的开源的一套新的APP开发方案,使用JS+部分原生语法来实现功能。初次学习成本较高,但是在入门后,经过良好的封装也能够实现大部分的跨平台。 Weex最底层的原理是和React-Native相同的,就是将JS代码渲染成原生组件只不过在业务代码层面,Weex和React-Native有差别 即移动端的网站,将页面部署在服务器上,然后用户使用各大浏览器访问。一般泛指 SPA(Single Page Application)模式开发出的网站。 即混合开发,由Native通过JSBridge等方法提供统一的API,然后用Html5+JS来写实际的逻辑,调用API,这种模式下,由于Android,iOS的API一般有一致性,而且最终的页面也是在webview中显示,所有有跨平台效果
体验最好 体验很好 体验很好 体验最差 体验不错

更详细的对比 / rn和weex更详细对比脑图

二、如何搭建weex项目

Weex也和前端项目一样,拥有它自己的脚手架全家桶。weex-toolkit + weexpack + playground + code snippets + weex-devtool。

weex-toolkit 是官方提供的一个脚手架命令行工具,你可以使用它进行 Weex-pack 项目的创建,调试等功能。

安装,使用npm进行安装,确保你的node版本>=6

$ npm i -g weex-toolkit。

1、初始化 weex 项目

$ weex init weex-demo

执行完命令后,在 weex-demo 目录中就创建了一个使用 Weex 和 Vue 的模板项目。然后我们进入项目所在路径,weex-toolkit 已经为我们生成了标准项目结构。在 package.json 中,已经配置好了几个常用的 npm script,分别是:

build: 源码打包,生成 JS Bundle
dev: webpack watch 模式,方便开发
serve: 开启静态服务器
debug: 调试模式

2、项目的运行

$ npm run build

$ npm run serve


3、weex项目调试:

这里需要下载一个weex-playground,是一个上架的App,ios直接在扫码,安卓可以点击这里这个可以用来通过扫码实时在手机上显示出实际的页面。

 $ npm run debug

使用手机上的weexplayground扫描浏览器打开的二维码。

image.png

单纯启动一个调试服务器,并同时唤起Chrome浏览器打开调试主页。


image.png

这个调试主页上会有一个二维码,使用 Playground App 扫这个二维码可以开启 Playground 调试。开启调试后,设备列表中会出现您的设备,根据提示进行后续的调试操作。其中:

Inspector 能够用来查看 Element \ NetWork \ Console log \ ScreenCast \ BoxModel \ Native View 等。

native组件树:

image.png

html组件数:

image.png
Debugger 用来调试 Weex 中的 JS 代码,能够设置断点、查看调用栈。     
image.png

weex-pack
weexpack 是新一代的weex应用工程和插件工程开发套件,是基于weex快速搭建应用原型的利器。它能够帮助开发者通过命令行创建weex应用工程和插件工程,快速打包 weex 应用并安装到手机运行,同时对于开发者而言还能够创建weex插件模版并发布插件到weex应用市场。 使用weexpack 能够方便的在在weex工程和native工程中安装插件。

目前weex-toolkit集成对weexpack的命令调用支持,你可以使用weex-toolkit命令来实现weexpack具备的功能。比如我们要实现添加iOS应用模板:

首先,全局安装 weex-pack 命令:
$ npm install -g weexpack

初始化项目
$ weexpack create <project name>

添加应用模版,官方提供的模版默认支持 weex bundle 调试和插件机制,注意模版名称均为小写,模版被安装到platforms目录下:
$ weexpack platform add ios # 使用weexpack 命令
$ weex platform add  ios # 使用weex-toolkit,添加native模板

打包应用并安装运行
$ weexpack run ios 
$ weexpack run android

更详细的的打包以及插件机制,见https://github.com/weexteam/weex-pack

weex toolkit 与 weex-pack 的区别

weex-toolkit 初始化的项目是针对开发单个 Weex 页面而设计的,也就是说这样的项目只包括单个页面开发需要的东西,比如前端页面源文件、webpack 配置、npm 脚本等。项目产生的输出就是一个 JS Bundle 文件,可以自由的进行部署。

weex-pack 是初始化一个完整的 App 工程,包括 Android 和 iOS 的整个 App 起步,前端页面只是其中的一部分。这样的项目最终产出是一个 Android App 和一个 iOS App。

官方最近在考虑整合,无限等待....

三、weex中vue的应用

1、weex中默认使用.vue 文件,基于template, style, script 快速构建组件化的应用。

2、支持vue大部分的api,除了一些dom有关的,比如一些键盘事件的修饰符({keyCode|keyAlias})、v-text

3、页面状态之间的共享和隔离

所有的weex页面,不管是基于vue和rax,都公用了一个weex runtime,其中js引擎只初始化一次,除非重启,这种情况下,如果共享全局状态很有可能造成内存泄漏,因此最好是隔离页面状态。因此weex在原生应用中大多是以'多页的实现存在',因此不支持Vue的一些全局功能,如Vue.config、Vue.filter、Vue.mixin、Vue.use,不过依然可以在一个单页中使用,每一个单页中还是用的同一个实例的

4、另外针对vue-router和vuex大部分在weex中都能完整应用,部分差异可见[weex中使用vue全家桶的差异性](https://weex.apache.org/cn/references/vue/difference-of-vuex.html)。

在演示项目中,使用的是web端完整单页,通过路由跳转,但是native端,复杂单页中使用vue-router,多页场景是使用navigator模块,[点击查看跳转逻辑](https://github.com/yinshuxun/weex-start-kit/blob/master/src/mixins/index.js)

5、编译环境 

针对 Web 平台,和普通 Vue 2.X 项目一样,可以使用任意官方推荐的方式编译源文件,如 Webpack + vue-loader 或者 Browserify + vueify 。
针对 Android 和 iOS 平台,我们使用 weex-loader 工具支持编译 .vue 格式的单文件组件;也就是说,目前只能使用 Webpack + weex-loader 来生成原生端可用的 js bundle。

四、weex与web平台的差异

  • BOM & DOM

    1、不支持dom操作

    2、仅支持部分事件类型,

    3、没有window/location/document/history/navigator等等对象。但是提供了诸如
    WXEnvironment对象,可以获取到当前设备的屏幕或者环境信息。

    4、weex SDK >= 0.10.0 的才支持事件冒泡

  • 布局 & css

    1、只支持flex

    2、不允许使用id,只允许用class

    3、不支持后代选择器或者继承

    4、样式必须写完整 如background:red; => background-color => red;

    5、不能设置背景图片

    6、动态绑定class需要使用数组形式

  • 组件

    1、只有scroll/list组件有滚动效果

    等等 ....

五、weex基本工作原理

![Upload image.png failed. Please try again.]


工作流
we\vue 文件 ————–前端(we\vue源码)
↓ (转换) ——————前端(构建过程)
JS Bundle —————–前端(JS Bundle代码)
↓ (部署) ——————服务器
在服务器上的JS bundle —-服务器
↓ (编译) —————— 客户端(JS引擎)
虚拟 DOM 树 ————— 客户端(Weex JS Framework)
↓ (渲染) —————— 客户端(渲染引擎)
Native视图 ————— 客户端(渲染引擎)

和如今 web 开发的最佳实践一样,Weex 会把一个页面的源代码全部编译打包成一个 JS bundle,在浏览器中,我们需要把这个 JS bundle 作为一段 <script> 载入网页,在客户端里,我们把这段 JS bundle 载入本地,并通过 WeexSDK 直接执行。

六、 weex项目中webpack打包的方式

和传统的vue项目不同的是,weex项目中的webpack打包需要区分打包web端以及native端,在web端,直接使用vue-loader加载器,将所有组件进行单页打包即可,并且为了使用weex官方分装的组件,需要在入口安装weex-vue-render模块
而native端是需要使用weex-loader加载器,根据多页分别进行打包。详情可见配置

附录:https://github.com/yinshuxun/weex-start-kit

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,839评论 6 482
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,543评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,116评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,371评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,384评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,111评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,416评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,053评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,558评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,007评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,117评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,756评论 4 324
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,324评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,315评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,539评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,578评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,877评论 2 345

推荐阅读更多精彩内容