资讯专栏INFORMATION COLUMN

【重磅】Chameleon 开放跨端扩展标准协议

shuibo / 2636人阅读

摘要:但是从年微信推出小程序,到至今各大厂商都推出自己的小程序,跨端开发就不仅仅是技术的问题了。实现了微信端的基本扩展,用户可以以此为模板进行开发。

新框架太多?学不动啦?有这一套跨端标准,今后再也不用学习新框架了。

各个小程序按自己喜好“各自为政”?有了这套标准,再也不用重复开发各种新平台啦。

如今前端比较流行的 React Native、Weex、Flutter 等跨平台开发框架,对于开发来说属于技术方案的选择,比如,我们会考虑用这个技术开发,性能会不会超过 h5,开发效率会不会超过原生开发等等。

但是从 2017 年微信推出小程序,到至今各大厂商都推出自己的小程序,跨端开发就不仅仅是技术的问题了。已经变成了必争的流量入口。现在的小程序大战像极了当前的浏览器大战。大战中受苦的是我们一线开发者,同样的应用要开发 N 次,面对了前所未有的挑战,所以跨端框架的产生是大趋势下的必然产物。

chameleon 基于对跨端工作的积累, 规范了一套跨端标准,称之为 MVVM+协议;开发者只需要按照标准扩展流程,即可快速扩展任意 MVVM 架构模式的终端。并让已有项目无缝运行新端。所以如果你希望让 chameleon 快速支持淘宝小程序、React Native?只需按标准实现即可扩展。

最终让开发者只需要用 chameleon 开发,就可以在任意端运行,再也不用学习新平台框架啦。

新端接入情况

滴滴、芒果 TV、阿里的同学合作,正在按照跨端协议流程进行字节跳动小程序的共建开发。

分工排期如下:https://github.com/didi/chame...

仓库地址: https://github.com/chameleon-...

快应用官方研发团队也正在接入中

分工排期如下:https://github.com/didi/chame...

仓库地址: https://github.com/quickappcn...

跨端原理

跨端框架最核心的工作是统一,chameleon 定义了标准的跨端协议,通过编译时+运行时的手段去实现各端的代码和功能,其实现原理如下图所示。

其中运行时和基础库部分利用多态协议实现各端的独立性与框架的统一性。chameleon 目前支持的端都是采用这种方式,我们定义了扩展一个新端所需要实现的所有标准,用户只需要按照这些标准实现即可完成一个新端的扩展。

跨端标准协议

我们再来看一张 chameleon 的设计图,能够实现标准化的扩展新端,得益于多态协议中对各层代码进行了接口的定义,各端代码按照接口定义进行实现,向用户代码提供统一调用,同时还提供”多态协议“让用户代码保障可维护性的前提下,直接触达各端原生能力的方式。

API 接口协议:定义基础接口能力标准。

内置组件协议:定义基础 UI 组件标准。

框架协议:定义生命周期、路由等框架标准。

DSL 协议:定义视图和逻辑层的语法标准。

多态实现协议:定义允许用户使用差异化能力标准。

如何扩展新端?

简单来说只需要实现 6 个 npm 包。

实现 API 接口协议

chameleon-api提供了网络请求,数据存储,获取系统信息,交互反馈等方法,用户需要创建一个 npm 包,结构参考cml-demo-api。将chameleon-api中提供的每个方法利用多态接口扩展语法扩展新端的实现。
以扩展一个alert方法为例,chameleon-apialert方法的接口定义文件为chameleon-api/src/interfaces/alert.interface,其中的接口定义内容如下:

  

用户实现的interface文件中采用语法引入chameleon-apialert方法的 interface 文件, 实现uiInterface

// 引入官方标准interface文件

// 扩展实现新端(以头条小程序为例,假设端扩展标识为:tt)
实现内置组件协议

组件分为内置组件chameleon-ui-builtin和扩展组件cml-ui。所以用户需要创建两个 npm 包分别实现这两个组件库,结构参考cml-demo-ui-builtin和cml-demo-ui。利用多态组件扩展语法,对原有组件库中的每一个组件进行新端的实现。

原有组件库中的组件也分为两种,一种为各端都有分别实现的多态组件,例如chameleon-ui-builtin中的button组件。实现起来新端基本上也是要多带带实现。另一种例如chameleon-ui-builtin中的radio组件,各端的实现都是用的chameleon-ui-builtin/components/radio/radio.cml。所以新端基本也可以复用这个实现,(还需要测试情况确实是否可以复用)。

新端独立实现

例如:

编写 my-ui-builtin/components/button/button.interface

// 引入官方标准interface文件

编写 my-ui-builtin/components/button/button.demo.cml




独立实现的my-ui-builtin/components/button/button.demo.cml文件属于多态组件的灰度层,可以调用各端底层组件和 api,具体例子参见button和scroller的实现。

新端复用现有组件

编写 my-ui-builtin/components/radio/button.interface

// 引入官方标准interface文件

// 复用官方的实现
实现 DSL 协议(编译时插件)

chameleon 内部会将整个项目文件编译为如下编译图结构,节点中的内容经过了标准编译,比如script节点的babel处理,style节点的lessstylus处理等等。

节点的数据结构如下:

class CMLNode {
  constructor(options = {}) {
    this.realPath; // 文件物理地址  会带参数
    this.moduleType; // template/style/script/json/asset
    this.dependencies = []; // 该节点的直接依赖       app.cml依赖pages.cml pages.cml依赖components.cml js依赖js
    this.childrens = []; // 子模块 cml文件才有子模块
    this.source; // 模块源代码
    this.output; // 模块输出  各种过程操作该字段
    ......
  }
}

用户只需要实现一个编译插件类,利用钩子方法实现对节点的编译,所有节点编译完后再进行文件的组织。编译类如下:

module.exports = class DemoPlugin {
  constructor(options) {
    ......
  }
  /**
   * @description 注册插件
   * @param {compiler} 编译对象
   * */
  register(compiler) {
    // 编译script节点,比如做模块化
    compiler.hook("compile-script", function(currentNode, parentNodeType) {
    })
    // 编译template节点 语法转义
    compiler.hook("compile-template", function(currentNode, parentNodeType) {
    })
    // 编译style节点  比如尺寸单位转义
    compiler.hook("compile-style", function(currentNode, parentNodeType) {
    })
    // 编译结束进入打包阶段
    compiler.hook("pack", function(projectGraph) {
      // 遍历编译图的节点,进行各项目的拼接
      // 调用writeFile方法写入文件
      // compiler.writeFile()
    })
    ......
  }
}
实现框架协议

运行时主要是对 cml 文件的逻辑对象进行适配,chameleon 内部将 cml 文件的逻辑对象分为三类 App、Page、Component。对应会调用用户运行时 npm 包的createApp、createPage、createComponent方法,所以对外只需要实现这三个方法。

例如一个 Page 的逻辑对象如下:

class PageIndex {
  data = {
    name: "chameleon"
  }
  computed = {
    sayName () {
      return "Hello" + this.name;
    }
  }
  mounted() {
  }
}
export default new PageIndex();

编译时就会自动插入用户的运行时方法处理逻辑对象,例如cml-demo-runtime

class PageIndex {
  ......
}
export default new PageIndex();

// 编译时自动插入用户配置的运行时方法
import {createPage} from "cml-demo-runtime";
createPage(exports.default);

createApp、createPage、createComponent方法,参考cml-demo-runtime的结构进行实现,需要include chameleon-runtime中相应的接口进行实现,才能够实现对chameleon-runtime的扩展。用户的工作量主要在于对逻辑对象的处理,可以参考chameleon-runtime中的实现方式,一般需要如下方面的适配工作。

从宏观来看,运行时处理可分为:

输入Options对象的适配,参考

跨端运行时能力注入,参考

从微观来看,有以下处理:

生命周期:映射表参考 和 实现参考

组件 props 属性:适配参考 和 变化监听参考

数据响应:数据响应实现参考

computed 计算能力:实现参考

watch 监听能力:适配参考 和 实现参考

methods 方法属性:适配参考

mixins 能力:适配参考 和 合并参考

生命周期多态

例如: createPage 方法的实现


实现框架数据管理

chameleon-store提供了类似 Vuex 的数据管理解决方案,具体标准参见数据管理。同样利用多态协议实现其功能。

更多

扩展新端 demo 示例仓库: https://github.com/chameleon-...。 实现了微信端的基本扩展,用户可以以此为模板进行开发。

更详细的教程参见扩展新端操作教程。

期待更多人的加入开源。想了解更多 chameleon 信息请访问官网 cmljs.org

预告:chameleon 1.0正式版即将到来

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/109726.html

相关文章

  • 重磅Chameleon 开放跨端扩展标准协议

    摘要:基于对跨端工作的积累,规范了一套跨端标准,称之为协议开发者只需要按照标准扩展流程,即可快速扩展任意架构模式的终端。实现了微信端的基本扩展,用户可以以此为模板进行开发。新框架太多?学不动啦?有这一套跨端标准,今后再也不用学习新框架了。各个小程序按自己喜好各自为政?有了这套标准,再也不用重复开发各种新平台啦。如今前端比较流行的 React Native、Weex、Flutter 等跨平台开发框架...

    liangdas 评论0 收藏0
  • 开源中国专访:Chameleon原理首发,其它跨多端统一框架都是假的?

    摘要:中国互联网络信息中心发布的中国互联网络发展状况统计报告显示,截至年月,我国网民规模达亿人,微信月活亿支付宝月活亿百度月活亿另一方面,中国手机占智能手机整体的比例超过,月活约亿。在年末正式发布了面向未来的跨端的。 开源中国专访:Chameleon原理首发,其它跨多端统一框架都是假的? 原创: 嘉宾-张楠 开源中国 以往我们说某一功能跨多端,往往是指在诸如 PC、移动等不同类型的设备之...

    GraphQuery 评论0 收藏0
  • Chameleon跨端框架——壹个理想主义团队的开源作品

    摘要:跨端框架壹个理想主义团队的开源作品历经近个月打磨,滴滴跨端方案终于开源了真正专注于一套代码运行多端。这时候我们专门成立了一个人的小项目组,完成一个名为的项目,一期目标是不影响用户发挥,不依赖框架方的原则性实现一套代码运行和微信小程序。 Chameleon跨端框架——壹个理想主义团队的开源作品 历经近20个月打磨,滴滴跨端方案chameleon终于开源了https://github.co...

    darkbug 评论0 收藏0
  • 编写chameleon跨端组件的正确姿势(上篇)

    摘要:使用语法统一实现跨端组件请关注文章编写跨端组件的正确姿势下篇依靠强大的多态协议,项目中可以轻松使用各端的第三方组件封装自己的跨端组件库。这种做法同时解决了组件命名冲突问题,例如在微信小程序端引用表示调用小程序原生的组件而不是内置的组件。 在chameleon项目中我们实现一个跨端组件一般有两种思路:使用第三方组件封装与基于chameleon语法统一实现。本篇是编写chameleon跨端...

    h9911 评论0 收藏0

发表评论

0条评论

shuibo

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<