在 .NET 中执行 JavaScript 代码

eb24c256eb593d04644e333823b69c29.png

0a03506e727fb69bfedbd26ba6cbf2b3.gif

336e96ee41d8c8003ba205c9d3ab0d87.png

你好,这里是 Dotnet 工具箱,定期分享 Dotnet 有趣,实用的工具和组件,希望对您有用!

Jint 简介

如果您想在您的 .NET 程序中使用 Javascript,那么我推荐您使用 Jint。

Jint 是适用于 .NET 的 开源 Javascript 解释器,功能强大,它可以在任何现代 .NET 平台上运行,因为它支持 .NET Standard 2.0 和 .NET 4.6.2 以及更高版本),包括最新的 .NET 6。

因为 Jint 既不生成任何 .NET 字节码也不使用 DLR,所以在执行比较少的代码时,它的运行效率很快。

在 Nuget 包管理器中搜索并安装 Jint 即可,它没有其他的一些依赖。

小试牛刀

执行 JS 表达式,并输出结果。

using Jint;

var engine = new Jint.Engine();

var result = engine.Execute("1 + 2 + 3 + 4 + 5")                    .GetCompletionValue();
Console.WriteLine(result);
// Output: 15

这里,变量 x 设置为 3,并且 x * x 在 JavaScript 中进行计算,结果直接返回给 .NET 对象。

using Jint; 

var square = new Engine()
    .SetValue("x", 3)     // 定义一个新变量 x
    .Evaluate( "x * x")   // 声明表达式
    .ToObject();          // 转换为 .NET object

Console.WriteLine(square);

// Output: 9

你可以直接把 .NET 中的对象实例传递给 JS 并使用它,它的修改在 .NET 和 JS 中保持同步。

var p = new Person
{
    Name = "Mickey Mouse"
};

var engine = new Engine()
    .SetValue("p", p)
    .Execute("p.Name = 'Minnie'");

Console.WriteLine(p.Name);

// Output: "Minnie"

你可以直接在 .NET 中执行在 JS 定义的函数。

var engine = new Engine();

var add = engine
    .Execute("function add(a, b) { return a + b; }")
    .GetValue("add");

var result = engine.Invoke("add",1,2);  

Console.WriteLine(result);

// Output: 3

您还可以使用 module 从多个脚本文件中导入和导出变量。

var engine = new Engine(options =>
{
    options.EnableModules(@"C:\Scripts");
})

var ns = engine.ImportModule("./my-module.js");

var value = ns.Get("value").AsString();

更多其他的高级用法,可以在 github 的 Jint 项目中找到。

项目地址

在 Dotnet工具箱 公众号内,回复 A111,即可获取项目地址。

37dcc5b3e8655a77c22257ae592c2422.jpeg

Dotnet 工具箱

扫码关注我们

2a53245ef13eced460b3f9e641a73b4b.png

分享

3d0a568fcbeafc47584e8867cb97708b.png

点收藏

661e2cf3c4bc048d15cd0a12b6d0777e.png

点点赞

d1562d35789dbc2ec5ce02b9db59bc94.png

点在看

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值