从0到1实现 OpenTiny 组件库跨框架技术(openui5 框架)

本文分享自华为云社区《从0到1实现 OpenTiny 组件库跨框架技术-云社区-华为云》,作者:华为云社区精选 。

在华为云《DTSE Tech Talk》技术直播第44期《0基础玩转 OpenTiny 跨框架组件库,实现一站式前端进阶》中,华为云前端开发 DTSE 技术布道师莫春辉老师在本期直播中与开发者一起交流了OpenTiny组件库解决方案的核心优势和设计理念,并通过具体的实操给大家演示OpenTiny如何从0到1实现组件库跨框架技术。

从0到1带你开发一个跨框架的UI组件

实现组件库跨框架技术是一种提高 Web 页面开发效率和应用灵活性非常重要的方法。随着前端技术的快速发展,组件库和框架的种类也日益繁多,因此,实现组件库跨框架技术对于解决开发痛点、降低开发成本具有重要意义。

本次实操的目标是搭建一个跨 VueReact、Solid 框架的按钮演示 demo,展示如何实现组件库跨框架技术的应用。通过本期的演练,希望能够为开发者提供一个清晰、具体的实现过程,帮助大家更好地理解这一技术的实际应用。

具体源码可参考:https://github.com/opentiny/dtt-cfc

从0到1实现 OpenTiny 组件库跨框架技术(openui5 框架)

本次实操流程主要是分为四个部分:

1、初始化工程

a) 使用pnpm管理项目,并配置pnpm-workspace.yaml

b) 配置项目eslint、prettier和git环境

从0到1实现 OpenTiny 组件库跨框架技术(openui5 框架)

2、创建 vue 应用并添加 @opentiny/vue-button 组件相关逻辑:

a) 初始化 Vue应用

b) 开发 Vue 组件的适配层和vue-button组件

c) 开发适配无渲染层renderless的js文件

从0到1实现 OpenTiny 组件库跨框架技术(openui5 框架)

3、创建 react 应用并添加 @opentiny/react-button 组件相关逻辑:

a) 初始化 React 应用

b) 开发 React 组件的适配层和react-button组件

c) 开发适配无渲染层renderless的js文件

从0到1实现 OpenTiny 组件库跨框架技术(openui5 框架)

4、创建 Solid 应用并添加 @opentiny/solid-button 组件相关逻辑:

a) 初始化 Solid 应用

b) 开发 Solid 组件的适配层和solid-button组件

c) 开发适配无渲染层renderless的js文件

从0到1实现 OpenTiny 组件库跨框架技术(openui5 框架)

TinyVue组件库当前已实现跨端、跨框架、跨版本

得益于 Renderless 无渲染的设计架构,OpenTiny 项目的 TinyVue 作为一个 Vue 组件库,不仅实现了组件库跨框架,同时也实现了一套代码不仅同时支持 Vue 2 / Vue 3,还同时支持PC和移动端,更适应多主题规范。在实际应用中,开发者是可以开发出跨终端(PC端、移动端、手表端)、跨框架(Vue2、Vue3、React、Solid)、跨主题(字体、颜色、圆角、图标…)、跨设计规范(图标、交互、默认配置…)的项目。

下图是 OpenTiny 跨端、跨框架、跨版本、跨设计规范示例启动后的演示效果(具体源码可以参考:https://github.com/opentiny/cross-framework-component):

从0到1实现 OpenTiny 组件库跨框架技术(openui5 框架)

那为什么 OpenTiny 要实现组件库跨端、跨框架、跨版本呢?

目前业界组件库,一般按前端框架React、Angular、Vue的不同来分类。要么按面向的终端,如PC组件库、Mobile组件库、小程序组件库等。由于 Vue 2和 Vue 3版本不能兼容,因此 Vue 2的组件库跟 Vue 3的组件库代码是不同的,即同一个技术栈也有不同版本的组件库。当前现状对于开发组件库和使用组件库都无疑是一种负担。

而且Vue 2 / Vue 3 两套组件库对应两套不同的代码,难免存在组件功能和 API 不同步的情况,开发者如果要从 Vue 2 组件库迁移到 Vue 3 组件库,将面临一定的成本和风险。

当前组件库分类如下所示:

从0到1实现 OpenTiny 组件库跨框架技术(openui5 框架)

面对相当业界的痛点,TinyVue 采用组件与框架分离的设计理念(Renderless 架构),通过让 Web 组件支持跨端跨技术栈跨 UX 规范的特性,使得开发人员只需开发和维护一套组件库代码,就能推出不同终端不同技术栈的版本,减少开发和维护的成本。同时用户在使用这套组件库时,虽然在使用不同终端不同技术栈的版本,但由于底层基于一套代码,其 API 接口基本相同,从而降低用户学习使用以及迁移升级的成本。

从0到1实现 OpenTiny 组件库跨框架技术(openui5 框架)

当然,这套设计架构需要同时结合面向业务逻辑的开发范式与无渲染组件的设计模式。因为单纯使用面向业务逻辑的开发范式,仅仅只能让相同的业务逻辑从原本散落到生命周期各个阶段的部分汇聚到一起。而无渲染组件的设计模式的实现方式有很多种,比如React中可以使用HOC高阶函数,Vue中可以使用 scopedSlot 作用域插槽,但当组件业务逻辑日趋复杂时,高阶函数和作用域插槽让代码变得难以理解和维护。因此只有将两者结合在一起,才有实现 Web 组件支持跨端、跨框架的可能性。

TinyVue 通过完成设备适配、分辨率适配、交互适配等问题,最终达到在不同的框架和不同终端中使用的效果。不仅如此,针对 Vue 2 和 Vue 3 ,TinyVue 还推出了相应的版本适配器,抹平 Vue 2 和 Vue 3 的差异,实现一套代码同时支持 Vue 2 和 Vue 3两个版本。这样不管是 Vue 2 项目还是 Vue 3 项目,使用组件的方式都是一样的,可以实现无缝切换,极大地降低了 Vue 2 迁移到 Vue 3 的成本和风险。

总结:

OpenTiny 是一套企业级 Web 前端开发解决方案,提供跨端、跨框架的UI组件库,适配 PC 端 / 移动端等多端,支持 Vue2 / Vue3 / Angular 多技术栈,拥有灵活扩展的低代码引擎,包含主题配置系统 / 中后台模板 / CLI 命令行等丰富的效率提升工具,可帮助开发者高效开发 Web 应用。

当然 OpenTiny 作为华为云解决方案中的重要组成部分,使能开发者构建云原生应用,也将助力开发者提高应用的性能和可靠性,促进应用的创新和发展。

从0到1实现 OpenTiny 组件库跨框架技术(openui5 框架)

未来,随着技术的不断发展和应用,OpenTiny 也将持续为开发者带来更加便利和高效的体验。

关注#华为云开发者联盟# 点击下方,第一时间了解华为云新鲜技术~

华为云博客_大数据博客_AI博客_云计算博客_开发者中心-华为云

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

(0)
上一篇 2024年5月16日 下午2:06
下一篇 2024年5月16日 下午2:18

相关推荐

  • 如何抓好基层党建工作(如何抓好基层党建工作发言稿)

    一、严格落实书记抓党建工作“第一责任人”职责。 各级党组织书记一定要在思想认识、责任担当、方法措施上贯彻党要管党、从严治党要求,强化抓党建的主角意识和主动精神,牢固树立抓好党建是最…

    科研百科 2023年9月13日
    103
  • 物业服务管理软件(物业管理软件软件)

    物业管理软件软件介绍 随着物业管理行业的不断发展,物业管理软件软件已经成为了物业管理的重要组成部分。物业管理软件软件能够帮助物业管理公司更好地管理物业,提高服务质量,降低管理成本。…

    科研百科 2024年8月30日
    39
  • 中国科学技术大学是一所很牛的大学,也是一所很特殊的大学(中国科学技术大学是什么大学)

    一提到中国科学技术大学,很多人都认为这所大学是一所很牛、很特殊的大学,这所大学真的有那么牛、那么特殊吗? 中国科学技术大学(中国科大、中科大)是一所以理工科为主的综合性研究型大学,…

    科研百科 2024年4月6日
    114
  • 2024年巡察工作汇报材料

    2024年巡察工作汇报材料 尊敬的领导、各位同事: 经过2024年的巡察工作,我们取得了一些成绩,但也发现了一些问题和不足。在此,我代表巡察小组,向各位领导和同事们汇报一下我们的工…

    科研百科 2024年10月4日
    54
  • 美萍会员业务管理系统简介(美萍会员管理系统v9.0标准版)

    美萍会员业务管理系统是一款专业的商业业务管理软件,其中包含商品业务管理系统,会员管理系统,库存管理系统(仓库管理系统),财务管理系统等模块。软件界面设计简洁,美观,其人性化的软件流…

    科研百科 2023年3月15日
    503
  • 软件项目学生管理系统

    软件项目学生管理系统 随着科技的不断发展,软件开发已经成为一个热门的领域。在这个领域中,软件项目学生管理系统是一个至关重要的工具,它可以帮助开发人员更好地管理项目和学生。本文将介绍…

    科研百科 2024年12月17日
    0
  • 软件开发自主化:一条比拼韧性和耐性的赛道(自主软件产品开发流程)

    老陈最近有点上火。 作为在杭州的一家智慧城市系统开发商,上半年接了湖北一个地级市的订单。在帮助城市升级交通管理系统的同时,要帮这个城市搭建智慧交通和智慧城管的软件框架。 订单由于是…

    科研百科 2023年3月20日
    145
  • Excel协调编辑

    Excel协调编辑Excel协调编辑近日,受新冠肺炎疫情影响,贵州省专访6月24日,重庆静山外国语学校办公室招聘一名实习生。因疫情情况,他们只能选择报警。现场,记者的朋友问了一名在…

    科研百科 2024年11月18日
    0
  • 社会工作部哪个科室比较好

    社会工作部哪个科室比较好 随着社会发展,社会工作部成为了社会机构中不可或缺的一部分。社会工作部通常包括多个科室,如社会服务科、儿童保护科、心理健康科等。这些科室的工作内容各不相同,…

    科研百科 2024年11月15日
    0
  • 开票3.0

    开票3.0:创新与实践的平衡 随着数字化技术的不断发展,开票3.0已经成为了现代企业运营的重要工具。在开票3.0中,数据和技术已经成为核心要素,企业可以通过自动化和智能化的方式快速…

    科研百科 2024年11月9日
    0