四时宝库

程序员的知识宝库

weex程序运行环境与web浏览器环境差异简介

本文主要参考week官方wiki。

Weex 是一个跨平台解决方案,Web 平台只是其一种运行环境,除此之外还可以在 Android 和 iOS 客户端中运行,在Android的iOS平台上运行时,jsbundle会被转化成原生程序执行,原生平台和 Web 平台的执行环境存在一定差异,在功能和开发体验上都有一定差异,尤其要注意web平台执行环境中特有的BOM和DOM对象。

主要差异如下:

Weex 环境中没有 DOM

DOM(Document Object Model),即文档对象模型,是 HTML 和 XML 文档的编程接口,是 Web 中的概念。Weex 的运行环境以原生应用为主,在 Android 和 iOS 环境中渲染出来的是原生的组件,不是 DOM Element。

不支持 DOM 操作

Android和iOS原生环境中不支持 Web API,没有 Element 、Event 、File 等对象。不支持选中元素,如 document.getElementById 、 document.querySelector 等;也不支持基于 DOM API 的程序库。

有限的事件类型

Weex 支持在标签上绑定事件,和在浏览器中的写法一样,但是 Weex 中的事件是由原生组件捕获并触发的,行为和浏览器中有所不同,事件中的属性也和 Web 中有差异。

  • 只支持 Web 中部分事件类型。
  • 不区分事件的捕获阶段和冒泡阶段。

Weex 环境中没有 BOM

BOM(Browser Object Model),即浏览器对象模型,是浏览器环境为 javascript 提供的接口。Weex 在原生端没有并不基于浏览器运行,不支持浏览器提供的 BOM 接口。

没有 window 、screen 对象

Weex 中并未提供浏览器中的 window 和 screen 对象,不支持使用全局变量。如果是想要获取设备的屏幕或环境信息,可以使用 WXEnvironment 变量,可获取信息具体如下:

  • WXEnvironment
  • weexVersion: WeexSDK 的版本。
  • appName: 应用的名称。
  • appVersion: 应用的版本。
  • platform: 运行平台,可能的值是 Web 、Android 、iOS 之一。
  • osName: 系统的名称。
  • osVersion: 系统版本。
  • deviceWidth: 设备宽度。
  • deviceHeight: 设备高度。

没有 document 对象

在浏览器中 document 表示了当前活动的文档模型,在 Android 和 iOS 环境中并没有这个对象,也不支持与其相关的 DOM 操作。

没有浏览器中的 history 、location 、navigator 对象

  • history 保存了当前页面的历史记录,并且提供了前进后退操作。
  • location 记录了当前页面 URL 相关的信息。
  • navigator 记录了当前浏览器中的信息。

在 Android 和 iOS 中也有“历史”和“导航”的概念,但是它是用于多个管理视图之间的跳转的。在浏览器中执行“前进”、“后退”仍然会处于同一个页签中,在原生应用中“前进”、“后退”则会真实的跳转到其他页面。

Weex 也提供了 navigator 模块来操作页面的跳转,该navigator与浏览器中的navigator不同,通过weex.requireModule('navigator')引入。

能够调用移动设备原生 API

在 Weex 中能够调用移动设备原生 API,使用方法是通过注册、调用模块来实现。其中有一些模块是 Weex 内置的,如 clipboard 、 navigator 、storage 等。

  • clipboard 剪切板
  • navigator 导航控制
  • storage 本地存储

为了保持框架的通用性,Weex 内置的原生模块有限,不过 Weex 提供了横向扩展的能力,可以扩展原生模块。

发表评论:

控制面板
您好,欢迎到访网站!
  查看权限
网站分类
最新留言
    友情链接