.net core 嵌入 js(javascript)指令碼引擎
阿新 • • 發佈:2018-11-16
漂亮的目錄
1、萬能的指令碼
折騰無止境,.net core 提供了更多的可能,今天我們就來看看指令碼引擎。提起指令碼,不得不說說Javascript——WEB網際網路世界的一大半江山都掌控在其下,當今世界,發展最迅猛的必然輸入前端技術,各種框架百花齊放,甚至於通過NodeJs,滲透到後端的地盤。Javascript無疑是最成功的語言,雖然開發這門語言只是一個人花了10天而已。
因此 .net core下加入一門指令碼引擎,是不是首先考慮Javascript呢?
2、內部嵌入引擎方式
JavaScript Engine Switcher 使用同一的介面訪問流行的Javascript引擎 (MSIE JavaScript Engine, Microsoft ClearScript.V8, Jurassic, Jint, ChakraCore and VroomJs). 該類庫允許你在不同的引擎間快速的切換。
該包支援的型別如下:
- JavaScriptEngineSwitcher.Core.Undefined
- System.Boolean
- System.Int32
- System.Double
- System.String
支援包包含下列列表:
- JS Engine Switcher: Core (supports .NET Framework 4.0 Client, .NET Framework 4.5 and .NET Standard 1.3)
- JS Engine Switcher: MS Dependency Injection (supports .NET Framework 4.5 and .NET Standard 1.3)
- JS Engine Switcher: MSIE (supports .NET Framework 4.0 Client, .NET Framework 4.5 and .NET Standard 1.3)
- JS Engine Switcher: V8 (supports .NET Framework 4.0 Client and .NET Framework 4.5)
- Windows (x86)
- Windows (x64)
- JS Engine Switcher: Jurassic (supports .NET Framework 4.0 Client and .NET Framework 4.5)
- JS Engine Switcher: Jint (supports .NET Framework 4.0 Client, .NET Framework 4.5 and .NET Standard 1.3)
- JS Engine Switcher: ChakraCore (supports .NET Framework 4.0 Client, .NET Framework 4.5 and .NET Standard 1.3)
- Windows (x86)
- Windows (x64)
- Windows (ARM)
- Linux (x64)
- OS X (x64) - JS Engine Switcher: Vroom (supports .NET Framework 4.0 Client, .NET Framework 4.5 and .NET Standard 1.6)
想在 .net core 下使用,有多重選擇,那我們就選擇 ChakraCore吧:
var engineSwitcher = JsEngineSwitcher.Current;
engineSwitcher.EngineFactories.Add(new ChakraCoreJsEngineFactory());
engineSwitcher.DefaultEngineName = ChakraCoreJsEngine.EngineName;
IJsEngine engine = JsEngineSwitcher.Current.CreateDefaultEngine();
engine.EmbedHostType("Test", typeof(Test));
var t = new Test();
engine.EmbedHostObject("TestA", t);
engine.Execute("var a=1+3;if(1)a=5;TestA.Name=a");
Console.WriteLine(t.Name);
為了在javascript引擎和.net core間進行互動,我定義了一個類,ooop,普通的類
public class Test
{
public string Name { get; set; }
public void Hello(string s)
{
Console.WriteLine(s);
}
}
程式碼互動清爽而乾淨,執行也很快,你有沒有被驚豔到?
3、呼叫NodeJs服務,與之通訊方式
微軟提供了一個nuget包:Microsoft.AspNetCore.NodeServices,通過該包,可以順利的和nodejs服務進行通訊。
為了使用它,我引入了注入容器。
這裡通過指令碼呼叫方式來執行js。
var services = new ServiceCollection();
services.AddNodeServices(options => {
options.LaunchWithDebugging = false;
options.ProjectPath = Path.Combine(AppDomain.CurrentDomain.BaseDirectory, "js");
});
var serviceProvider = services.BuildServiceProvider();
var nodeServices = serviceProvider.GetRequiredService<INodeServices>();
for (int i = 0; i < 100; i++)
{
var result = nodeServices.InvokeAsync<int>("./addNumbers", 1, 2).Result;
}
注意: 指令碼預設放置在js目錄下,命名為:addNumbers.js。
js程式碼如下,我們可以通過callback返回結果。
module.exports = function (callback, first, second) {
var result = first + second;
callback(/* error */ null, result);
};
該方式注入了一個單例的nodejs服務引擎,因此理論上看執行js的效率會高於第一種方式。
結論
通過指令碼可以做很多靈活的需求,例如:自定義任務、自定義的規則、甚至流程。
.net core 給我們提供了無儘可能。