成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

java中調(diào)用npm模塊

didikee / 498人閱讀

摘要:工具和資料群高級爬蟲作者自建群,歡迎加入作者收集的爬蟲相關(guān)工具和資料正文一些小的片段可以很方便的直接使用直接導(dǎo)入,但是如何使用方法導(dǎo)入使用下載的模塊呢答案是使用這個(gè)項(xiàng)目。

工具和資料

QQ群 - Javascript高級爬蟲 - 作者自建群,歡迎加入!

awesome-java-crawler - 作者收集的爬蟲相關(guān)工具和資料

正文

一些小的javascript片段可以很方便的直接使用ScriptEngine.eval()直接導(dǎo)入,但是如何使用require方法導(dǎo)入使用npm下載的javascript模塊呢?

答案是使用jvm-npm這個(gè)項(xiàng)目。

首先,創(chuàng)建一個(gè)目錄放置所有javascript文件,比如:D:path ojs_modules

從jvm-npm下載jvm-npm.js,放到上述目錄中

使用npm i -g下載你需要引用的npm模塊,注意看最后的提示,即模塊下載目錄

到模塊下載目錄,通常為 pm ode_modules,里面一般有個(gè)dist目錄,從里面找到完整的模塊js文件,復(fù)制到上述目錄

見以下Kotlin示例代碼:(注意把js_module換成你需要加載的模塊名)

val JS_ROOT = "D:path	ojs_modules"
val JSE = ScriptEngineManager().getEngineByName("nashorn").apply {
    System.setProperty("user.dir", JS_ROOT)             // 設(shè)定jvm-npm的當(dāng)前目錄
    eval(Util.readLocalUtfText("$JS_ROOTjvm-npm.js")) // 在ScriptEngine中加載jvm-npm.js
    println(eval("typeof require"))                     // 驗(yàn)證require方法已正確引入
    eval("var mylib = require("js_module")")            // 這時(shí)候,就可以用require()方法來引入當(dāng)前目錄中的js模塊了
    println(eval("typeof mylib"))                       // 驗(yàn)證js模塊已正確加載
}
...
val bar = JSE.eval("mylib.foo()")                       // js代碼中可以使用加載的js模塊了

注意:

jvm-npm有個(gè)bug,如果你的js文件大于64K,則會導(dǎo)致文件截?cái)唷?br>這種情況下你需要編寫一個(gè)能一次讀取完整File或InputStream的java方法,替換掉下面這句:

    return new Scanner(input).useDelimiter("A").next()

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/72731.html

相關(guān)文章

  • java調(diào)用npm模塊

    摘要:工具和資料群高級爬蟲作者自建群,歡迎加入作者收集的爬蟲相關(guān)工具和資料正文一些小的片段可以很方便的直接使用直接導(dǎo)入,但是如何使用方法導(dǎo)入使用下載的模塊呢答案是使用這個(gè)項(xiàng)目。 showImg(https://segmentfault.com/img/remote/1460000018765904); 工具和資料 QQ群 - Javascript高級爬蟲 - 作者自建群,歡迎加入! a...

    wind5o 評論0 收藏0
  • React的移動端和PC端生態(tài)圈的使用匯總

    摘要:調(diào)用通過注冊表調(diào)用到實(shí)例,透過的,調(diào)用到中的,最后通過,調(diào)用,根據(jù)參數(shù)相應(yīng)模塊執(zhí)行。京東的,多端解決方案是一套遵循語法規(guī)范的多端開發(fā)解決方案。 showImg(https://segmentfault.com/img/bVbuMkw?w=1304&h=808); 對于一項(xiàng)技術(shù),我們不能停留在五分鐘狀態(tài),特別喜歡一句話,用什么方式繪制UI界面一點(diǎn)不重要,重要的是底層的思維,解決問題和優(yōu)化...

    kun_jian 評論0 收藏0
  • React的移動端和PC端生態(tài)圈的使用匯總

    摘要:調(diào)用通過注冊表調(diào)用到實(shí)例,透過的,調(diào)用到中的,最后通過,調(diào)用,根據(jù)參數(shù)相應(yīng)模塊執(zhí)行。京東的,多端解決方案是一套遵循語法規(guī)范的多端開發(fā)解決方案。 showImg(https://segmentfault.com/img/bVbuMkw?w=1304&h=808); 對于一項(xiàng)技術(shù),我們不能停留在五分鐘狀態(tài),特別喜歡一句話,用什么方式繪制UI界面一點(diǎn)不重要,重要的是底層的思維,解決問題和優(yōu)化...

    J4ck_Chan 評論0 收藏0
  • React的移動端和PC端生態(tài)圈的使用匯總

    摘要:調(diào)用通過注冊表調(diào)用到實(shí)例,透過的,調(diào)用到中的,最后通過,調(diào)用,根據(jù)參數(shù)相應(yīng)模塊執(zhí)行。京東的,多端解決方案是一套遵循語法規(guī)范的多端開發(fā)解決方案。 showImg(https://segmentfault.com/img/bVbuMkw?w=1304&h=808); 對于一項(xiàng)技術(shù),我們不能停留在五分鐘狀態(tài),特別喜歡一句話,用什么方式繪制UI界面一點(diǎn)不重要,重要的是底層的思維,解決問題和優(yōu)化...

    Travis 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<