• 优维低代码:Storyboard Functions 微应用函数


    优维低代码技术专栏,是一个全新的、技术为主的专栏,由优维技术委员会成员执笔,基于优维7年低代码技术研发及运维成果,主要介绍低代码相关的技术原理及架构逻辑,目的是给广大运维人提供一个技术交流与学习的平台。


    连载第二十八期

    《高级指引:Storyboard Functions 微应用函数》

    # 背景

    在编排微应用时,经常需要进行数据加工,有些复杂的加工方法,我们可以通过 Custom Processors 自定义加工函数来实现。 

    这些在代码仓库中管理的加工函数,可以享受代码仓库带来的好处:代码风格和静态检查及自动修复、使用 TypeScript 增强代码健壮性、严格的单元测试流程提升代码质量等等。不过它同时也带来了一些不便:编写门槛较高、发布周期较长、需要管理依赖版本等等。

    因此我们还提供了微应用级别的等价加工函数:Storyboard Functions 微应用函数,它与 Custom Processor 的能力基本一致,同样用于数据加工处理,但是可以直接在 Next Builder 中进行编写和使用,并跟随微应用一起发布。

    # 说明

    Storyboard Functions 的定位为纯粹地处理数据加工,使用 JavaScript 或 TypeScript 编写,对页面数据无感知(不可以直接引用 CTX 等页面运行时数据,但可以使用参数传递过来),可以在 Evaluate Placeholder 求值占位符中通过 FN.yourFunction(params) 来调用它。

    例如,编写以下函数:

    function sayHello(params) {  return `Hello, ${params.name}`;}

    在编排时可以这样使用:

    anyProp: '<% FN.sayHello({ name: "world" }) %>'

    函数中还可以使用在 evaluate placeholder 求值占位符中的、与运行时状态无关的几个框架内置对象:

    _ (Lodash)

    moment

    FN

    PIPES

    TAG_URL

    SAFE_TAG_URL

    I18N

    I18N_TEXT

    IMG

    例如,可以在函数中使用同一个微应用的其它函数,例如:​​​​​​​

    function sayHello(params) {  return FN.sayExclamation(`Hello, ${params.name}`);}

    # 测试用例

    Storyboard Functions 通常包含较复杂的逻辑,因此需要编写测试用例来保障其质量。该功能暂未开发完成。

    # 注意

    编写 Storyboard Functions 时可以使用绝大多数的 JavaScript/TypeScript 语法,但由于它的定位仅为纯数据加工,以及出于对函数代码的健壮性和可维护性等因素的考虑,限制了部分语法和能力。

    不推荐或不支持的语法清单:

    🚫 Async/Await: async function() { await … }

    🚫 Generator: function* a() { yield … }

    🚫 Class: class A { … }

    🚫 ThisExpression: this.anyProp

    🚫 VarDeclaration of var: var a

    🚫 LabeledStatement: anyLabel: …

    🚫 WithStatement: with (…) { … }

    🚫 DebuggerStatement: debugger

  • 相关阅读:
    Transformer——台大李宏毅详讲Transformer
    教师办公实用小程序有哪些
    elasticsearch的基本操作
    仿真测试断开服务器公网连接
    20 个 JS 工具函数助力高效开发
    高速公路智能公专融合调度系统方案
    golang语言和JAVA对比
    kuiper安装
    从Redis分布式缓存实战入手到底层原理分析、覆盖大厂面试考点
    Vue组件的渲染更新原理知识大连串
  • 原文地址:https://blog.csdn.net/EasyOps_DevOps/article/details/127810784