摘要:如果函數(shù)沒有名稱函數(shù)表達式,就叫做匿名回調(diào)函數(shù)。回調(diào)函數(shù)不一定用于異步,同步阻塞場景下也會用到回調(diào)函數(shù)。比如說要求在執(zhí)行完某些操作后執(zhí)行回調(diào)函數(shù)。通過標簽訪問跨域的地址,返回一個參數(shù)為請求數(shù)據(jù)的的回調(diào)函數(shù),而不再直接是數(shù)據(jù)。
javascript
作為junior developer,僅僅覺得這些問題經(jīng)常在我面試的時候被問到,好記性不如爛筆頭,自己整理記錄一遍~~~
1.javascript如何實現(xiàn)繼承? 三種方式: 1. 原型繼承 // 優(yōu)點:既繼承了父類的模板,又繼承了父類的原型對象 // 缺點:父類實例化傳參,而不是子類實例化傳參(不符合常規(guī)語言的寫法) function Parent(work, drink) { this.work = function() { console.log(work); } this.drink = drink; } Parent.prototype.draw = function() { alert("I can draw"); } function Child() { this.cry = function() { console.log("the best ability is to cry"); } } Child.prototype = new Parent("code", "beer"); var xiaoLi = new Child(); xiaoLi.work(); // code xiaoLi.draw(); // I can draw xiaoLi.cry(); // the best ability is to cry 關(guān)于原型鏈的解釋:https://www.cnblogs.com/chengzp/p/prototype.html 2. 類繼承(借用構(gòu)造函數(shù)的方式繼承) // 優(yōu)點:繼承了父類的模板,方便通過子類實例化傳參 // 缺點:不能繼承父類的原型對象 function Parent(work, drink) { this.work = function() { console.log(work); } this.drink = drink; } Parent.prototype.draw = function() { alert("I can draw"); } function Child(work, drink, sex) { Parent.call(this, work, drink); this.sex = sex; } var xiaoLi = new Child("code", "beer", "male"); alert(xiaoLi.drink); // code xiaoLi.work(); // beer // xiaoLi.draw(); //沒有繼承父類的原型對象,所以,會報錯:xiaoLi.draw() is not a function console.log(xiaoLi.sex); // male 3. 混合繼承(原型繼承和類繼承) // 混合繼承(原型繼承和類繼承(借用構(gòu)造函數(shù)的方式繼承)) function Parent(eat, sleep) { this.eat = function() { console.log("function 1" + eat); } this.sleep = function() { console.log("function 2" + sleep); } } Parent.prototype.other = "work"; function Child(eat, sleep, age) { Parent.call(this, eat, sleep); this.age = age; } Child.prototype = new Parent(); var xiaoLi = new Child("cake", "want to sleep", "10"); xiaoLi.eat(); xiaoLi.sleep(); console.log(xiaoLi.age); console.log(xiaoLi.other);
2.原生ajax是如何實現(xiàn)的? 特點: 在不重新加載整個網(wǎng)頁的情況下,對頁面局部進行刷新。 XMLHttpRequest對象是實現(xiàn)ajax的基礎(chǔ),XMLHttpRequest有很多方法,常用的有open(),send()等 ajax請求共包含五個步驟: 1.創(chuàng)建XMLHttpRequest對象(一個異步調(diào)用對象) 2.設(shè)置HTTP請求的參數(shù)(請求方法,url,是否異步) 3.設(shè)置響應HTTP請求狀態(tài)變化的回調(diào)函數(shù) 4.發(fā)送HTTP請求 5.獲取異步調(diào)用返回的數(shù)據(jù) 6.局部更新頁面 var xhr = new XMLHttpRequest(); xhr.open("POST", url, true); xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); xhr.onreadystatechange = function () { if (xhr.readyState == 4 && (xhr.status == 200 || xhr.status == 304)) { fn.call(this, xhr.responseText); } }; xhr.send(data); post方法一定要用setRequestHeader("header","value");
3.作用域 塊級作用域:ES6才支持,在{}大括號內(nèi)的就是塊級作用域 (塊級作用域的出現(xiàn)解決了:for循環(huán)定義的變量造成的全局污染;不用再通過閉包來保存必要的變量了) 函數(shù)作用域:在函數(shù)中實現(xiàn)的 全局作用域:在外部聲明的,如果沒有用var關(guān)鍵字聲明,在非嚴格模式下,也為全局作用域 注意: 在es6之前沒有塊級作用域這個概念,所以在{}塊級作用域中聲明的變量其實就是全局變量(舉個栗子) for (var i = 1; i <= 10; i++) { console.log (i); // outputs 1, 2, 3, 4, 5, 6, 7, 8, 9, 10;? }; ? ?// The variable i is a global variable and it is accessible in the following function with the last value it was assigned above ? ?function aNumber () { console.log(i); } ? ?// The variable i in the aNumber function below is the global variable i that was changed in the for loop above. Its last value was 11, set just before the for loop exited:? aNumber (); // 11? 關(guān)于es6的let和const: let和const沒有變量聲明的提升; let和const不允許在相同作用域內(nèi)重復聲明;
4.如何理解閉包? 比較常用的情景: 在A函數(shù)里返回B函數(shù),B函數(shù)可以調(diào)用A函數(shù)的局部變量; 特點: 1.函數(shù)嵌套 2.函數(shù)內(nèi)部可以引用外部的參數(shù)和變量 3.閉包函數(shù)里的參數(shù)和變量不會被垃圾回收機制回收(閉包會使變量始終保存在內(nèi)存中,如果使用不當會增大內(nèi)存消耗) 閉包的好處: 1.希望變量長期保存在內(nèi)存中 2.避免全局變量的污染 3.私有變量的存在
5.回調(diào)函數(shù) 定義: 函數(shù)A作為參數(shù)傳遞給函數(shù)B,在函數(shù)B中執(zhí)行函數(shù)A,此時函數(shù)A就叫做回調(diào)函數(shù)。如果函數(shù)沒有名稱(函數(shù)表達式),就叫做匿名回調(diào)函數(shù)。 回調(diào)函數(shù)不一定用于異步,同步(阻塞)場景下也會用到回調(diào)函數(shù)。比如說要求在執(zhí)行完某些操作后執(zhí)行回調(diào)函數(shù)。 舉幾個栗子: 同步(阻塞)回調(diào): fn1執(zhí)行完后執(zhí)行fn2 在同步場景下,回調(diào)函數(shù)最后執(zhí)行 異步回調(diào): ajax請求 在異步回調(diào)中,回調(diào)函數(shù)有可能不執(zhí)行,因為時間沒有被觸發(fā)或者條件不滿足 回調(diào)函數(shù)的應用場景: 動態(tài)加載js后,圖片加載完成后,ajax請求等 另外,最好保證回調(diào)存在且必須是函數(shù)引用或者函數(shù)表達式: (callback && typeof(callback) === "function") && callback();
6.es6常用新特性: 1.let和const(新的變量聲明方式,允許把變量作用域控制在塊級里面) 2.解構(gòu)賦值(對象和數(shù)組都適用) 3.promise 一個對象,用來表示并傳遞異步操作的最終結(jié)果 交互方式:將回調(diào)函數(shù)傳入then方法獲取最終結(jié)果或出錯原因 以鏈式調(diào)用代替回調(diào)函數(shù)層層嵌套 //生成promise實例 var promise = new Promise(function(resolve, reject) { //...other code... if (/* 異步操作成功 */){ resolve(value);//resolve函數(shù)將Promise對象的狀態(tài)從Pending變?yōu)镽esolved } else { reject(error);//reject函數(shù)將Promise對象的狀態(tài)從Pending變?yōu)镽ejected } }); //Promise實例生成以后,用then方法分別指定Resolved狀態(tài)和Reject狀態(tài)的回調(diào)函數(shù)。 promise.then(function(value) { // success }, function(err) { // failure }); jQuery.ajax()方法中運用promise: var http = { get: function(url) { var promise = new Promise(function(resolve, reject) { $.ajax({ url: url, method: "get", success: function(data) { resolve(data); }, error: function(xhr, statusText) { reject(statusText); } }); }); return promise; } }; http.get("data.php").then(function(data) { document.write(data); }, function(err) { document.write(err); }); 這里是獲取的data值: /* data.php文件 */7.cookie和web storage的區(qū)別? 1.與服務器的交互上 cookie始終會在http同源請求頭上攜帶(即使不需要),在瀏覽器端和客戶端之間傳來傳去 localStorage和sessionStorage不會主動發(fā)送給服務器,僅保存在本地 2.儲存大小 cookie由于不同瀏覽器的限制,大小在4KB左右 localStorage和sessionStorage儲存大小達5MB或以上 3.過期時間 cookie與設(shè)置的有效期時間有關(guān) localStorage存儲持久數(shù)據(jù),除非主動刪除 sessionStorage在瀏覽器關(guān)閉后自動刪除8.cookie和session的區(qū)別? cookie數(shù)據(jù)存放在客戶的瀏覽器,session存儲在服務器上 考慮到安全性 建議: 將登陸等重要信息存放為session 其它信息可以放在cookie中9.一個頁面從輸入url到頁面加載,這個過程都發(fā)生了什么? 簡潔版: 1.瀏覽器根據(jù)請求的url向服務器發(fā)送請求 2.服務求處理完成后返回數(shù)據(jù),瀏覽器接收文件 3.瀏覽器對加載到的資源(html, css, js, image等)進行語法解析 4.載入解析到的資源,渲染頁面10.事件委派 優(yōu)點:減少事件注冊;簡化DOM更新時,相應事件的更新
11.拖拽
12.DOM事件 DOM事件(3個級別):DOM0;DOM2;DOM3; DOM0特點:js與html強耦合;綁定的速度快,不需要操作dom,可直接在元素上綁定 dom.onclick=function(){ do something; } DOM2特點:可以在一個元素中添加不同的事件,事件不會覆蓋; dom.addEventListener("click",function(){},false) DOM3特點:在dom2的基礎(chǔ)上,添加更多的事件類型;可自定義事件; var event=new Event("test"); dom.addEventListener("test",function(){},false); setTimeout(function(){ oBox.dispatchEvent(event); },2000) DOM事件捕獲的具體流程: window->document->html->body->...->目標元素 事件流: 捕獲->目標階段->冒泡 一個節(jié)點上注冊多個事件: 解決響應優(yōu)先級:event.stopImmediatePropagation();
13.javascript如何實現(xiàn)一個類,怎么實例化這個類? 1.構(gòu)造函數(shù)法 // 構(gòu)造函數(shù)法(this + prototype) // 用new關(guān)鍵字生成實例 對象 function Person(name, age) { this.name = name; this.age = age; } Person.prototype.info = function() { alert(this.name + this.age); } var xiaoLi = new Person("李佳", 26); xiaoLi.info(); 2.es6語法糖 // es6語法糖 // 用new關(guān)鍵字生成實例化對象 // 優(yōu)點:避免了使用prototype class Person { constructor(x, y) { this.x = x; this.y = y; } info() { alert(this.x + this.y); } } var xiaoLi = new Person("李佳", 26); xiaoLi.info();
14.解釋作用域鏈 1.全局函數(shù)無法查看局部函數(shù)的細節(jié),局部函數(shù)可以訪問全局函數(shù)的屬性 2.當前作用域沒有找到屬性或方法,可以向上層乃至全局尋找,這種形式就是作用域鏈
15. .call()和.apply()的區(qū)別? .call()和.apply()是每個函數(shù)都包含而非繼承來的方法,用于改變函數(shù)的作用域 兩方法作用相同 區(qū)別在接收參數(shù)的方式不同,call()要求明確傳入每一個參數(shù); 擴充作用域,舉個栗子: window.color = "red"; var o = {color: "blue"}; function sayColor() { alert(this.color); } sayColor(); // red sayColor.call(this); // red sayColor.call(window); //red sayColor.call(o); // blue
15.jsonp的原理 利用script標簽可以跨域訪問的特性,動態(tài)創(chuàng)建script標簽,給標簽設(shè)置src屬性。 通過script標簽訪問跨域的地址,返回一個參數(shù)為請求數(shù)據(jù)的callback的回調(diào)函數(shù),而不再直接是json數(shù)據(jù)。 具體實現(xiàn)步驟: 原生: $(document).ready(function(){ var url = "http://www.practice-zhao.com/student.php?id=1&callback=jsonhandle"; var obj = $(""); obj.attr("src",url); $("body").append(obj); }); jquery: $(document).ready(function(){ $.ajax({ type : "get", async: false, url : "http://www.practice-zhao.com/student.php?id=1", dataType: "jsonp", jsonp:"callback", //請求php的參數(shù)名 jsonpCallback: "jsonhandle",//要執(zhí)行的回調(diào)函數(shù) success : function(data) { alert("age:" + data.age + "name:" + data.name); } }); });
16.jquery鏈式調(diào)用 原理:對象方法上最后加上return this;語句 優(yōu)點:節(jié)省代碼,代碼看起來更優(yōu)雅
17.原型和原型鏈 先記兩個干巴巴的結(jié)論: 舉個栗子: function Person(name, age, job) { this.name = name; this.age = age; this.job = job; this.sayName = function() { alert(this.name) } } var person1 = new Person("Zaxlct", 28, "Software Engineer"); var person2 = new Person("Mick", 23, "Doctor"); console.log(person1.constructor == Person); //true console.log(person2.constructor == Person); //true 1.實例的構(gòu)造函數(shù)屬性(constructor)指向構(gòu)造函數(shù)。 var A = new Person(); Person.prototype = A; 2.原型對象(Person.prototype)是 構(gòu)造函數(shù)(Person)的一個實例。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/107820.html
摘要:手把手教你做個人火的時候,隨便一個都能賺的盆滿缽滿,但是,個人沒有服務端,沒有美工,似乎就不能開發(fā)了,真的是這樣的嗎秘密花園經(jīng)典的中文手冊。涵蓋前端知識體系知識結(jié)構(gòu)圖書推薦以及入門視頻教程,全的簡直不要不要的了。 JavaScript 實現(xiàn)點擊按鈕復制指定區(qū)域文本 html5 的 webAPI 接口可以很輕松的使用短短的幾行代碼就實現(xiàn)點擊按鈕復制區(qū)域文本的功能,不需要依賴 flash。...
摘要:我對知乎前端相關(guān)問題的十問十答張鑫旭張鑫旭大神對知乎上經(jīng)典的個前端問題的回答。作者對如何避免常見的錯誤,難以發(fā)現(xiàn)的問題,以及性能問題和不好的實踐給出了相應的建議。但并不是本身有問題,被標準定義的是極好的。 這一次,徹底弄懂 JavaScript 執(zhí)行機制 本文的目的就是要保證你徹底弄懂javascript的執(zhí)行機制,如果讀完本文還不懂,可以揍我。 不論你是javascript新手還是老...
showImg(https://segmentfault.com/img/remote/1460000018716142?w=200&h=200); showImg(https://segmentfault.com/img/remote/1460000018716143);showImg(https://segmentfault.com/img/remote/1460000010953710);...
閱讀 1237·2023-04-25 15:53
閱讀 2108·2021-11-19 09:40
閱讀 3495·2021-10-11 10:59
閱讀 2075·2019-08-30 15:55
閱讀 1963·2019-08-30 15:54
閱讀 2308·2019-08-29 13:03
閱讀 2761·2019-08-28 18:17
閱讀 1516·2019-08-27 10:51