翻譯和編譯自: http://docs.oracle.com/javase/8/docs/technotes/guides/scripting/nashorn/toc.htmljavascript
用Notepad++新建一js文件。F6執行命令爲:html
npp_save
cmd.exe /c jjs.exe -fx "$(FULL_CURRENT_PATH)"
java
代碼內容例如如下:web
//查看包類型 print(java); print(java.lang); print(typeof java.lang); print(typeof java.lang.System); print(typeof java.lang.System == 'function'); //建立Java對象 var HashMap = Java.type("java.util.HashMap"); var mapDef = new HashMap(); var map100 = new HashMap(100); print(Java.type("java.util.Map").Entry); print('內部類:' + Java.type("java.util.Map$Entry")); //存取內部類 //JavaString測試 var StringCls = Java.type("java.lang.String"); var str = new StringCls("Hello"); str = str.toUpperCase(); print('Upper: ' + str); //測試輸出 Java.type("java.lang.System").out.println(10); Java.type("java.lang.System").out["println(double)"](10.92929); //日期 var Date = Java.type('java.util.Date'); var date = new Date(); print('year:' + date.year); date.year += 1000; print('new year:' + date.year); //字符串處理 print(" hehe".trimLeft()); // hehe print("hehe ".trimRight() + "he"); // hehehe //簡單函數的定義 function sqr(x) x * x; print(sqr(3)); // 9 //把不一樣對象的屬性綁定 var o1 = {age: 15}; var o2 = {name: 'bar'}; Object.bindProperties(o1, o2); //綁定o2到o1上 print('對象的o1屬性:' + o1.name + ', ' + o1.age); //對象的o1屬性:bar, 15 print('對象的o2屬性:' + o2.name + ', ' + o2.age); //對象的o2屬性:bar, undefined o1.name = 'BAM'; print('對象的o2屬性:' + o2.name); //BAM //load命令 load('http://cdnjs.cloudflare.com/ajax/libs/underscore.js/1.6.0/underscore-min.js'); var odds = _.filter([1, 2, 3, 4, 5, 6], function (num) { return num % 2 == 1; }); print('underscore結果:' + odds); // 1, 3, 5 //Lamda表達式 var map = Array.prototype.map; var names = ["john", "jerry", "bob"]; //調用匿名函數。輸入參數是names,匿名函數本身主動遍歷names的內容name,並計算其長度 var a = map.call(names, function(name) { return name.length() }); print('Lamda表達式:' + a); //Java數組 var IntArray = Java.type("int[]"); var iarr = new IntArray(10); iarr[1] = 5; iarr[2] = 3; iarr[3] = iarr[1] + iarr[2]; print('5 + 3 = ' + iarr[3]); print('iarr.length= ' + iarr.length); print(iarr[0]); for (var i in iarr) print(i); //取得索引下標 for each(var i in iarr) print(i); //取得值 //try...catch使用方法 try { iarr[10] = 5; } catch (e) { print('try...catch...使用方法:' + e.message); print(e.lineNumber) print(e.columnNumber) print(e.fileName) } //Java.to實現javascript到java數組類型的轉換 var jsVals = ["a", "bc", "de"]; var JString = Java.type("java.lang.String[]"); var jVals = Java.to(jsVals, JString); //數據類型轉換 var ival = 10; print(ival.class); ival = Number(ival); print(ival.class); //Java集合使用 var ArrayList = Java.type("java.util.ArrayList"); var list = new ArrayList(); list.add("zhang"); list.add("wang"); for each(var i in list) print(i); //HashMap print(); print('HashMap demo'); var HashMap = Java.type("java.util.HashMap"); var hm = new HashMap(); hm.put('zhangsan', 133992); hm.put('lisi', {name:'martin', sex:'male'}); for each (key in hm.keySet()) print('key: ' + key); for each (val in hm.values()) print('val: ' + val + ' ' + typeof val); //存取類及事實上例成員 print('pi:' + Java.type("java.lang.Math").PI); print('time:' + Java.type("java.lang.System").currentTimeMillis()) print('ok'); //繼承和擴展線程類 var Run = Java.type("java.lang.Runnable"); var MyRun = Java.extend(Run, { run: function() { print("I am running in separate thread"); } }); //構造 var Thread = Java.type("java.lang.Thread"); var th = new Thread(new MyRun()); th.run(); var th1 = new Thread(new MyRun()); th1.run(); //super調用父類方法 var SuperRunner = Java.type('java.lang.Thread'); var Runner = Java.extend(SuperRunner); var runner = new Runner() { run: function() { Java.super(runner).run(); print('on my run'); } } runner.run(); //用Javascript定義一個類Dog function Dog(name) { this.name = name; this.bark = function() { return "Hello, " + this.name; } } var dog = new Dog("martin"); print("dog bark function: " + dog.bark()); //怎樣繼承Object類 //from: https://wiki.openjdk.java.net/display/Nashorn/Nashorn+extensions /*沒模仿成功 var Object = Java.type("java.lang.Object"); var Dog = Java.extend(Object); var dog = new Dog() { bark : function(name) { return "hello, " + name; } } print('狗叫:' + dog.bark('martin')); */ //Packages使用方法 var Vector = Packages.java.util.Vector; // but short-cuts defined for important package prefixes like // Packages.java, Packages.javax, Packages.com // Packages.edu, Packages.javafx, Packages.org var JFrame = javax.swing.JFrame; // javax == Packages.javax var List = java.util.List; // java == Packages.java //exit(1); //告訴引擎代碼運行到這裏 //quit(1); //導入範圍---集中一次導入--JavaImporter和with使用方法 var imports = new JavaImporter(java.io, java.lang); with (imports) { var file = new File(__FILE__); //查找我在哪裏? System.out.println('哪裏: ' + file.getAbsolutePath()); //內容比較古怪 // /path/to/my/script.js } var CollectionsAndFiles = new JavaImporter( java.util, java.io, java.nio); with (CollectionsAndFiles) { var files = new LinkedHashSet(); files.add(new File("Plop")); files.add(new File("Foo")); files.add(new File("w00t.js")); } //__LINE__顯示當前代碼行數,用於調試比較好 print(__FILE__, __LINE__, __DIR__); print('JavaFX application'); var Button = javafx.scene.control.Button; var StackPane = javafx.scene.layout.StackPane; var Scene = javafx.scene.Scene; /*僅僅能看到最後的JavaFX應用 function start(primaryStage) { primaryStage.title = "Hello World!"; var button = new Button(); button.text = "Say 'Hello World'"; button.onAction = function() print("Hello World!"); var root = new StackPane(); root.children.add(button); primaryStage.scene = new Scene(root, 300, 250); primaryStage.show(); } */ //還有一個app--簡化版 //但假設前面窗體凝視去掉的話。如下的代碼未運行 /* $STAGE.title = "Hello World!"; var button = new Button(); button.text = "Say 'Hello World 2'"; button.onAction = function() print("Hello World1!"); var root = new StackPane(); root.children.add(button); $STAGE.scene = new Scene(root, 300, 250); $STAGE.show(); */ //爲何窗體代碼僅僅運行最後的內容 load("fx:base.js"); load("fx:controls.js"); load("fx:graphics.js"); $STAGE.title = "Hello World!"; var button = new Button(); button.text = "Say 'Hello World 3'"; button.onAction = function() print("Hello World!"); var root = new StackPane(); root.children.add(button); $STAGE.scene = new Scene(root, 300, 250); $STAGE.show(); //複雜些的javafx應用---一個動畫演示 load("fx:base.js"); load("fx:controls.js"); load("fx:graphics.js"); var WIDTH = 500; var HEIGHT = 600; var animation; function setup(primaryStage) { var root = new Group(); primaryStage.resizable = false; var scene = new Scene(root, WIDTH, HEIGHT); scene.title = "Colourful Circles"; primaryStage.scene = scene; // create first list of circles var layer1 = new Group(); for(var i = 0; i < 15; i++) { var circle = new Circle(200, Color.web("white", 0.05)); circle.strokeType = StrokeType.OUTSIDE; circle.stroke = Color.web("white", 0.2); circle.strokeWidth = 4; layer1.children.add(circle); } // create second list of circles var layer2 = new Group(); for(var i = 0; i < 20; i++) { var circle = new Circle(70, Color.web("white", 0.05)); circle.strokeType = StrokeType.OUTSIDE; circle.stroke = Color.web("white", 0.1); circle.strokeWidth = 2; layer2.children.add(circle); } // create third list of circles var layer3 = new Group(); for(var i = 0; i < 10; i++) { var circle = new Circle(150, Color.web("white", 0.05)); circle.strokeType = StrokeType.OUTSIDE; circle.stroke = Color.web("white", 0.16); circle.strokeWidth = 4; layer3.children.add(circle); } // set a blur effect on each layer layer1.effect = new BoxBlur(30, 30, 3); layer2.effect = new BoxBlur(2, 2, 2); layer3.effect = new BoxBlur(10, 10, 3); // create a rectangle size of window with colored gradient var colors = new Rectangle(WIDTH, HEIGHT, new LinearGradient(0, 1, 1, 0, true, CycleMethod.NO_CYCLE, new Stop(0, Color.web("#f8bd55")), new Stop(0.14, Color.web("#c0fe56")), new Stop(0.28, Color.web("#5dfbc1")), new Stop(0.43, Color.web("#64c2f8")), new Stop(0.57, Color.web("#be4af7")), new Stop(0.71, Color.web("#ed5fc2")), new Stop(0.85, Color.web("#ef504c")), new Stop(1, Color.web("#f2660f")))); colors.blendMode = BlendMode.OVERLAY; // create main content var group = new Group(new Rectangle(WIDTH, HEIGHT, Color.BLACK), layer1, layer2, layer3, colors); var clip = new Rectangle(WIDTH, HEIGHT); clip.smooth = false; group.clip = clip; root.children.add(group); // create list of all circles var allCircles = new java.util.ArrayList(); allCircles.addAll(layer1.children); allCircles.addAll(layer2.children); allCircles.addAll(layer3.children); // Create a animation to randomly move every circle in allCircles animation = new Timeline(); for each (var circle in allCircles) { animation.getKeyFrames().addAll( new KeyFrame(Duration.ZERO, // set start position at 0s new KeyValue(circle.translateXProperty(), Math.random() * WIDTH), new KeyValue(circle.translateYProperty(), Math.random() * HEIGHT)), new KeyFrame(new Duration(20000), // set end position at 20s new KeyValue(circle.translateXProperty(), Math.random() * WIDTH), new KeyValue(circle.translateYProperty(), Math.random() * HEIGHT)) ); } animation.autoReverse = true; animation.cycleCount = Animation.INDEFINITE; } function stop() { animation.stop(); } function play() { animation.play(); } function start(primaryStage) { setup(primaryStage); primaryStage.show(); play(); } //JavaFX應用案例 //http://justmy2bits.com/2013/09/08/javafx-with-nashorn-canvas-example/ //編程參考: //http://www.infoq.com/cn/news/2013/08/everything-about-java-8 //https://wiki.openjdk.java.net/display/Nashorn/Nashorn+Documentation //https://wiki.openjdk.java.net/display/Nashorn/Main //https://blogs.oracle.com/nashorn/ //http://winterbe.com/posts/2014/04/05/java8-nashorn-tutorial/ //http://www.oracle.com/technetwork/articles/java/jf14-nashorn-2126515.html //https://wiki.openjdk.java.net/display/Nashorn/Nashorn+extensions
JavaFX效果例如如下:ajax