08.31 成都web前端開發面試:JS開發乾貨分享之面試中常見JS開發測試題

成都web前端開發面試:JS開發乾貨分享之面試中常見JS開發測試題

成都web前端開發面試:JS開發乾貨分享之面試中常見JS開發測試題

作為一名web前端開發工程師,我們總免不了去找工作。既然要找工作那就不免會有面試,一般我們頭疼的莫過於技術面試了,前面的HTML和CSS可能對於我們來說是小kiss,因為那部分相對於JS開發而言比較簡單,但是一遇到JS開發這部分我們就開始撓頭了,今天華清遠見JS開發頻道就為你分享幾道面試中常見的JS開發測試題,讓你規避面試中的“風險”。

1、介紹js的基本數據類型

Undefined、Null、Boolean、Number、String

2、s有哪些內置對象?

數據封裝類對象:Object、Array、Boolean、Number 和 String

其他對象:Function、Arguments、Math、Date、RegExp、Error

3.this對象的理解

this總是指向函數的直接調用者(而非間接調用者);

如果有new關鍵字,this指向new出來的那個對象;

在事件中,this指向觸發這個事件的對象,特殊的是,IE中的attachEvent中的this總是指向全局對象Window;

4.eval是做什麼的?

它的功能是把對應的字符串解析成JS代碼並運行;

應該避免使用eval,不安全,非常耗性能(2次,一次解析成js語句,一次執行)。

由JSON字符串轉換為JSON對象的時候可以用eval,var obj =eval(‘(‘+ str +’)’);

5.DOM怎樣添加、移除、移動、複製、創建和查找節點

// 創建新節點

createDocumentFragment() //創建一個DOM片段

createElement() //創建一個具體的元素

createTextNode() //創建一個文本節點

// 添加、移除、替換、插入

appendChild()

removeChild()

replaceChild()

insertBefore() //在已有的子節點前插入一個新的子節點

// 查找

getElementsByTagName() //通過標籤名稱

getElementsByName() //通過元素的Name屬性的值(IE容錯能力較強,會得到一個數組,其中包括id等於name值的)

getElementById() //通過元素Id,唯一性

6.null和undefined的區別?

null是一個表示”無”的對象,轉為數值時為0;undefined是一個表示”無”的原始值,轉為數值時為NaN。

undefined:

(1)變量被聲明瞭,但沒有賦值時,就等於undefined。

(2) 調用函數時,應該提供的參數沒有提供,該參數等於undefined。

(3)對象沒有賦值的屬性,該屬性的值為undefined。

(4)函數沒有返回值時,默認返回undefined。

null:

(1) 作為函數的參數,表示該函數的參數不是對象。

(2) 作為對象原型鏈的終點。

7.new操作符具體幹了什麼呢?

(1)創建一個空對象,並且 this 變量引用該對象,同時還繼承了該函數的原型。

(2)屬性和方法被加入到 this 引用的對象中。

(3)新創建的對象由 this 所引用,並且後隱式的返回 this 。

8.JSON 的瞭解?

JSON(JavaScript Object Notation) 是一種輕量級的數據交換格式。它是基於JavaScript的一個子集。數據格式簡單, 易於讀寫, 佔用帶寬小。

格式:採用鍵值對,例如:{‘age’:’12’, ‘name’:’back’}

9.call() 和 apply() 的區別和作用?

apply()函數有兩個參數:第一個參數是上下文,第二個參數是參數組成的數組。如果上下文是null,則使用全局對象代替。

如:function.apply(this,[1,2,3]);

call()的第一個參數是上下文,後續是實例傳入的參數序列。

如:function.call(this,1,2,3);

10.如何獲取UA?

function whatBrowser() {

document.Browser.Name.value=navigator.appName;

document.Browser.Version.value=navigator.appVersion;

document.Browser.Code.value=navigator.appCodeName;

document.Browser.Agent.value=navigator.userAgent;

}

今天的分享就到這裡了,大家趕緊做一下上面的測試題,看看自己是否已經合格了。


分享到:


相關文章: