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

資訊專欄INFORMATION COLUMN

前端面試題

xiaoqibTn / 3424人閱讀

摘要:前端面試題總結(jié),持續(xù)更新和區(qū)別瀏覽器的緩存機制提供了可以將用戶數(shù)據(jù)存儲在客戶端上的方式,可以利用等跟服務端進行數(shù)據(jù)交互。

前端面試題總結(jié),持續(xù)更新

cookies sessionStorage和localstorage區(qū)別

瀏覽器的緩存機制提供了可以將用戶數(shù)據(jù)存儲在客戶端上的方式,可以利用cookie,session等跟服務端進行數(shù)據(jù)交互。
相同點:都是存儲在客戶端
不同點

WebStorage的優(yōu)點:
(1)存儲空間更大:cookie為4KB,而WebStorage是5MB;
(2)節(jié)省網(wǎng)絡流量:WebStorage不會傳送到服務器,存儲在本地的數(shù)據(jù)可以直接獲取,也不會像cookie一樣美詞請求都會傳送到服務器,所以減少了客戶端和服務器端的交互,節(jié)省了網(wǎng)絡流量;
(3)對于那種只需要在用戶瀏覽一組頁面期間保存而關(guān)閉瀏覽器后就可以丟棄的數(shù)據(jù),sessionStorage會非常方便;
(4)快速顯示:有的數(shù)據(jù)存儲在WebStorage上,再加上瀏覽器本身的緩存。獲取數(shù)據(jù)時可以從本地獲取會比從服務器端獲取快得多,所以速度更快;
(5)安全性:WebStorage不會隨著HTTP header發(fā)送到服務器端,所以安全性相對于cookie來說比較高一些,不會擔心截獲,但是仍然存在偽造問題;
(6)WebStorage提供了一些方法,數(shù)據(jù)操作比cookie方便;

setItem (key, value) ——  保存數(shù)據(jù),以鍵值對的方式儲存信息。
getItem (key) ——  獲取數(shù)據(jù),將鍵值傳入,即可獲取到對應的value值。
removeItem (key) ——  刪除單個數(shù)據(jù),根據(jù)鍵值移除對應的信息。
clear () ——  刪除所有的數(shù)據(jù)
key (index) —— 獲取某個索引的key

數(shù)組去重

    // 新建一新數(shù)組,遍歷傳入數(shù)組,值不在新數(shù)組就push進該新數(shù)組中
    function uniq(arr) {
        var newArr = [];
        for (var i = 0; i < arr.length; i++) {
            if (newArr.indexOf(arr[i]) == -1) {
                newArr.push(arr[i]);
            }
        }
        return newArr;
    }
    var aa = [1, 2, 2, 4, 9, 6, 7, 5, 2, 3, 5, 6, 5];
    console.log(uniq(aa));  // [1, 2, 4, 9, 6, 7, 5, 3];
    

3.ajax步驟

ajax(異步javascript xml) 能夠刷新局部網(wǎng)頁數(shù)據(jù)而不是重新加載整個網(wǎng)頁。
```
//步驟一:創(chuàng)建異步對象
var ajax = new XMLHttpRequest();
//步驟二:設置請求的url參數(shù),參數(shù)一是請求的類型,參數(shù)二是請求的url,可以帶參數(shù),動態(tài)的傳遞參數(shù)starName到服務端
ajax.open("get", "getStar.php?starName=" + name);
//步驟三:發(fā)送請求
ajax.send();
//步驟四:注冊事件 onreadystatechange 狀態(tài)改變就會調(diào)用
ajax.onreadystatechange = function () {
    if (ajax.readyState == 4 && ajax.status == 200) {
        //步驟五 如果能夠進到這個判斷 說明 數(shù)據(jù) 完美的回來了,并且請求的頁面是存在的
        console.log(ajax.responseText);//輸入相應的內(nèi)容
    }
}
```

4.簡單說說xml與json的區(qū)別:

JSON相對于XML來講,數(shù)據(jù)的體積小,傳遞的速度更快些。
JSON與JavaScript的交互更加方便,更容易解析處理,更好的數(shù)據(jù)交互。
XML對數(shù)據(jù)描述性比較好。
JSON的速度要遠遠快于XML

5.js數(shù)據(jù)類型:

五種基本類型---Undefined、Null、Boolean、Number和String。Object、Array和Function則屬于引用類型。

6.http 和 https 有何區(qū)別?
http是HTTP協(xié)議運行在TCP之上。所有傳輸?shù)膬?nèi)容都是明文,客戶端和服務器端都無法驗證對方的身份。
https是HTTP運行在SSL/TLS之上,SSL/TLS運行在TCP之上。所有傳輸?shù)膬?nèi)容都經(jīng)過加密,加密采用對稱加密,但對稱加密的密鑰用服務器方的證書進行了非對稱加密。此外客戶端可以驗證服務器端的身份,如果配置了客戶端驗證,服務器方也可以驗證客戶端的身份

7.bootstrap實現(xiàn)響應式布局原理:百分比布局+媒體查詢

8.請解釋JSONP的工作原理:JSONP (JSON with Padding)是一個簡單高效的跨域方式,HTML中的script標簽可以加載并執(zhí)行其他域的javascript,于是我們可以通過script標記來動態(tài)加載其他域的資源。例如我要從域A的頁面pageA加載域B的數(shù)據(jù),那么在域B的頁面pageB中我以JavaScript的形式聲明pageA需要的數(shù)據(jù),然后在 pageA中用script標簽把pageB加載進來,那么pageB中的腳本就會得以執(zhí)行。JSONP在此基礎上加入了回調(diào)函數(shù),pageB加載完之后會執(zhí)行pageA中定義的函數(shù),所需要的數(shù)據(jù)會以參數(shù)的形式傳遞給該函數(shù)。JSONP易于實現(xiàn),但是也會存在一些安全隱患,如果第三方的腳本隨意地執(zhí)行,那么它就可以篡改頁面內(nèi)容,截獲敏感數(shù)據(jù)。但是在受信任的雙方傳遞數(shù)據(jù),JSONP是非常合適的選擇。

9.談談你對閉包的理解:使用閉包主要是為了設計私有的方法和變量。閉包的優(yōu)點是可以避免全局變量污染,缺點是閉包會常駐內(nèi)存,會增大內(nèi)存使用量,使用不當很容易造成內(nèi)存泄露。閉包有三個特性,第一 函數(shù)嵌套函數(shù),第二 函數(shù)內(nèi)部可以使用外部的參數(shù)和變量,第三 參數(shù)和變量不會被垃圾回收機制回收

10.get請求與post請求區(qū)別:

get:
get是從服務器上獲取數(shù)據(jù),post是向服務器傳送數(shù)據(jù);
get傳送的數(shù)據(jù)量較小,不能大于2KB。post傳送的數(shù)據(jù)量較大,一般被默認為不受限制。但理論上,IIS4中最大量為80KB,IIS5中為100KB;
get安全性非常低,post安全性較高。但是執(zhí)行效率卻比Post方法好;
get是把參數(shù)數(shù)據(jù)隊列加到提交表單的ACTION屬性所指的URL中,值和表單內(nèi)各個字段一一對應,在URL中可以看到;
在做數(shù)據(jù)查詢時,建議用Get方式;

post:
    post是通過HTTP post機制,將表單內(nèi)各個字段與其內(nèi)容放置在HTML HEADER內(nèi)一起傳送到ACTION屬性所指的URL地址,用戶看不到這個過程;
    所以:包含機密信息的話,建議用Post數(shù)據(jù)提交方式;而在做數(shù)據(jù)添加、修改或刪除時,建議用Post方式。
    


第二更
11.什么情況下會碰到跨域問題,有哪些解決方法?

跨域問題是瀏覽器為了實施的同源策略導致的,同源策略限制了來自不同源的document,腳本。同源意思就是兩個url的域名、協(xié)議、端口要完全相同。解決方法:script標簽jsonp跨域、nginx反向代理、node.js中間件代理跨域、后端在頭部信息設置安全域名、后端在服務器上設置cors。
// jsonp原理:動態(tài)引入script標簽,通過script標簽引入一個js,這個js文件載入后會執(zhí)行我們在url參數(shù)中指定的參數(shù),并且把我們需要的json數(shù)據(jù)作為參數(shù)傳入
 functioncreateJs(sUrl){
    var oScript =document.createElement("script");
    oScript.type = "text/javascript";
    oScript.src= sUrl;
    document.getElementsByTagName("head")[0].appendChild(oScript);
}

12.如何對一個數(shù)組去重?

// 方法一:es6中Set+Array.from方法,目前主流的瀏覽器,Chrome,Firfox,Opera,Safari,包括微軟的Edge,都是支持的,唯獨IE系列不支持
var arr = ["1", "2", "3", 1, NaN, NaN, undefined, undefined, null, null, "a", "b", "b"];
console.log(new Set(arr));  // Set(9)?{"1", "2", "3", 1, NaN, undefined, null, "a", "b"]
// 這里看到返回的是一個對象,通過Array.from方法轉(zhuǎn)為數(shù)組
var newArr = Array.from(new Set(arr));
console.log(newArr)  // [1, 3, 9, null, "1"]

// 方法二:遍歷,將值添加到新數(shù)組,用indexOf()判斷值是否存在,已存在就不添加,達到去重效果。
//ps:這個方法不能分辨NaN,會出現(xiàn)兩個NaN。
var arr = ["1", "2", "3", 1, NaN, NaN, undefined, undefined, null, null, "a", "b", "b"];
var unique = arr => {
    let newA = [];
    arr.forEach(item=> {
        if(newA.indexOf(item)==-1) {
            newA.push(item)
        }
    })
    return newA;
}
console.log(unique(arr))  // ["1", "2", "3", 1, NaN, NaN, undefined, null, "a", "b"]

// 方法三:將數(shù)組的值添加只一個對象的屬性名里,并且給屬性賦值,對象不能添加相同的屬性名,以這個為依據(jù)可以實現(xiàn)去重,然后用objec.keys(obj),返回改對象可枚舉屬性組成的數(shù)組,即去重后的數(shù)組。
var arr = ["1", "2", "3", 1, NaN, NaN, undefined, undefined, null, null, "a", "b", "b"];
var unique = arr => {
    var obj = {};
    arr.forEach(item => {
        obj[item] = 0;
    })
    return Object.keys(obj);
}
console.log(unique(arr))  // ["1", "2", "3", "NaN", "undefined", "null", "a", "b"]

13.翻轉(zhuǎn)一個字符串:

let a = "99151512";
console.log([...a]) // ["9", "9", "1", "5", "1", "5", "1", "2"]  字符串的解構(gòu)賦值
let b = [...a].reverse().join("")
console.log(b) // 21515199

第三更(vue篇)

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

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

相關(guān)文章

  • 你不能錯過的前端面試合集

    摘要:收集的一些前端面試題從面試題發(fā)現(xiàn)不足,進而查漏補缺,比通過面試更難得及各大互聯(lián)網(wǎng)公司前端筆試面試題篇及各大互聯(lián)網(wǎng)公司前端筆試面試題篇面試題個和個經(jīng)典面試題前端開發(fā)面試題如何面試前端工程師很重要個變態(tài)題解析如何通過餓了么面試輕 收集的一些前端面試題 從面試題發(fā)現(xiàn)不足,進而查漏補缺,比通過面試更難得 1 BAT及各大互聯(lián)網(wǎng)公司2014前端筆試面試題--Html,Css篇 2 BAT...

    ninefive 評論0 收藏0
  • 你不能錯過的前端面試合集

    摘要:收集的一些前端面試題從面試題發(fā)現(xiàn)不足,進而查漏補缺,比通過面試更難得及各大互聯(lián)網(wǎng)公司前端筆試面試題篇及各大互聯(lián)網(wǎng)公司前端筆試面試題篇面試題個和個經(jīng)典面試題前端開發(fā)面試題如何面試前端工程師很重要個變態(tài)題解析如何通過餓了么面試輕 收集的一些前端面試題 從面試題發(fā)現(xiàn)不足,進而查漏補缺,比通過面試更難得 1 BAT及各大互聯(lián)網(wǎng)公司2014前端筆試面試題--Html,Css篇 2 BAT...

    darkbaby123 評論0 收藏0
  • 前端開發(fā)面試鏈接

    摘要:手冊網(wǎng)超級有用的前端基礎技術(shù)面試問題收集前端面試題目及答案匯總史上最全前端面試題含答案常見前端面試題及答案經(jīng)典面試題及答案精選總結(jié)前端面試過程中最容易出現(xiàn)的問題前端面試題整理騰訊前端面試經(jīng)驗前端基礎面試題部分最新前端面試題攻略前端面試前端入 手冊網(wǎng):http://www.shouce.ren/post/index 超級有用的前端基礎技術(shù)面試問題收集:http://www.codec...

    h9911 評論0 收藏0
  • 前端開發(fā)面試鏈接

    摘要:手冊網(wǎng)超級有用的前端基礎技術(shù)面試問題收集前端面試題目及答案匯總史上最全前端面試題含答案常見前端面試題及答案經(jīng)典面試題及答案精選總結(jié)前端面試過程中最容易出現(xiàn)的問題前端面試題整理騰訊前端面試經(jīng)驗前端基礎面試題部分最新前端面試題攻略前端面試前端入 手冊網(wǎng):http://www.shouce.ren/post/index 超級有用的前端基礎技術(shù)面試問題收集:http://www.codec...

    snifes 評論0 收藏0
  • 前端最強面經(jīng)匯總

    摘要:獲取的對象范圍方法獲取的是最終應用在元素上的所有屬性對象即使沒有代碼,也會把默認的祖宗八代都顯示出來而只能獲取元素屬性中的樣式。因此對于一個光禿禿的元素,方法返回對象中屬性值如果有就是據(jù)我測試不同環(huán)境結(jié)果可能有差異而就是。 花了很長時間整理的前端面試資源,喜歡請大家不要吝嗇star~ 別只收藏,點個贊,點個star再走哈~ 持續(xù)更新中……,可以關(guān)注下github 項目地址 https:...

    wangjuntytl 評論0 收藏0
  • 20W字囊括上百個前端面試的項目開源了

    摘要:字囊括上百個前端面試題的項目開源了這個項目是什么項目內(nèi)容這個項目目前在上剛剛開源主要內(nèi)容如下前端面試題主要整理了高頻且有一定難度的前端面試題對這些面試題進行解讀前端原理詳解針對一些有一定難度面試題涉及的知識點進行詳解比如涉及的編譯原理響應式 20W字囊括上百個前端面試題的項目開源了 這個項目是什么? 項目內(nèi)容 這個項目目前在GitHub上剛剛開源,主要內(nèi)容如下: 前端面試題: 主要整...

    Euphoria 評論0 收藏0

發(fā)表評論

0條評論

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