場景,適用于無Html頁面,純后臺調式腳本語言。
首先創建一個js文件,放在resource下的靜態文件下
// 供java進行調用
function hello(str) {
var copeStr = str + " 123";
return copeStr;
}
然后,創建測試類
public class TestJs {
// 獲取js文件的絕對路徑
private static String jsName = "src/main/resources/static/test.js";
public static void main(String[] args) {
try {
// todo 初始化 JavaScript 引擎
ScriptEngineManager manager = new ScriptEngineManager();
ScriptEngine engine = manager.getEngineByName("javascript");
engine.eval("load('" + jsName + "');");
/**
* 這里我們將 engine 強制轉換為 Invocable 類型,使用 invokeFunction 方法將參數傳遞給腳本引擎。
* invokeFunction 這個方法使用了可變參數的定義方式,可以一次傳遞多個參數,并且將腳本語言的返回值作為它的返回值。
*/
Invocable inv = (Invocable) engine;
String str = "Hello Js";
// 將 Java 對象轉成 JavaScript 對象
//Object Java = engine.get("Java");
//ScriptObjectMirror bytes_som = (ScriptObjectMirror) inv.invokeMethod(Java, "from", str);
// 進行 js 方法的調用,hello 為 js文件里的方法名
Object json = inv.invokeFunction("hello",str);
System.out.printf(json.toString());
} catch(Exception e) {
e.printStackTrace();
}
}
}
運行測試類,輸出:
Hello Js 123
測試成功。
年來,從事JavaScript的程序員越來越多,JavaScript的曝光率也越來越高,如果你想轉行試試JavaScript,不妨收下這份面試題及答案,沒準用得上。當然,如果針對這些問題,你有更棒的答案,歡迎移步至評論區。
1、什么是JavaScript?(這是基本題,對很多程序員來說也是送分題!)
JavaScript是客戶端和服務器端腳本語言,可以插入到HTML頁面中,并且是目前較熱門的Web開發語言。同時,JavaScript也是面向對象編程語言。
類似的基本題目還包括:JavaScript都有哪些類型?JavaScript是誰發明的?......
2、列舉Java和JavaScript之間的區別?
Java是一門十分完整、成熟的編程語言。相比之下,JavaScript是一個可以被引入HTML頁面的編程語言。這兩種語言并不完全相互依賴,而是針對不同的意圖而設計的。 Java是一種面向對象編程(OOPS)或結構化編程語言,類似的如C ++或C,而JavaScript是客戶端腳本語言,它被稱為非結構化編程。
3. JavaScript和ASP腳本相比,哪個更快?
JavaScript更快。JavaScript是一種客戶端語言,因此它不需要Web服務器的協助來執行。另一方面,ASP是服務器端語言,因此總是比JavaScript慢。值得注意的是,Javascript現在也可用于服務器端語言(nodejs)。
4、什么是負無窮大?
負無窮大是JavaScript中的一個數字,可以通過將負數除以零來得到。
5、如何將JavaScript代碼分解成幾行嗎?
在字符串語句中可以通過在第一行末尾使用反斜杠“\”來完成
例:document.write("This is \a program");
如果不是在字符串語句中更改為新行,那么javaScript會忽略行中的斷點。
例:
var x=1, y=2,
z=
x+y;
上面的代碼是完美的,但并不建議這樣做,因為阻礙了調試。
6、什么是未聲明和未定義的變量?
未聲明的變量是程序中不存在且未聲明的變量。如果程序嘗試讀取未聲明變量的值,則會遇到運行時錯誤。未定義的變量是在程序中聲明但尚未給出任何值的變量。如果程序嘗試讀取未定義變量的值,則返回未定義的值。
7、如何編寫可動態添加新元素的代碼?
8、什么是全局變量?這些變量如何聲明,使用全局變量有哪些問題?
全局變量是整個代碼長度可用的變量,也就是說這些變量沒有任何作用域。var關鍵字用于聲明局部變量或對象。如果省略var關鍵字,則聲明一個全局變量。
例:// Declare a global globalVariable = “Test”;
使用全局變量所面臨的問題是本地和全局變量名稱的沖突。此外,很難調試和測試依賴于全局變量的代碼。
9、解釋JavaScript中定時器的工作?如果有,也可以說明使用定時器的缺點?
定時器用于在設定的時間執行一段代碼,或者在給定的時間間隔內重復該代碼。這通過使用函數setTimeout,setInterval和clearInterval來完成。
setTimeout(function,delay)函數用于啟動在所述延遲之后調用特定功能的定時器。
setInterval(function,delay)函數用于在提到的延遲中重復執行給定的功能,只有在取消時才停止。
clearInterval(id)函數指示定時器停止。
定時器在一個線程內運行,因此事件可能需要排隊等待執行。
10、ViewState和SessionState有什么區別?
“ViewState”特定于會話中的頁面。
“SessionState”特定于可在Web應用程序中的所有頁面上訪問的用戶特定數據。
11、什么是===運算符?
===被稱為嚴格等式運算符,當兩個操作數具有相同的值而沒有任何類型轉換時,該運算符返回true。
12、說明如何使用JavaScript提交表單?
要使用JavaScript提交表單,請使用
document.form [0] .submit();
document.form [0] .submit()
13、元素的樣式/類如何改變?
可以通過以下方式完成:
document.getElementById(“myText”).style.fontSize = “20?;
或
document.getElementById(“myText”).className = “anyclass”;
14、JavaScript中的循環結構都有什么?
For、While、do-while loops
15、如何在JavaScript中將base字符串轉換為integer?
parseInt() 函數解析一個字符串參數,并返回一個指定基數的整數。parseInt()將要轉換的字符串作為其第一個參數,第二個參數是給定字符串的基礎。
為了將4F(基數16)轉換為整數,所使用的代碼是 :parseInt ("4F", 16);
16、說明“==”和“===”之間的區別?
“==”僅檢查值相等,而“===”是一個更嚴格的等式判定,如果兩個變量的值或類型不同,則返回false。
17、3 + 2 +“7”的結果是什么?
由于3和2是整數,它們將直接相加。由于7是一個字符串,它將會被直接連接,所以結果將是57。
18、說明如何檢測客戶端機器上的操作系統?
為了檢測客戶端機器上的操作系統,應使用navigator.appVersion字符串(屬性)。
19、Javascript中的NULL是什么意思?
NULL用于表示無值或無對象。它意味著沒有對象或空字符串,沒有有效的布爾值,沒有數值和數組對象。
20、delete操作符的功能是什么?
delete操作符用于刪除程序中的所有變量或對象,但不能刪除使用VAR關鍵字聲明的變量。
21、JavaScript中有哪些類型的彈出框?
Alert、Confirm and、Prompt
22、Void(0)怎么用?
Void(0)用于防止頁面刷新,并在調用時傳遞參數“zero”。
Void(0)用于調用另一種方法而不刷新頁面。
23、如何強制頁面加載JavaScript中的其他頁面?
必須插入以下代碼才能達到預期效果:
24、escape字符是用來做什么的?
使用特殊字符(如單引號,雙引號,撇號和&符號)時,將使用轉義字符(反斜杠)。在字符前放置反斜杠,使其顯示。
例:
25、什么是JavaScript Cookie?
Cookie是用來存儲計算機中的小型測試文件,當用戶訪問網站以存儲他們需要的信息時,它將被創建。
26、解釋JavaScript中的pop()方法?
pop()方法與shift()方法類似,但不同之處在于Shift方法在數組的開頭工作。此外,pop()方法將最后一個元素從給定的數組中取出并返回。然后改變被調用的數組。
例:
var cloths = [“Shirt”, “Pant”, “TShirt”];
cloths.pop();
//Now cloth becomes Shirt,Pant
27、在JavaScript中使用innerHTML的缺點是什么?
如果在JavaScript中使用innerHTML,缺點是:內容隨處可見;不能像“追加到innerHTML”一樣使用;即使你使用+ = like“innerHTML = innerHTML +'html'”舊的內容仍然會被html替換;整個innerHTML內容被重新解析并構建成元素,因此它的速度要慢得多;innerHTML不提供驗證,因此我們可能會在文檔中插入有效的和破壞性的HTML并將其中斷。
28、break和continue語句的作用?
Break語句從當前循環中退出。
continue語句繼續下一個循環語句。
29、在JavaScript中,dataypes的兩個基本組是什么?
Primitive
Reference types
原始類型是數字和布爾數據類型。引用類型是更復雜的類型,如字符串和日期。
30、如何創建通用對象?
通用對象可以創建為:
var I = new object();
31、operator類型用來做什么?
'Typeof'是一個運算符,用于返回變量類型的字符串描述。
32、哪些關鍵字用于處理異常?
try... Catch-finally用于處理JavaScript中的異常。
33、JavaScript中不同類型的錯誤有幾種?
有三種類型的錯誤:
Load time errors:該錯誤發生于加載網頁時,例如出現語法錯誤等狀況,稱為加載時間錯誤,并且會動態生成錯誤。
Run time errors:由于在HTML語言中濫用命令而導致的錯誤。
Logical Errors:這是由于在具有不同操作的函數上執行了錯誤邏輯而發生的錯誤。
34、在JavaScript中使用的Push方法是什么?
push方法用于將一個或多個元素添加或附加到數組的末尾。使用這種方法,可以通過傳遞多個參數來附加多個元素。
35、什么是JavaScript中的unshift方法?
Unshift方法就像在數組開頭工作的push方法。該方法用于將一個或多個元素添加到數組的開頭。
36、對象屬性如何分配?
屬性按以下方式分配給對象:
obj["class"] = 12;
或
obj.class = 12;
37、獲得CheckBox狀態的方式是什么?
alert(document.getElementById('checkbox1')。checked);
如果CheckBox被檢查,此警報將返回TRUE。
38、解釋window.onload和onDocumentReady?
在載入頁面的所有信息之前,不運行onload函數。這導致在執行任何代碼之前會出現延遲。
onDocumentReady在加載DOM之后加載代碼。這允許早期的代碼操縱。
39、你將如何解釋JavaScript中的閉包? 什么時候使用?
Closure是與函數返回時保留在內存中的函數相關的本地聲明變量。
例如:
40、一個值如何附加到數組?
可以以給定的方式將值附加到數組:
arr [arr.length] = value;
41、解釋for-in循環?
for-in循環用于循環對象的屬性。
for-in循環的語法是:
在每次循環中,來自對象的一個屬性與變量名相關聯,循環繼續,直到對象的所有屬性都被耗盡。
42、描述JavaScript中的匿名函數?
被聲明為沒有任何命名標識符的函數被稱為匿名函數。一般來說,匿名函數在聲明后無法訪問。
匿名函數聲明:
43、.call()和.apply()之間有什么區別?
函數.call()和.apply()在使用上非常相似,只是有一點區別。當程序員知道函數參數的編號時,使用.call(),因為它們必須在調用語句中被提及為參數。另一方面,當不知道數字時使用.apply(),函數.apply()期望參數為數組。
.call()和.apply()之間的基本區別在于將參數傳遞給函數。它們的用法可以通過給定的例子進行說明。
44、定義事件冒泡?
JavaScript允許DOM元素嵌套在一起。在這種情況下,如果單擊子級的處理程序,父級的處理程序也將執行同樣的工作。
45、什么樣的布爾運算符可以在JavaScript中使用?
“And”運算符(&&),'Or'運算符(||)和'Not'運算符(!)可以在JavaScript中使用。
*運算符沒有括號。
46、一個特定的框架如何使用JavaScript中的超鏈接定位?
可以通過使用“target”屬性在超鏈接中包含所需幀的名稱來實現。
<a href=”newpage.htm” target=”newframe”>>New Page</a>
47、在web-garden和web-farm之間有何不同?
web-garden和web-farm都是網絡托管系統。唯一的區別是web-garden是在單個服務器中包含許多處理器的設置,而web-farm是使用多個服務器的較大設置。
48、如何分配對象屬性?
將屬性分配給對象的方式與賦值給變量值相同。例如,表單對象的操作值以下列方式分配為“‘submit”:Document.form.action =“submit”
49、在JavaScript中讀取和寫入文件的方法是什么?
可以通過使用JavaScript擴展(從JavaScript編輯器運行),打開文件的示例來完成:
fh = fopen(getScriptPath(), 0);
50、在JavaScript中如何使用DOM?
DOM代表文檔對象模型,并且負責文檔中各種對象的相互交互。DOM是開發網頁所必需的,其中包括諸如段落,鏈接等對象。可以操作這些對象以包括添加或刪除等操作,DOM還需要向網頁添加額外的功能。除此之外,API的使用比其他更有優勢。
51、JavaScript中如何使用事件處理程序?
事件是由用戶生成活動(例如單擊鏈接或填寫表單)導致的操作。需要一個事件處理程序來管理所有這些事件的正確執行。事件處理程序是對象的額外屬性。此屬性包括事件的名稱以及事件發生時采取的操作。
52、解釋延遲腳本在JavaScript中的作用?
默認情況下,在頁面加載期間,HTML代碼的解析將暫停,直到腳本停止執行。這意味著,如果服務器速度較慢或者腳本特別沉重,則會導致網頁延遲。在使用Deferred時,腳本會延遲執行直到HTML解析器運行。這減少了網頁加載時間,并且它們的顯示速度更快。
53、JavaScript中的各種功能組件是什么?
JavaScript中的不同功能組件是:
First-class函數:JavaScript中的函數被用作第一類對象。這通常意味著這些函數可以作為參數傳遞給其他函數,作為其他函數的值返回,分配給變量,也可以存儲在數據結構中。
嵌套函數:在其他函數中定義的函數稱為嵌套函數。
54、解釋unshift()方法?
該方法在數組啟動時起作用,與push()不同。 它將所需數量的元素添加到數組的頂部。例如:
輸出如下所示:
[" joseph "," Jane ", " charlie ", " john "]
55、decodeURI()和encodeURI()是什么?
EncodeURl()用于將URL轉換為十六進制編碼。而DecodeURI()用于將編碼的URL轉換回正常。
56、為什么不建議在JavaScript中使用innerHTML?
innerHTML內容每次刷新,因此很慢。 在innerHTML中沒有驗證的余地,因此,更容易在文檔中插入錯誤代碼,從而使網頁不穩定。
57、如何在不支持JavaScript的舊瀏覽器中隱藏JavaScript代碼?
在<script>標簽之后的代碼中添加“<! - ”,不帶引號。
在<script>標簽之前添加“// - >”代碼中沒有引號。
舊瀏覽器現在將JavaScript代碼視為一個長的HTML注釋。而支持JavaScript的瀏覽器則將“<! - ”和“// - >”作為一行注釋。
avascript并不是只是存活在瀏覽器里面。
Google公司的chrome瀏覽器非常著名,出于公司發展戰略的考慮,為了把持互聯網入口,google把這個瀏覽器做的非常出色。
而且Google也做到了,一個成果就是google命名為V8的JavaScript解釋引擎。
在早期,chrome團隊每次在更新里面都提到“JavaScript速度提高XX倍”,這個XX通常是以百位來計數的。
人們一看,我擦,這么強的東西,只用在瀏覽器里面太可惜了,而且Chrome一直是個開源產品,為什么不把V8那一部分拿出來,單獨做一個東西呢?
于是Node.js就誕生了。
從此以后,人們就可以在任何地方使用JavaScript了。
你可以去node.js官網(https://nodejs.org/en/)去下載。
Node.js的版本發展速度非常快,經常一個星期就發布一個新的版本,被人戲稱為“版本帝”。
后來node.js發表了LTS版本,就是“長時間支持版本”,就是版本號不變,但是那些改進特性會融入到這個版本里面。
如果你喜歡嘗試新特性,可以使用Current版本。
在node.js里面都可以下載。
node.js并不只是把V8引擎給利用了起來,還帶來了NPM這個改變世界的東東。
npm你可以想象成一個代碼倉庫,人們可以把自己的代碼以模塊的形式發布到npm倉庫上面,任何其他人就可以使用這些模塊了。
npm是世界上最大的代碼倉庫之一,幾乎可以找到任何方面的Javascript代碼模塊。
這也是現在Javasript征服世界的一個原因之一。
當然另外一個方面,node.js也有不是非常擅長的領域,譬如長時間的運算(如加密等)。
同時,Javascript的設計方面也有一些問題,它的異步執行方式對于傳統的C系列編程人員(C系就是C、c++、Java等c語法類型),思維方式需要一些改變才能習慣異步代碼。
好吧,今天就到這里。
自己下載安裝一個node.js來試一試吧!
*請認真填寫需求信息,我們會在24小時內與您取得聯系。