LiteFlow LiteFlow
💒首页
  • v2.13.2(当前版本)
  • What's New

    • 🌈What' s New In LiteFlow v2.13.2?
  • 历史版本

    • v2.12.X
    • v2.11.X
    • v2.10.X
    • v2.9.X
    • v2.8.X
  • 升级指南

    • 🌈2.13.0升级指南
    • 2.12.4升级指南
    • 2.12.0升级指南
    • 升级到2.9.3说明
    • 升级到2.9.X说明
    • 升级到2.8.X说明
    • 升级到2.7.X说明
👑LF CLUB社区
  • 常见问题
  • 专题解释

    • 如何理解上下文这个概念?
    • Slot是一个什么样的概念,在框架中起到什么样的作用?
💖赞助
🧩插件
🔥PPT
  • 项目介绍
  • 项目成员
  • 更新记录
  • 参与开发
👥加入群聊
🧤谁在使用
  • Gitee (opens new window)
  • GitCode (opens new window)
  • Github (opens new window)

广告采用随机轮播方式显示 ❤️成为赞助商
💒首页
  • v2.13.2(当前版本)
  • What's New

    • 🌈What' s New In LiteFlow v2.13.2?
  • 历史版本

    • v2.12.X
    • v2.11.X
    • v2.10.X
    • v2.9.X
    • v2.8.X
  • 升级指南

    • 🌈2.13.0升级指南
    • 2.12.4升级指南
    • 2.12.0升级指南
    • 升级到2.9.3说明
    • 升级到2.9.X说明
    • 升级到2.8.X说明
    • 升级到2.7.X说明
👑LF CLUB社区
  • 常见问题
  • 专题解释

    • 如何理解上下文这个概念?
    • Slot是一个什么样的概念,在框架中起到什么样的作用?
💖赞助
🧩插件
🔥PPT
  • 项目介绍
  • 项目成员
  • 更新记录
  • 参与开发
👥加入群聊
🧤谁在使用
  • Gitee (opens new window)
  • GitCode (opens new window)
  • Github (opens new window)
  • 🍤LiteFlow简介
  • 🍓项目特性
  • 🧁环境支持

  • 🍟快速开始(Hello world)

  • 🍢配置项

  • 🔗组件

  • 🧩EL规则

  • 🌮上下文

  • 🛩执行器

  • 🍋脚本组件

    • 🌭脚本语言介绍
    • 🍫脚本语言种类

      • ☕️Java脚本引擎
      • 🥏Groovy脚本引擎
      • 🧀Javascript脚本引擎
        • 依赖
        • 使用
        • 脚本类型
        • 如何取到上下文以及和Java类进行交互
      • 🥞QLExpress脚本引擎
      • 🍧Python脚本引擎
      • 🍝Lua脚本引擎
      • 🥐Aviator脚本引擎
      • 🥠Kotlin脚本引擎
    • 🍣脚本与Java进行交互
    • 🍱多脚本语言混合共存
    • 🌯文件脚本的定义
    • 🍘动态刷新脚本
    • 🍦验证脚本
    • 🗑卸载脚本
  • 🗂规则配置源

  • 🍼元数据管理

  • 🌌异步中的线程池

  • 🎲动态构造

  • 🧮决策路由

  • 😸生命周期

  • 🎨高级特性

  • ⛱测试用例以及示例

  • 🪂性能表现
  • v2.13.X文档
  • 🍋脚本组件
  • 🍫脚本语言种类
铂赛东
2023-08-28
目录

🧀Javascript脚本引擎

# 依赖

对于Javascript脚本,你有两种引擎可以选择,一种是基于jdk的js引擎实现,只支持ES5。另一种是基于GraalJs引擎实现,支持ES6。

如果你使用jdk8,你可以选用下面任意一种脚本引擎,而jdk11和jdk17,你只能选用graaljs引擎,因为jdk8之后的jdk已经移除了jdk自带的Nashorn JavaScript引擎。

<dependency>
    <groupId>com.yomahub</groupId>
    <artifactId>liteflow-script-javascript</artifactId>
    <version>2.13.2</version>
</dependency>
<dependency>
    <groupId>com.yomahub</groupId>
    <artifactId>liteflow-script-graaljs</artifactId>
    <version>2.13.2</version>
</dependency>

# 使用

你需要在你的xml中去定义node节点,以下是一个示例

<node id="s1" name="普通脚本1" type="script" language="js">
    <![CDATA[
        var a=3;
        var b=2;
        var c=1;
        var d=5;

        function addByArray(values) {
            var sum = 0;
            for (var i = 0; i < values.length; i++) {
                sum += values[i];
            }
            return sum;
        }

        var result = addByArray([a,b,c,d]);

        defaultContext.setData("s1",parseInt(result));
    ]]>
</node>

以上是一个普通脚本组件的示例,你可以用js的绝大部分语法特性,甚至还可以在脚本里定义Function。

# 脚本类型

要注意的是,type分为4种:

script:普通脚本节点,脚本里无需返回。

switch_script:选择脚本节点,脚本里需要返回选择的节点Id。

boolean_script:条件脚本节点,脚本里需要返回true/false。

for_script:数量循环节点,脚本里需要返回数值类型,表示循环次数。

注意

脚本组件中无法定义循环迭代组件。

# 如何取到上下文以及和Java类进行交互

关于这部分,请详细参考脚本与Java进行交互这一章节。

帮助我们改善此文档 (opens new window)
上次更新: 2025/05/07, 13:09:49
🥏Groovy脚本引擎
🥞QLExpress脚本引擎

← 🥏Groovy脚本引擎 🥞QLExpress脚本引擎→

Theme by Vdoing | Copyright © 2020-2025 铂赛东 | MIT License
沪ICP备18012955号-2
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式