毕业论文
您现在的位置: 卡片 >> 卡片前景 >> 正文 >> 正文

优维低代码对构件组合的封装,自定义模板

来源:卡片 时间:2025/7/27
白癜风专家哪里最好 http://www.znlvye.com/

文章我们讲述了基于WebComponents的构件,可复用的构件是EasyMABuilder的基础。

现代软件的开发追求最大化的可复用性,因为软件复用带来诸多好处:提升研发效率、降低研发成本、降低过程风险、增加可靠性、有利于标准化等。

构件,就是EasyMABuilder中可复用的单元,通过组合现有的构件就可以搭建出完整的Web应用。

而随着应用规模的增长,开发者可能需要更上层的复用,即:将一套构件的组合封装成一个新的可复用的单元,并且希望它能像普通构件那样使用。例如我们可能需要一个显示趋势图的卡片,它由一个卡片构件及一个趋势图构件组成,我们希望将这个定制卡片能复用在多个页面中。

EasyMABuilder对此提供了对构件组合的封装:自定义模板,以下我们简称为模板。

创建模板的界面与编排一个普通页面的界面完全一致,因为它们都是编排一套构件的组合。

不同的是,模板将内部的构件封装了起来,并且可以按需对外暴露属性、事件、方法和插槽,并将这些信息映射到内部的构件,这样,模板也有了普通构件的几大要素,因此它就可以像普通构件那样在各个地方复用。

例如,上文提到的趋势图卡片,我们可以先编排好模板的构件结构:

为了提升这个模板的可复用性,我们扩展一下它的能力,支持由外部传入卡片的标题和趋势图的数据源,进行一下属性映射的配置:

这样,我们的模板就有了两个属性chartTitle和dataSource,设置或读取它们等同于读取内部构件的对应属性。

例如,我们可以在页面中同时编排两个趋势图卡片,分别显示CPU使用率和内存使用率:

事件、方法和插槽的映射方式与属性类似,其中,插槽的映射是系统在运行时通过模板的展开来实现的。

例如,假设我们为上面的模板再添加一个附加按钮的插槽addon,映射到卡片构件的对应插槽上,然后我们为上面的CPU使用率卡片添加一个查看详细信息的附加按钮。

在模板被展开之前的页面storyboard中,构件树大约长这样:

展开后:

每个模板在运行时将被分别展开,其中的插槽下的子构件也会被移植到指定的内部构件的对应插槽上。例如上面的查看详情的附加按钮view-detail就被移植到了CPU使用率所在模板内部的卡片构件的addon插槽中。

自定义模板可以在每个应用内维护,也可以选择在多个应用之间连接共享,还可以单独打包并纳入平台的构件资源库中,就像普通的构件包一样。

由于模板就是构件组合的编排,因此可以轻易地将现有的页面编排的某个部分转换成模板,以便在别处复用,这样可以更加平滑地进行应用的迭代研发。

以上我们讲诉了自定义模板在兼容普通构件的基本能力的前提下,通过对构件组合的封装,在EasyMABuilder中提供了更上层的可复用单元,从而让开发者以更高的效率和更好的可靠性完成应用的编排。

在低代码平台中,除了组织基本的UI界面结构外,还有一项重要的工作是维护和管理数据,特别是来自远端的异步数据和动态变更的状态数据。

转载请注明:http://www.0431gb208.com/sjsbszl/9927.html