国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

前端知識點整理——javascript

ermaoL / 2174人閱讀

摘要:如果函數(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

    相關(guān)文章

    • 前端識點整理

      摘要:難怪超過三分之一的開發(fā)人員工作需要一些知識。但是隨著行業(yè)的飽和,初中級前端就業(yè)形勢不容樂觀。整個系列的文章大概有篇左右,從我是如何成為一個前端工程師,到各種前端框架的知識。 為什么 call 比 apply 快? 這是一個非常有意思的問題。 作者會在參數(shù)為3個(包含3)以內(nèi)時,優(yōu)先使用 call 方法進行事件的處理。而當參數(shù)過多(多余3個)時,才考慮使用 apply 方法。 這個的原因...

      Lowky 評論0 收藏0
    • 前端識點整理

      摘要:難怪超過三分之一的開發(fā)人員工作需要一些知識。但是隨著行業(yè)的飽和,初中級前端就業(yè)形勢不容樂觀。整個系列的文章大概有篇左右,從我是如何成為一個前端工程師,到各種前端框架的知識。 為什么 call 比 apply 快? 這是一個非常有意思的問題。 作者會在參數(shù)為3個(包含3)以內(nèi)時,優(yōu)先使用 call 方法進行事件的處理。而當參數(shù)過多(多余3個)時,才考慮使用 apply 方法。 這個的原因...

      snowLu 評論0 收藏0
    • 前端基礎(chǔ)入門

      摘要:手把手教你做個人火的時候,隨便一個都能賺的盆滿缽滿,但是,個人沒有服務端,沒有美工,似乎就不能開發(fā)了,真的是這樣的嗎秘密花園經(jīng)典的中文手冊。涵蓋前端知識體系知識結(jié)構(gòu)圖書推薦以及入門視頻教程,全的簡直不要不要的了。 JavaScript 實現(xiàn)點擊按鈕復制指定區(qū)域文本 html5 的 webAPI 接口可以很輕松的使用短短的幾行代碼就實現(xiàn)點擊按鈕復制區(qū)域文本的功能,不需要依賴 flash。...

      shinezejian 評論0 收藏0
    • JavaScript文章

      摘要:我對知乎前端相關(guān)問題的十問十答張鑫旭張鑫旭大神對知乎上經(jīng)典的個前端問題的回答。作者對如何避免常見的錯誤,難以發(fā)現(xiàn)的問題,以及性能問題和不好的實踐給出了相應的建議。但并不是本身有問題,被標準定義的是極好的。 這一次,徹底弄懂 JavaScript 執(zhí)行機制 本文的目的就是要保證你徹底弄懂javascript的執(zhí)行機制,如果讀完本文還不懂,可以揍我。 不論你是javascript新手還是老...

      mumumu 評論0 收藏0
    • Record 前端開發(fā)知識整理分享

      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);...

      TZLLOG 評論0 收藏0

    發(fā)表評論

    0條評論

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