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

資訊專欄INFORMATION COLUMN

前端面試集錦2017/4/13更新

geekzhou / 2942人閱讀

摘要:情況三作為構(gòu)造函數(shù)調(diào)用所謂構(gòu)造函數(shù),就是通過這個函數(shù)生成一個新對象。讓我們用一張圖表示構(gòu)造函數(shù)和實例原型之間的關(guān)系在這張圖中我們用表示實例原型。

瀏覽器的內(nèi)核分別是什么?
IE: trident內(nèi)核
Firefox:gecko內(nèi)核
Safari:webkit內(nèi)核
Opera:以前是presto內(nèi)核,Opera現(xiàn)已改用Google Chrome的Blink內(nèi)核
Chrome:Blink(基于webkit,Google與Opera Software共同開發(fā))

null與undefined的區(qū)別?

(1)null表示"沒有對象",即該處不應(yīng)該有值。典型用法是:

①作為函數(shù)的參數(shù),表示該函數(shù)的參數(shù)不是對象。
②作為對象原型鏈的終點。

(2)undefined表示"缺少值",就是此處應(yīng)該有一個值,但是還沒有定義。典型用法是:

①變量被聲明了,但沒有賦值時,就等于undefined。
②調(diào)用函數(shù)時,應(yīng)該提供的參數(shù)沒有提供,該參數(shù)等于undefined。
③對象沒有賦值的屬性,該屬性的值為undefined。
④函數(shù)沒有返回值時,默認返回undefined。

簡述一下src與href的區(qū)別
href 時指向網(wǎng)絡(luò)資源所在位置,建立和當(dāng)前元素(錨點)或當(dāng)前文檔(鏈接)之間的鏈接,用于超鏈接。

src 時指向外部的資源位置,指向的內(nèi)容將會嵌入到文檔中當(dāng)前標(biāo)簽所在位置;
在請求 src 資源時會將其指向的資源下載并應(yīng)用到文檔內(nèi),例如 js 腳本,img 圖片和 frame 等元素。當(dāng)瀏
覽器解析到該元素時,會暫停其他資源的下載和處理,直到將該資源加載、編譯、執(zhí)行完畢,圖片和框架等元
素也是如此,類似于將所指向資源嵌入當(dāng)前標(biāo)簽內(nèi)。這也是為什么將 js 腳本放在底部而不是頭部。

HTML中引入CSS的方法

行內(nèi)式

?行內(nèi)式是在標(biāo)記的style屬性中設(shè)定CSS樣式。這種方式?jīng)]有體現(xiàn)出CSS的優(yōu)勢,不推薦使用。
...此處寫CSS樣式 ???缺點是對于一個包含很多網(wǎng)頁的網(wǎng)站,在每個網(wǎng)頁中使用嵌入式,進行修改樣式時非常麻煩。單 ???一網(wǎng)頁可以考慮使用嵌入式。

導(dǎo)入式

將一個獨立的.css文件引入HTML文件中,導(dǎo)入式使用CSS規(guī)則引入外部CSS文件,
             
導(dǎo)入式會在整個網(wǎng)頁裝載完后再裝載CSS文件,因此這就導(dǎo)致了一個問題,如果網(wǎng)頁比較大則會兒出現(xiàn)
先顯示無樣式的頁面,閃爍一下之后,再出現(xiàn)網(wǎng)頁的樣式。這是導(dǎo)入式固有的一個缺陷。

鏈接式

也是將一個.css文件引入到HTML文件中,但它與導(dǎo)入式不同的是鏈接式使用HTML規(guī)則引入外部CSS文件,它
在網(wǎng)頁的標(biāo)簽對中使用標(biāo)記來引入外部樣式表文件,使用語法如下:

使用鏈接式時與導(dǎo)入式不同的是它會以網(wǎng)頁文件主體裝載前裝載CSS文件,因此顯示出來的網(wǎng)頁從一開始
就是帶樣式的效果的,它不會象導(dǎo)入式那樣先顯示無樣式的網(wǎng)頁,然后再顯示有樣式的網(wǎng)頁,這是鏈接
式的優(yōu)點。

如何使得一個DOM元素在瀏覽器可視范圍內(nèi)不顯示?
最基本的:
設(shè)置 display:none; 或  visibility:hidden;

技巧性的:
設(shè)置寬高為0,透明度為0,設(shè)置 z-index:-1000px;

display:none 與 visibility:hidden的區(qū)別?

是否是繼承屬性:display不是繼承屬性,而visibility是繼承屬性,后代元素的visibility屬性若存在則不會繼承,若不存在則繼承父元素visibility的值,意味著:父元素的visibility為hidden但是子元素的visibility為visible則子元素依舊可見,子元素visibility不存在則子元素不可見。而元素的display屬性設(shè)為none其后整棵子樹都不可見。

是否占據(jù)空間:使用display:none,在文檔渲染時,該元素如同不存在(但依然存在文檔對象模型樹中);而使用visibility:hidden,其占的空間會被空白占位。即一個(display:none)不會在渲染樹中出現(xiàn),一個(visibility:hidden)會。

頁面相關(guān)屬性改值后是否重新渲染:visibility :hidden不渲染;display:none渲染

px、em、rem的區(qū)別?

px、em都是長度單位。區(qū)別:px的值是固定的,寫多少就是多少,容易計算。em的值不是固定的,em繼承父元素的字體大小。
rem是CSS3新引進來的一個度量單位,rem是相對于根元素,這樣就意味著,我們只需要在根元素確定一個參考值,在根元素中設(shè)置多大的字體,這完全可以根據(jù)您自己的需求。

簡述盒子模型
盒子模型:內(nèi)容、內(nèi)邊距、外邊距、邊框

DOCTYPE的作用?嚴(yán)格模式與混雜模式的區(qū)別?

DOCTYPE聲明位于文檔的最前面,處于標(biāo)簽之前。告訴瀏覽器的解析器,用什么文檔類型規(guī)范來解析這個文檔。
在標(biāo)準(zhǔn)模式中,瀏覽器以其支持的最高標(biāo)準(zhǔn)呈現(xiàn)頁面;在混雜模式中,頁面以一種比較寬松的向后兼容的方式顯示。混雜模式通常模擬老式瀏覽器的行為以防止老站點無法工作。

Javascript的this用法?

情況一:純粹的函數(shù)調(diào)用

這是函數(shù)的最通常用法,屬于全局性調(diào)用,因此this就代表全局對象Global。
請看下面這段代碼,它的運行結(jié)果是1。
  

   function test(){
      this.x = 1;
      alert(this.x);
    }
    test(); // 1

為了證明this就是全局對象,我對代碼做一些改變:
  

      var x = 1;
    function test(){
      alert(this.x);
    }
    test(); // 1

運行結(jié)果還是1。再變一下:
  

var x = 1;

    function test(){
      this.x = 0;
    }
    test();
    alert(x); //0

  
情況二:作為對象方法的調(diào)用

函數(shù)還可以作為某個對象的方法調(diào)用,這時this就指這個上級對象。
  

     function test(){
      alert(this.x);
    }
    var o = {};
    o.x = 1;
    o.m = test;
    o.m(); // 1

  
情況三 作為構(gòu)造函數(shù)調(diào)用

所謂構(gòu)造函數(shù),就是通過這個函數(shù)生成一個新對象(object)。這時,this就指這個新對象。
  

 function test(){
      this.x = 1;
    }
    var o = new test();
    alert(o.x); // 1

運行結(jié)果為1。為了表明這時this不是全局對象,我對代碼做一些改變:
  

     var x = 2;
    function test(){
      this.x = 1;
    }
    var o = new test();
    alert(x); //2

運行結(jié)果為2,表明全局變量x的值根本沒變。

情況四 apply調(diào)用

apply()是函數(shù)對象的一個方法,它的作用是改變函數(shù)的調(diào)用對象,它的第一個參數(shù)就表示改變后的調(diào)用這個函數(shù)的對象。因此,this指的就是這第一個參數(shù)。
  

      var x = 0;
    function test(){
      alert(this.x);
    }
    var o={};
    o.x = 1;
    o.m = test;
    o.m.apply(); //0

apply()的參數(shù)為空時,默認調(diào)用全局對象。因此,這時的運行結(jié)果為0,證明this指的是全局對象。
如果把最后一行代碼修改為
  o.m.apply(o); //1
運行結(jié)果就變成了1,證明了這時this代表的是對象o。

JavaScript如何實現(xiàn)繼承?
一、構(gòu)造繼承法;
二、原型繼承法;
三、實例繼承法;

JavaScript深入之從原型到原型鏈

JavaScript深入系列的第一篇,從原型與原型鏈開始講起,如果你想知道構(gòu)造函數(shù)的實例的原型,原型的原型,原型的原型的原型是什么,就來看看這篇文章吧。

構(gòu)造函數(shù)創(chuàng)建對象

我們先使用構(gòu)造函數(shù)創(chuàng)建一個對象:

 

      function Person() {
     
      } 
      var person = new Person();
      person.name = "Kevin"; 
      console.log(person.name) // Kevin
      

在這個例子中,Person 就是一個構(gòu)造函數(shù),我們使用 new 創(chuàng)建了一個實例對象 person。
很簡單吧,接下來進入正題:

prototype

每個函數(shù)都有一個 prototype 屬性,就是我們經(jīng)常在各種例子中看到的那個 prototype ,比如:

 function Person() {
    
 } 
 // 雖然寫在注釋里,但是你要注意:
 // prototype是函數(shù)才會有的屬性
 Person.prototype.name = "Kevin"; 
 var person1 = new Person(); 
 var person2 = new Person(); 
 console.log(person1.name) // Kevin
 console.log(person2.name) // Kevin 

那這個函數(shù)的 prototype屬性到底指向的是什么呢?是這個函數(shù)的原型嗎?

其實,函數(shù)的 prototype屬性指向了一個對象,這個對象正是調(diào)用該構(gòu)造函數(shù)而創(chuàng)建的實例的原型,也就是這個例子中的 person1 和 person2 的原型。

那什么是原型呢?你可以這樣理解:每一個JavaScript對象(null除外)在創(chuàng)建的時候就會與之關(guān)聯(lián)另一個對象,這個對象就是我們所說的原型,每一個對象都會從原型"繼承"屬性。

讓我們用一張圖表示構(gòu)造函數(shù)和實例原型之間的關(guān)系:

在這張圖中我們用 Object.prototype 表示實例原型。

那么我們該怎么表示實例與實例原型,也就是 person 和 Person.prototype 之間的關(guān)系呢,這時候我們就要講到第二個屬性:

_proto _

這是每一個JavaScript對象(除了 null )都具有的一個屬性,叫__proto__,這個屬性會指向該對象的原型。

為了證明這一點,我們可以在火狐或者谷歌中輸入:

function Person() { 
   
} 
var person = new Person(); 
console.log(person.__proto__  === Person.prototype); // true 

于是我們更新下關(guān)系圖:

既然實例對象和構(gòu)造函數(shù)都可以指向原型,那么原型是否有屬性指向構(gòu)造函數(shù)或者實例呢?

constructor

指向?qū)嵗故菦]有,因為一個構(gòu)造函數(shù)可以生成多個實例,但是原型指向構(gòu)造函數(shù)倒是有的,這就要講到第三個屬性:constructor,每個原型都有一個 constructor 屬性指向關(guān)聯(lián)的構(gòu)造函數(shù)。

為了驗證這一點,我們可以嘗試:

function Person(){
   
} 
console.log(Person === Person.prototype.constructor); // true

所以再更新下關(guān)系圖: 綜上我們已經(jīng)得出:

function Person() {
 
} 
var person = new Person();
console.log(person.__proto__ == Person.prototype) // true
console.log(Person.prototype.constructor == Person) // true 
//順便學(xué)習(xí)一個ES5的方法,可以獲得對象的原型 
console.log(Object.getPrototypeOf(person) === Person.prototype) // true 

了解了構(gòu)造函數(shù)、實例原型、和實例之間的關(guān)系,接下來我們講講實例和原型的關(guān)系:

實例與原型

當(dāng)讀取實例的屬性時,如果找不到,就會查找與對象關(guān)聯(lián)的原型中的屬性,如果還查不到,就去找原型的原型,一直找到最頂層為止。

舉個例子:

function Person() { 

}
Person.prototype.name = "Kevin"; var
person = new Person(); person.name = "Daisy";
console.log(person.name) // Daisy delete person.name;
console.log(person.name) // Kevin 

在這個例子中,我們給實例對象 person 添加了 name 屬性,當(dāng)我們打印 person.name 的時候,結(jié)果自然為 Daisy。

但是當(dāng)我們刪除了 person 的 name 屬性時,讀取person.name,從 person 對象中找不到 name 屬性就會從 person 的原型也就是 person.__proto__,也就是 Person.prototype中查找,幸運的是我們找到了 name 屬性,結(jié)果為 Kevin。

但是萬一還沒有找到呢?原型的原型又是什么呢?

原型的原型

在前面,我們已經(jīng)講了原型也是一個對象,既然是對象,我們就可以用最原始的方式創(chuàng)建它,那就是:

var obj = new Object();
obj.name = "Kevin";
console.log(obj.name) // Kevin 

所以原型對象是通過 Object構(gòu)造函數(shù)生成的,結(jié)合之前所講,實例的 _proto _ 指向構(gòu)造函數(shù)的 prototype ,所以我們再更新下關(guān)系圖:

原型鏈

那Object.prototype 的原型呢?

null,不信我們可以打?。?/p>

console.log(Object.prototype.__proto__ === null) // true 
   

所以查到屬性的時候查到Object.prototype 就可以停止查找了。

所以最后一張關(guān)系圖就是

順便還要說一下,圖中由相互關(guān)聯(lián)的原型組成的鏈狀結(jié)構(gòu)就是原型鏈,也就是藍色的這條線。

補充

最后,補充三點大家可能不會注意的地方:

constructor

首先是 constructor 屬性,我們看個例子:

function Person() {

 } 
var person = new Person(); 
console.log(person.constructor === Person); //  true

當(dāng)獲取 person.constructor 時,其實 person 中并沒有 constructor屬性,當(dāng)不能讀取到constructor 屬性時,會從 person 的原型也就是 Person.prototype中讀取,正好原型中有該屬性,所以:

person.constructor === Person.prototype.constructor

_proto _

其次是 _proto _ ,絕大部分瀏覽器都支持這個非標(biāo)準(zhǔn)的方法訪問原型,然而它并不存在于 Person.prototype 中,實際上,它是來自于 Object.prototype ,與其說是一個屬性,不如說是一個getter/setter,當(dāng)使用 obj._ proto _ 時,可以理解成返回了
Object.getPrototypeOf(obj)。

真的是繼承嗎?

最后是關(guān)于繼承,前面我們講到“每一個對象都會從原型‘繼承’屬性”,實際上,繼承是一個十分具有迷惑性的說法,引用《你不知道的JavaScript》中的話,就是:

繼承意味著復(fù)制操作,然而 JavaScript 默認并不會復(fù)制對象的屬性,相反,JavaScript
只是在兩個對象之間創(chuàng)建一個關(guān)聯(lián),這樣,一個對象就可以通過委托訪問另一個對象的屬性和函數(shù),所以與其叫繼承,委托的說法反而更準(zhǔn)確些。

========================================待更新===========================================

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

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

相關(guān)文章

  • 前端面試集錦2017/4/13更新

    摘要:情況三作為構(gòu)造函數(shù)調(diào)用所謂構(gòu)造函數(shù),就是通過這個函數(shù)生成一個新對象。讓我們用一張圖表示構(gòu)造函數(shù)和實例原型之間的關(guān)系在這張圖中我們用表示實例原型。 瀏覽器的內(nèi)核分別是什么? IE: trident內(nèi)核 Firefox:gecko內(nèi)核 Safari:webkit內(nèi)核 Opera:以前是presto內(nèi)核,Opera現(xiàn)已改用Google Chrome的Blink內(nèi)核 Chrome:Blink(...

    yzd 評論0 收藏0
  • 前端面試集錦2017/4/13更新

    摘要:情況三作為構(gòu)造函數(shù)調(diào)用所謂構(gòu)造函數(shù),就是通過這個函數(shù)生成一個新對象。讓我們用一張圖表示構(gòu)造函數(shù)和實例原型之間的關(guān)系在這張圖中我們用表示實例原型。 瀏覽器的內(nèi)核分別是什么? IE: trident內(nèi)核 Firefox:gecko內(nèi)核 Safari:webkit內(nèi)核 Opera:以前是presto內(nèi)核,Opera現(xiàn)已改用Google Chrome的Blink內(nèi)核 Chrome:Blink(...

    iflove 評論0 收藏0
  • 「大集錦」WEB前端開發(fā) 辨析類 面試真題

    摘要:學(xué)堂碼匠面試?yán)镒畛3霈F(xiàn)的問題句式大概就是說說和的區(qū)別談?wù)労偷牟煌税梢徊úǖ谋嫖鲱}正在襲來,快快開啟防御,殺出重圍,來一場絕地反擊僵尸,啊,不對,辨析三連發(fā)掃描了眾多的面試題,發(fā)現(xiàn)額各個技術(shù)之間的辨析真的是如僵尸一般,一波一波的相信不少人 HTML5學(xué)堂-碼匠:面試?yán)镒畛3霈F(xiàn)的問題句式大概就是說說XXX和XXX的區(qū)別談?wù)刋XX和XXX的不同了吧~!一波波的辨析題正在襲來,快快開啟防御,...

    CoderStudy 評論0 收藏0
  • 「大集錦」WEB前端開發(fā) 辨析類 面試真題

    摘要:學(xué)堂碼匠面試?yán)镒畛3霈F(xiàn)的問題句式大概就是說說和的區(qū)別談?wù)労偷牟煌税梢徊úǖ谋嫖鲱}正在襲來,快快開啟防御,殺出重圍,來一場絕地反擊僵尸,啊,不對,辨析三連發(fā)掃描了眾多的面試題,發(fā)現(xiàn)額各個技術(shù)之間的辨析真的是如僵尸一般,一波一波的相信不少人 HTML5學(xué)堂-碼匠:面試?yán)镒畛3霈F(xiàn)的問題句式大概就是說說XXX和XXX的區(qū)別談?wù)刋XX和XXX的不同了吧~!一波波的辨析題正在襲來,快快開啟防御,...

    ralap 評論0 收藏0

發(fā)表評論

0條評論

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