摘要:原型是由構造器函數創建的。從原型繼承的方法與屬性是在構造器函數中定義的。可以將此屬性作為構造器使用獲得某個對象實例的構造器的名字,可以這么用該屬性的值是那個函數本身,而不是一個包含函數名稱的字符串。
前端面試題總結 寫在前面的話:
寫文目的:總結前端面試過程中沒回答上來的點,深化印象,也方便日后溫習。
寫文方法:寫之前先自己看相關知識,理解好后過段時間根據記憶來寫,最后對比糾正。
準備面試流程:1.更新簡歷,多參考其他的優秀簡歷
2.復習面試題
筆者就是因為只更新了簡歷沒有復習導致基礎不過關,錯過兩家心儀的公司。
順便說下,平時工作中的確很多時候用不到也不會去背某些面試中的問題,不過面試題中基礎部分很重要,理解好基礎才更輕松掌握新框架新知識。時不時去看看面試題也不失為一種鞏固基礎的方法。一般一面面基礎,二面面項目,項目經驗再多,一面過不了,什么戲也不會有。
被面過的面試題: csscss優先級,屬性選擇器的優先級在哪
0.類型選擇器(如, h1)和偽元素(如, ::before)
1.類選擇器,屬性選擇器,偽類(如,:hover)
3.ID選擇器
通用選擇器(universal selector)(*), 組合子(combinators) (+, >, ~, " ") 和 否定偽類(negation pseudo-class)(:not()) 對特異性沒有影響。(但是,在 :not() 內部聲明的選擇器是會影響優先級,在計算選擇器數量時還是會把其中的選擇器當做普通選擇器進行計數)。
4.給元素添加的內聯樣式總會覆蓋外部樣式表的任何樣式 ,因此可看作是具有最高的優先級。
權重記憶口訣。一個元素名,或者偽元素+1,一個屬性選擇器/class或者偽類+10,一個id+100,一個行內樣式+1000。
**!important 規則例外
當在一個樣式聲明中使用一個!important 規則時,此聲明將覆蓋任何其他聲明。**
直接定位的樣式權重大于繼承的樣式,無論繼承的規則的特異性(優先級)如何。
Styles for a directly targeted element will always take precedence over inherited styles, regardless of the specificity of the inherited rule.
h1 { color: purple; } #parent { color: green; }
當它應用在下面的HTML時:
Here is a title!
瀏覽器會將h1渲染成紫色。
因為h1選擇器清晰地定位了元素。
~ 組合器
A + B 匹配任意元素,滿足條件:B是A的下一個兄弟節點(AB有相同的父結點,并且B緊跟在A的后面)
A ~ B 滿足條件:B是A之后的兄弟節點中的任意一個(AB有相同的父節點,B在A之后,但不一定是緊挨著A)(會盡可能多匹配)
js基礎什么是閉包
閉包是由函數與創建該函數的環境所組成的
優點:減少全局變量污染
缺點:影響腳本性能
3==true 打印出什么
會打印出false,這里會將true轉變成1
Number 和 String 或者 Bool 類型比較,會對String 或者 Bool 類型進行ToNumber()轉換
Number(true) // 1 Number(false) // 0 1==true //true 1===true //false 3==true //false
變量聲明提升
變量聲明無論出現在代碼的任何位置,都會在代碼執行前處理。所以在代碼的任何位置聲明變量就好像在代碼開頭聲明一樣。
var a = 100; function fn() { alert(a); var a = 200; alert(a); } fn(); alert(a); var a; alert(a); //這里alert出100 var a = 300; alert(a);
not defined 與 undefined
console.log(a) //報錯 Uncaught ReferenceError: a is not defined var b; console.log(b) //undefined
判斷變量是不是數組的幾個方法
var a=[]; a.constructor===Array //true a instanceof Array === true //true
?? 注意:以上方法在跨frame時會有問題,跨frame實例化的對象不共享原型
var iframe = document.createElement("iframe"); //創建iframe document.body.appendChild(iframe); //添加到body中 xArray = window.frames[window.frames.length-1].Array; var arr = new xArray(1,2,3); // 聲明數組[1,2,3] alert(arr instanceof Array); // false alert(arr.constructor === Array); // false
解決:
Object.prototype.toString.call(a) // "[object Array]" Array.isArray(a) //true
bind,call,apply用法與區別
用法:都是改變函數內this指向
bind:返回一個新的函數,調用新的函數才執行,新函數里this永久地被綁定到了bind的第一個參數上
而call與apply能直接執行
fuc.call(thisObj,a,b,c) fuc.apply(thisObj,[a,b,c]) // apply 傳數組
原型 與 prototype屬性
原型:
JavaScript的對象中都包含了一個" [[Prototype]]"內部屬性,這個屬性所對應的就是該對象的原型。對象從原型繼承方法與屬性。原型可能也有原型,這種關系被稱為原型鏈。
"[[Prototype]]"作為對象的內部屬性,是不能被直接訪問的。所以為了方便查看一個對象的原型,大多數現代瀏覽器還是提供了一個名為"__proto__"這個非標準(不是所有瀏覽器都支持)的訪問器(ECMA引入了標準對象原型訪問"Object.getPrototype(object)")。
原型是由構造器函數創建的。從原型繼承的方法與屬性是在構造器函數中定義的。
prototype屬性:
prototype屬性并不指向當前對象的原型對象(原型對象是一個內部對象,應當使用 __proto__ 訪問)。prototype屬性是繼承成員被定義的地方。
常見的對象定義模式是,在構造器(函數體)中定義屬性、在 prototype 屬性上定義方法。(在prototype屬性中定義屬性會不夠靈活)
發現的比較奇異的點:一個變量不是函數的話默認沒有 prototype屬性,是函數的話默認就有 prototype屬性,并且prototype對象中的constructor屬性就是它本身
var a = {}; console.log(a.__proto__) //{constructor: ?, __defineGetter__: ?, __defineSetter__: ?, hasOwnProperty: ?, __lookupGetter__: ?,?…} console.log(a.__proto__ === Object.prototype) //true console.log(a.constructor) //? Object() { [native code] } console.log(a.constructor === Object) //true //******不是函數的話默認沒有 prototype屬性 console.log(a.prototype) //undefined console.log("b:") var b = function c() { }; console.log(b.__proto__) //? () { [native code] } console.log(b.__proto__ === Function.prototype) //true console.log(b.constructor) //? Function() { [native code] } console.log(b.constructor === Function) //true //******函數默認就有 prototype屬性,并且prototype對象中的constructor屬性就是它本身 console.log(b.prototype) //{constructor: ?} console.log(b.prototype.constructor) //? c() { } console.log(b.prototype.constructor===b) //true
constructor
每個對象實例都具有 constructor 屬性,它指向創建該實例的構造器函數。
可以將此屬性作為構造器使用:
var person3 = new person1.constructor("Karen", "Stephenson", 26, "female", ["playing drums", "mountain climbing"]);
獲得某個對象實例的構造器的名字,可以這么用:
person1.constructor.name
該屬性的值是那個函數本身,而不是一個包含函數名稱的字符串。對于原始值(js中有5種:null undefined number boolean string),該屬性為只讀。
var a = 1; console.log(a.prototype) //undefined console.log(a.constructor) //? Number() { [native code] } var b = []; console.log(b.prototype) //undefined console.log(b.constructor) //? Array() { [native code] } //改變 a b 的constructor為 {} a.constructor = {} b.constructor = {} console.log(a.constructor) //沒有變,還是 ? Number() { [native code] } console.log(b.constructor) //{}
new
class
函數堆棧
ECMAScript中變量的兩種類型
原始值:
引用值:
js三大組成部分
1.ECMAScript
2.dom
3.bom
除了 GET POST,還有哪些方法
keep-alive
http返回碼100 200 300 400分別代表什么,即響應的5種類型
100:信息響應
200:成功
300:重定向
400:客戶端錯誤
500:服務端錯誤
理解重定向
http無狀態含義
解釋三次握手,四次揮手
三次握手
1.客戶端發syn包給服務端,等待服務器確認(syn:同步序列編號(Synchronize Sequence Numbers))
2.服務端發syn+ack包給客戶端
3.客戶端發確認包ack給服務端
四次揮手
中斷連接端可以是Client端,也可以是Server端。
1.關閉主動方發送fin包
2.被動方發送ack包
3.被動方關閉連接,發送fin包
4.主動方發送ack包確認
數據結構與算法鏈表和數組的區別
js代碼實現了解過哪些排序算法
自己實現個jQuery,可以傳選擇器進去,然后實現css()與height()方法
demo
var myJquery4 = function (selector) { //console.log(this) //window return new jqNodes(selector) //new會創造一個對象實例,對象實例繼承自構造函數的prototype,這里是jqNodes.prototype } var jqNodes = function (selector) { console.log(this) //1.以new調用時this指向即將創建的新對象 //2.直接調用則指向 window this._items = document.querySelectorAll(selector) return this } var myJqueryCore = { //放核心方法 css: function () { console.log(this) //myJquery4("li").css("color") 這樣調用時是作為new出來的對象原型里的方法調用的,this指向new出來的對象 var prop = arguments[0], val = arguments[1] if (!val) return getComputedStyle(this._items[0]).getPropertyValue(prop); Array.prototype.map.call(this._items, function (c) { return c.setAttribute("style", prop + ":" + val) }) return this } } jqNodes.prototype = myJqueryCore //關鍵
寫個輪播圖
之前感覺比較困擾的是從最后一頁到第一頁如何無縫滑動。無縫滑動的關鍵在于在第一頁前放上最后一頁,在最后一頁后面再放上第一頁。在最后一頁點擊后一頁時,先滑動到放置在后邊的第一頁,滑動完成后立刻改變父元素的left值到排列在第二個的第一頁。
demo
html結構:
5123451
關鍵js:
$("#list").animate({ left: newLeft }, function () { if (newLeft < -3000) { list.style.left = -600 + "px"; } else if (newLeft > -600) { list.style.left = -3000 + "px"; } })
菜單高亮滾動監聽
主要參考了 http://blog.csdn.net/sinrryzh...
我修改成了可以有多個固定導航的
demo
網上看的面試題&自己發現的面試知識點欄目1內容
欄目2內容
欄目3內容
欄目4內容
欄目5內容
欄目6內容
欄目7內容
欄目2-1內容
欄目2-2內容
欄目2-3內容
欄目2-4內容
欄目2-5內容
欄目2-6內容
欄目2-7內容
注:自己發現的面試知識點一般是在工作學習中發現的基礎重要但之前被自己忽略的知識點。
js基礎全等號優先級大于邏輯與
var a=1===2&&3?4:5
逗號操作符
逗號操作符 對它的每個操作數求值(從左到右),并返回最后一個操作數的值。
var x=(0,1) //x=1
比較對象
兩個獨立聲明的對象永遠也不會相等,即使他們有相同的屬性,只有在比較一個對象和這個對象的引用時,才會返回true.
encodeURI encodeURIComponent
encodeURI
encodeURI 會替換所有的字符,但不包括以下字符,即使它們具有適當的UTF-8轉義序列:
類型 包含 保留字符 ; , / ? : @ & = + $ 非轉義的字符 字母 數字 - _ . ! ~ * " ( ) 數字符號 #
encodeURI自身無法產生能適用于HTTP GET 或 POST 請求的URI,例如對于 XMLHTTPRequests, 因為 "&", "+", 和 "=" 不會被編碼,然而在 GET 和 POST 請求中它們是特殊字符。然而encodeURIComponent這個方法會對這些字符編碼。
encodeURIComponent
轉義除了字母、數字、(、)、.、!、~、*、"、-和_之外的所有字符。
dangerouslysethtml會過濾掉__html屬性里的 ,是因為用了encodeURI函數來避免xss攻擊
encodeURI("http:////") -->”////“ encodeURI("") --> Uncaught SyntaxError: Invalid or unexpected token encodeURIComponent("http:////") -->"%2F%2F%2F%2F" encodeURIComponent("/") --> "%2F" encodeURIComponent("") --> Uncaught SyntaxError: Invalid or unexpected tokenhttp協議
xss
cross-site scripting,跨站腳本,屬于代碼注入的一種。它允許惡意用戶將代碼注入到網頁上,其他用戶在觀看網頁時就會受到影響。這類攻擊通常包含了html以及用戶端腳本語言。
攻擊實例:用戶A提交表單事加入類似以下代碼,如果提交表單時沒有做檢測,而之后的結果頁面是其他用戶也能看到的,那么其他頁面看到的結果頁就會受到影響。
解決辦法:不信賴用戶輸入,對特殊字符如”<”,”>”轉義。
uri url urn
uri:統一資源標識符
url:統一資源定位符
urn:統一資源名稱
url與urn是uri的子集。
讓uri能成為url的是那個“訪問機制”,“網絡位置”。e.g. http:// or ftp://.。
urn是唯一標識的一部分,就是一個特殊的名字。
etag是什么
ETag(entity tag)唯一地表示一份資源的實體標簽。
標簽是由 ASCII 字符組成的字符串,用雙引號括起來(如 "675af34563dc-tr34")。前面可以加上 W/ 前綴表示應該采用弱比較算法。
ETag: "33a64df551425fcc55e4d42a148795d9f25f89d4" ETag: W/"0815"
ETag由Web服務器根據URL上的資源的特定版本而指定。如果那個URL上的資源內容改變,一個新的不一樣的ETag就會被分配。ETag的比較只對同一個URL有意義——不同URL上的資源的ETag值可能相同也可能不同,從他們的ETag的比較中無從推斷。
用法:
1.檢測"空中碰撞"(資源同步更新而相互覆蓋):
在ETag和 If-Match 頭部的幫助下,可以檢測到"空中碰撞"的編輯沖突。
2.緩存未更改的資源
如果用戶再次訪問給定的URL(設有ETag字段),顯示資源過期了且不可用,客戶端就發送值為ETag的If-None-Match header字段:
If-None-Match: "33a64df551425fcc55e4d42a148795d9f25f89d4"
服務器將客戶端的ETag(作為If-None-Match字段的值一起發送)與其當前版本的資源的ETag進行比較,如果兩個值匹配(即資源未更改),服務器將返回不帶任何內容的304未修改狀態,告訴客戶端緩存版本可用(新鮮)。
If-Match 頭部
請求首部 If-Match 的使用表示這是一個條件請求。在請求方法為 GET 和 HEAD 的情況下,服務器僅在請求的資源滿足此首部列出的 ETag 之一時才會返回資源。而對于 PUT 或其他非安全方法來說,只有在滿足條件的情況下才可以將資源上傳。
應用:
GET 和 HEAD 方法,搭配 Range首部使用,可以用來保證新請求的范圍與之前請求的范圍是對同一份資源的請求。如果 ETag 無法匹配,那么需要返回 416 (Range Not Satisfiable,范圍請求無法滿足) 響應。
2.對于其他方法來說,尤其是 PUT, If-Match 首部可以用來檢測用戶想要上傳的不會覆蓋獲取原始資源之后做出的更新。如果請求的條件不滿足,那么需要返回 412 (Precondition Failed,先決條件失敗) 響應。
語法:
If-Match:, , …
樂觀并發控制
ASCII字符串
ASCII (發音: /??ski/ ,American Standard Code for Information Interchange,美國信息交換標準碼) 是計算機中最常用的編碼方式,用于將字母,數字,標點符號和控制字符轉換為計算機可以理解的數字形式。
ASCII的局限在于只能顯示26個基本拉丁字母、阿拉伯數目字和英式標點符號,因此只能用于顯示現代美國英語(而且在處理英語當中的外來詞如na?ve、café、élite等等時,所有重音符號都不得不去掉,即使這樣做會違反拼寫規則)。而ASCII雖然解決了部分西歐語言的顯示問題,但對更多其他語言依然無能為力。因此現在的軟件系統大多采用Unicode。
ASCII主要用于顯示現代英語和其他西歐語言。從2007年開始逐漸被UTF-8 代替。
Unicode
Unicode(中文:萬國碼、國際碼、統一碼、單一碼)是計算機科學領域里的一項業界標準。它對世界上大部分的文字系統進行了整理、編碼,使得電腦可以用更為簡單的方式來呈現和處理文字。
UTF-8
UTF-8(8-bit Unicode Transformation Format)是一種針對Unicode的可變長度字符編碼,也是一種前綴碼。它可以用來表示Unicode標準中的任何字符,且其編碼中的第一個字節仍與ASCII兼容,這使得原來處理ASCII字符的軟件無須或只須做少部分修改,即可繼續使用。因此,它逐漸成為電子郵件、網頁及其他存儲或發送文字的應用中,優先采用的編碼。
Range首部
Range 是一個請求首部,告知服務器返回文件的哪一部分。在一個 Range 首部中,可以一次性請求多個部分,服務器會以 multipart 文件的形式將其返回。如果服務器返回的是范圍響應,需要使用 206 Partial Content 狀態碼。假如所請求的范圍不合法,那么服務器會返回 416 Range Not Satisfiable 狀態碼,表示客戶端錯誤。服務器允許忽略 Range 首部,從而返回整個文件,狀態碼用 200 。
語法:
Range:= - Range: = - Range: = - , -
Range: bytes=200-1000, 2000-6576, 19000-
一級域名,二級域名
以www.baidu.com為例子
最右邊一個點右邊的為頂級域名(一級域名)com
一級域名左邊是二級域名 baidu
主域,子域
子域名域名系統等級中,屬于更高一層域的域。比如,mail.example.com
和calendar.example.com是example.com的兩個子域,而example.com
則是頂級域.com的子域
為什么換工作
不要說是因為錢少。上一家的薪資不要做假,因為公司可能會查。期望薪資可以要高點,說明。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/112601.html
摘要:整理收藏一些優秀的文章及大佬博客留著慢慢學習原文協作規范中文技術文檔協作規范阮一峰編程風格凹凸實驗室前端代碼規范風格指南這一次,徹底弄懂執行機制一次弄懂徹底解決此類面試問題瀏覽器與的事件循環有何區別筆試題事件循環機制異步編程理解的異步 better-learning 整理收藏一些優秀的文章及大佬博客留著慢慢學習 原文:https://www.ahwgs.cn/youxiuwenzhan...
摘要:前端面試題總結持續更新中為什么只需要寫需要來規范瀏覽器的行為讓瀏覽器按照它們應該的方式來運行基于所以需要對進行引用,才能告知瀏覽器文檔所使用的文檔類型。 前端面試題總結——H5(持續更新中) 1.HTML5 為什么只需要寫 ? HTML5 需要doctype來規范瀏覽器的行為,讓瀏覽器按照它們應該的方式來運行; HTML4.01基于SGML,所以需要對DTD進行引用,才能告知瀏覽器文檔...
摘要:在此基礎上加入了回調函數,加載完之后會執行中定義的函數,所需要的數據會以參數的形式傳遞給該函數。通常的做法是,為它們指定回調函數。 前端面試題總結——JS(持續更新中) 1.javascript的typeof返回哪些數據類型 Object number function boolean underfind string 2.例舉3種強制類型轉換和2種隱式類型轉換? 強制(parseIn...
摘要:前言一直混跡社區突然發現自己收藏了不少好文但是管理起來有點混亂所以將前端主流技術做了一個書簽整理不求最多最全但求最實用。 前言 一直混跡社區,突然發現自己收藏了不少好文但是管理起來有點混亂; 所以將前端主流技術做了一個書簽整理,不求最多最全,但求最實用。 書簽源碼 書簽導入瀏覽器效果截圖showImg(https://segmentfault.com/img/bVbg41b?w=107...
摘要:等知名網站已經開始測試并使用格式。頁面加載速度更快結構化清晰頁面顯示簡潔。表現與結構相分離。易于優化搜索引擎更友好,排名更容易靠前。用于替換當前元素,用于在當前文檔和引用資源之間確立聯系。 前端面試題總結——HTML(持續更新中) 1.什么是HTML? HTML:HyperText Markup Language超文本標記語言 2.XHTML和HTML有什么區別 HTML是一種基本的W...
閱讀 1158·2021-09-22 15:43
閱讀 2354·2021-09-22 15:32
閱讀 4522·2021-09-22 15:11
閱讀 2215·2019-08-30 15:55
閱讀 2587·2019-08-30 15:54
閱讀 991·2019-08-30 15:44
閱讀 1105·2019-08-29 13:26
閱讀 800·2019-08-29 12:54