当前位置:首页 > JavaScript

java 实现js

2026-03-01 01:58:21JavaScript

在 Java 中实现 JavaScript 功能

Java 可以通过调用 JavaScript 引擎来执行 JavaScript 代码,常用的引擎包括 Nashorn(JDK 8-14)和 GraalVM(JDK 15+)。以下是具体实现方法。

使用 Nashorn 引擎(JDK 8-14)

Nashorn 是 JDK 8 到 14 中内置的 JavaScript 引擎,可以直接调用。

import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;

public class NashornExample {
    public static void main(String[] args) {
        ScriptEngineManager manager = new ScriptEngineManager();
        ScriptEngine engine = manager.getEngineByName("nashorn");

        try {
            engine.eval("var result = 10 + 20;");
            Object result = engine.eval("result;");
            System.out.println("Result: " + result);
        } catch (ScriptException e) {
            e.printStackTrace();
        }
    }
}

使用 GraalVM 引擎(JDK 15+)

从 JDK 15 开始,Nashorn 被移除,推荐使用 GraalVM 的 JavaScript 引擎。

import org.graalvm.polyglot.Context;
import org.graalvm.polyglot.Value;

public class GraalVMExample {
    public static void main(String[] args) {
        try (Context context = Context.create()) {
            Value result = context.eval("js", "10 + 20");
            System.out.println("Result: " + result.asInt());
        }
    }
}

在 Java 中调用 JavaScript 函数

可以通过 eval 方法定义 JavaScript 函数,并在 Java 中调用。

import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;

public class JsFunctionExample {
    public static void main(String[] args) {
        ScriptEngineManager manager = new ScriptEngineManager();
        ScriptEngine engine = manager.getEngineByName("nashorn");

        try {
            engine.eval("function add(a, b) { return a + b; }");
            Object result = engine.eval("add(10, 20);");
            System.out.println("Result: " + result);
        } catch (ScriptException e) {
            e.printStackTrace();
        }
    }
}

在 Java 和 JavaScript 之间传递数据

可以通过 Bindings 对象在 Java 和 JavaScript 之间共享变量。

import javax.script.Bindings;
import javax.script.ScriptEngine;
import javax.script.ScriptEngineManager;
import javax.script.ScriptException;

public class DataPassingExample {
    public static void main(String[] args) {
        ScriptEngineManager manager = new ScriptEngineManager();
        ScriptEngine engine = manager.getEngineByName("nashorn");
        Bindings bindings = engine.createBindings();

        bindings.put("x", 10);
        bindings.put("y", 20);

        try {
            Object result = engine.eval("x + y", bindings);
            System.out.println("Result: " + result);
        } catch (ScriptException e) {
            e.printStackTrace();
        }
    }
}

使用 GraalVM 实现更复杂的交互

GraalVM 支持多语言交互,可以在 Java 中直接调用 JavaScript 函数并传递复杂对象。

java 实现js

import org.graalvm.polyglot.Context;
import org.graalvm.polyglot.Value;

public class GraalVMComplexExample {
    public static void main(String[] args) {
        try (Context context = Context.create()) {
            context.eval("js", "function greet(name) { return 'Hello, ' + name; }");
            Value greetFunction = context.getBindings("js").getMember("greet");
            String result = greetFunction.execute("World").asString();
            System.out.println(result);
        }
    }
}

注意事项

  • Nashorn 在 JDK 15 及以上版本中已被移除,建议使用 GraalVM。
  • GraalVM 需要单独安装或使用 GraalVM 提供的 JDK。
  • 性能敏感场景下,直接调用 JavaScript 可能不如原生 Java 代码高效。

通过以上方法,可以在 Java 中灵活调用和执行 JavaScript 代码,实现跨语言功能集成。

标签: javajs
分享给朋友:

相关文章

java程序如何运行

java程序如何运行

编写Java代码 使用文本编辑器或IDE(如IntelliJ IDEA、Eclipse)编写Java源代码,保存为.java文件。例如: public class HelloWorld {…

js类实现

js类实现

使用类实现 JavaScript 功能 在 JavaScript 中,类(Class)是一种语法糖,基于原型继承机制。通过 class 关键字可以更直观地定义对象模板。 基本类定义 class…

js实现选题

js实现选题

实现选题功能的JavaScript方法 基础实现方案 使用数组存储选项,通过随机索引选取: const options = ['选项A', '选项B', '选项C', '选项D']; const r…

js实现文字滚动

js实现文字滚动

实现文字滚动的几种方法 使用CSS动画实现滚动 通过CSS的@keyframes和transform属性可以实现平滑的文字滚动效果。 <style> .scroll-text { w…

js实现 功能

js实现 功能

在 JavaScript 中实现功能通常涉及多个关键步骤,具体取决于功能需求。以下是常见功能的实现方法和示例: 基本功能实现 使用函数封装逻辑是最直接的方式。例如,实现一个计算两数之和的函数: f…

js实现下拉菜单

js实现下拉菜单

使用HTML和CSS创建基础结构 HTML部分需要包含一个触发下拉的按钮和隐藏的下拉菜单内容: <div class="dropdown"> <button class="dr…