Weex和Web开发体验的异同

简介: 在2017年1月12日 Weex Conf 2017下午的技术实践论坛上, Weex团队的勾股详细讲解了Weex和Web开发体验的异同。他主要从Weex 中的 Web 标准、Weex 中的 Web 研发模式以及其它注意事项展开了此次分享。

2017年1月12日 Weex Conf 2017下午的技术实践论坛上, Weex团队的勾股详细讲解了Weex和Web开发体验的异同。他主要从Weex 中的 Web 标准Weex 中的 Web 研发模式以及其它注意事项展开了此次分享。

本文根据现场分享和幻灯片整理而成。


Weex 中的 Web 标准

Weex中的Web标准主要包括HTML/CSS/JavaScript三个维度。

HTML

目前Weex支持的Components约为15个,具体组件如下图所示。

6adcbc09ebb57bdf0c05aadb7d7c54bc506d8a68

相比于完成的HTML语法标准,Weex所缺失的内容可以总结为三部分:

  •  块级语义化标签,如Section、 Article等;
  •  内联文本标签,如Strong、em等;
  •  表单类标签,如button、select等。

对于缺失的内容,Weex提供了特定的的解决方式。对于缺失的块级语义化标签,可以通过自定义标签的方式去定制,如<section>标签可以通过<div>的方式代替(两者行为类似),并且降低了成本。具体代码如下:

 
<template>
<section>
<text>Hello World</text>
</section>
</template>

采用div替换后:

 
<template>
<div>
<text>Hello World</text>
</div>
</template>

对于内联语义化标签,如<strong>标签,也可以<text style="font-weight: bold;">方式替换,效果完全相同。

对于表单类标签,如<input>/<textarea>等文本输入相关的标签现已支持;radio可以利用<image>+<text>拼接实现;checkbox可以利用<switch>代替;<select>标签可以通过picker或自定义定制得到。

值得注意的是:上述的内容全部可以通过Vue <template>实现。此外,富文本组件目前也在开发过程中,期待未来能够在Weex中提供(Github上富文本组件讨论区:https://github.com/alibaba/weex/issues/835)。

CSS

对于CSS,从命题维度角度考虑:首先,CSS选择器种类繁多;其次,CSS有很多属性,相同或不同的属性有着各种属性值和单位。Weex在支持CSS方面具有以下特点:

  •  从上层语法角度来看,Weex目前支持单个Class选择器,这也是CSS在JS中的最佳实践;
  •  支持伪类wip,如传统的hover(更多细节点击此处阅读);
  •  属性支持情况,width、overflow等使用频次较高的属性都已支持(更多细节点击此处查看);

由于目前的Vue 2.0前端框架、上层建筑以及周边组件足够丰富,目前Weex现已支持PostCSS/CSS Next。

JavaScript

JavaScript的标准可以分为语法层面和浏览器或Web端API设计两个层面。目前可以使用ES6、ES7或更高更好的版本开发JavaScript,同时一些关键的Polyfill,Weex都做了官方的支持;此外,Weex 在 JS 引擎中为每个页面都提供了一套 Native DOM APIs,这套接口和 HTML DOM APIs 非常接近,利用这套接口可以通过JavaScript控制 Native 的渲染逻辑,而且 Weex上层的 Vue 2.0 也是基于这套接口进行适配的(更多细节点击此处查看);Weex还提供了Device API,使得JavaScript尽可能具有驱动整个设备的能力。

289c920ee047637937e58f41d8e3a2d98cc4aaf7

在Weex运行时,只有一个JavaScript引擎实例。在Weex中,尽管可以同时打开多个页面,但这些页面是共享一份JavaScript(这和传统的网页有区别)。之所以这么做是为了让设备在端上的资源能够得到充分利用,但这同时带来了长效的JavaScript内存泄露的问题。

目前,除了通过封装的方式控制内存泄露之外,还可以强制“use strict”,因为在该模式下无法随意创建全局变量;此外,还可以强制Object.freeze全局变量,在此之后对全局变量或对象只能进行读操作。

JS Service

未来,我们希望在JavaScript引擎中建立JS Service层,该层可以横跨多种JS框架统一管理;同时可以横跨所有实例,实现多实例统一管理,使得能力、数据和内存得到有效管理和增强;甚至可以将Polyfill、AMD 实现、第三方库引入、native 回调函数管理、全局数据共享、全局路由管理、Worker...等功能都在JS Service调度实现。

Vue 2.x 在Weex和Web中的差异

Vue 2.x 在 Weex 和 Web 中的差异主要体现在平台、功能、样式、编译环境上,下面来一一解读。

4ea9809925fb690635695314c2f834c4216bb4ef

平台差异,Vue.js最初是为 Web 平台设计的,虽然可以基于 Weex 开发原生应用,但是 Web 开发和原生开发毕竟不同,由于运行平台存在差异,Weex 不支持 Vue 中与 DOM 相关的功能:

  •  不支持事件冒泡和捕获机制,.prevent 、.capture 、.stop 、.self 等事件修饰符在原生环境中无意义;
  •  键盘事件的 .{keyCode | keyAlias} 修饰符在原生环境中无意义;
  •  无法通过 vm.$el 获取界面元素,原生环境中没有 DOM Element;
  •  无需自行调用 vm.$mount,默认会将入口组件挂载到原生应用的视图中;
  •  不支持 v-html 和 v-text 指令。

功能差异,Weex 中仅引入 Vue Runtime 的功能,这样做除了可以减少代码体积以外,还能减少运行期编译模板的负担,提升性能。具体的差异有:

  •  定义组件时不支持使用 template 属性;
  •  不支持使用 x-templates;
  •  不支持使用 Vue.compile。

样式差异,Weex 中的样式是由原生渲染器解析的,出于性能和功能复杂度的考虑,Weex 对 CSS 的特性做了一些取舍,使其更符合最佳实践:

  •  Weex 中只支持单个类名选择器,不支持关系选择器,也不支持属性选择器;
  •   Weex 中,写在组件 <style> 里的样式只能用在当前组件中,默认是 scoped 作用域。

编译环境的差异,在 Weex 中使用 Vue.js ,你所需要关注的运行平台除了 Web 之外还有 Android 和 iOS ,在开发和编译环境上还有一些不同点。针对 Web 和原生平台,将 Vue 项目源文件编译成目标文件,有两种不同的方式:

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

两者更多差异,请阅读:《Vue 2.x 在 Weex 和 Web 中的差异》

研发模式

较为合理的移动开发模式应该是单页研发、多页聚合,也就是先把一个移动应用拆成多个页面,每个页面可以独立设计和开发,中间通过路由方式或调度的方式串联起来。

2934ba0af7002c859f4da5c3921248cd82b6b71f

这种方式和Web中的SPA方式产生一定的交集。SPA(single-page application)即单页化应用,它的优势在于避免了多个页面重复加载资源(所有资源第一次全部加载好,打成Bundle);其次,可以方便地自定义专场效果;再者,它几乎没有页面之间的等待;此外,SPA与全局数据、全局状态共享可以做到天衣无缝地结合。

但在实际使用SPA的时,也遇到很多痛点,如页面首次打开的开销;内存管理问题,多个页面共享一个内存;原生路由的配合/开放规则的应对;所有页面必须基于相同的JS框架等问题。

那么Weex的研发模式又是如何实现的呢?

e64ca4c28e908cd87ee3cb613d0fe2684246bedd

首先,Weex坚持每个页面一个JS Bundle;再者,支持原生的转场效果;同时,运行时优化、缓存和预加载也进行充分的实践;此外,还通过JS Service进行资源复用和全局数据/状态管理。

经过这些改进之后,即便非单页应用,Weex也可以实现页面秒开;同时,不同的团队/个人可以自由选择JS框架;还为内存管理提供了更好的引导,并支持原生&开放规则的路由。因此,是时候向SPA说再见了!

工程研发

从工程研发角度来看,Weex中Web开发过程必定需要如下几类上层建筑:

  1. 初始化项目,因为前端越来越复杂,有很多环境需要配置,因此一个优秀的、极度简单的脚手架变得越来越重要,建议使用weex-toolkit或vue-cli;
  2.  开发环境,前端主流编辑器均可应用在Weex中。
  3.  调试,因为无法完全在浏览器内调试,建议在真机情况下调试,目前Weex提供了端上预览、Hot-reload以及Native调试工具。
  4.  测试,目前与Macaca测试框架结合使用。
  5.  打包,目前社区有多种打包方式供选择,如webpack/babel/postcss。
  6.  发布,发布目前不是某个具体的工具,但每一家公司都会有自己搭建、发布、缓存推送的平台,也可以沿用Web研发的最佳实践。
  7.  监控,可以采用曝光埋点、交互埋点等方式,也可以沿用Web研发中的监控最佳实践。

其它注意事项

在具体实践中,总结了一些具体事项:

  •  长列表性能优化 ,可以<list> / <cell>对内存做进一步回收,有一点需要注意的是默认对图片进行回收(即图片在可视区外会自动回收);
  •  流式渲染,通过append=“tree|node”可以控制渲染的颗粒度,进一步优化首屏渲染效果;
  •  View嵌套层级不宜过多,最好不要超过10层;
  •  推荐 Devtool 真机调试。

 

相关文章
|
1月前
|
XML JSON API
ServiceStack:不仅仅是一个高性能Web API和微服务框架,更是一站式解决方案——深入解析其多协议支持及简便开发流程,带您体验前所未有的.NET开发效率革命
【10月更文挑战第9天】ServiceStack 是一个高性能的 Web API 和微服务框架,支持 JSON、XML、CSV 等多种数据格式。它简化了 .NET 应用的开发流程,提供了直观的 RESTful 服务构建方式。ServiceStack 支持高并发请求和复杂业务逻辑,安装简单,通过 NuGet 包管理器即可快速集成。示例代码展示了如何创建一个返回当前日期的简单服务,包括定义请求和响应 DTO、实现服务逻辑、配置路由和宿主。ServiceStack 还支持 WebSocket、SignalR 等实时通信协议,具备自动验证、自动过滤器等丰富功能,适合快速搭建高性能、可扩展的服务端应用。
109 3
|
20天前
|
设计模式 前端开发 数据库
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第27天】本文介绍了Django框架在Python Web开发中的应用,涵盖了Django与Flask等框架的比较、项目结构、模型、视图、模板和URL配置等内容,并展示了实际代码示例,帮助读者快速掌握Django全栈开发的核心技术。
113 45
|
1天前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
13 2
|
16天前
|
前端开发 API 开发者
Python Web开发者必看!AJAX、Fetch API实战技巧,让前后端交互如丝般顺滑!
在Web开发中,前后端的高效交互是提升用户体验的关键。本文通过一个基于Flask框架的博客系统实战案例,详细介绍了如何使用AJAX和Fetch API实现不刷新页面查看评论的功能。从后端路由设置到前端请求处理,全面展示了这两种技术的应用技巧,帮助Python Web开发者提升项目质量和开发效率。
31 1
|
18天前
|
XML 安全 PHP
PHP与SOAP Web服务开发:基础与进阶教程
本文介绍了PHP与SOAP Web服务的基础和进阶知识,涵盖SOAP的基本概念、PHP中的SoapServer和SoapClient类的使用方法,以及服务端和客户端的开发示例。此外,还探讨了安全性、性能优化等高级主题,帮助开发者掌握更高效的Web服务开发技巧。
|
21天前
|
安全 数据库 开发者
Python Web开发:Django框架下的全栈开发实战
【10月更文挑战第26天】本文详细介绍了如何在Django框架下进行全栈开发,包括环境安装与配置、创建项目和应用、定义模型类、运行数据库迁移、创建视图和URL映射、编写模板以及启动开发服务器等步骤,并通过示例代码展示了具体实现过程。
33 2
|
1月前
|
设计模式 测试技术 持续交付
开发复杂Web应用程序
【10月更文挑战第3天】开发复杂Web应用程序
39 2
WK
|
21天前
|
安全 Java 编译器
C++和Java哪个更适合开发web网站
在Web开发领域,C++和Java各具优势。C++以其高性能、低级控制和跨平台性著称,适用于需要高吞吐量和低延迟的场景,如实时交易系统和在线游戏服务器。Java则凭借其跨平台性、丰富的生态系统和强大的安全性,广泛应用于企业级Web开发,如企业管理系统和电子商务平台。选择时需根据项目需求和技术储备综合考虑。
WK
36 0
|
1月前
|
Java PHP
PHP作为广受青睐的服务器端脚本语言,在Web开发中占据重要地位。理解其垃圾回收机制有助于开发高效稳定的PHP应用。
【10月更文挑战第1天】PHP作为广受青睐的服务器端脚本语言,在Web开发中占据重要地位。其垃圾回收机制包括引用计数与循环垃圾回收,对提升应用性能和稳定性至关重要。本文通过具体案例分析,详细探讨PHP垃圾回收机制的工作原理,特别是如何解决循环引用问题。在PHP 8中,垃圾回收机制得到进一步优化,提高了效率和准确性。理解这些机制有助于开发高效稳定的PHP应用。
45 3
|
23天前
|
JavaScript 前端开发 Java
SpringBoot_web开发-webjars&静态资源映射规则
https://www.91chuli.com/ 举例:jquery前端框架
17 0
下一篇
无影云桌面