摘要:對于,其默認大小一般是本地存儲和都保存在瀏覽器端,且都是同源的。把變量放在閉包中和放在全局作用域,對內(nèi)存的影響是一致的,這里并不能說成是內(nèi)存泄露。將新的樹和之前的虛擬樹進行相比較,根據(jù)結果對進行精準響應。
1. JavaScript 1. JavaScript文件在什么情況下會放在html哪個位置
https://zhuanlan.zhihu.com/p/...
對于必須要在DOM加載之前運行的JavaScript腳本,我們需要把這些腳本放置在頁面的head中,而不是通過外部引用的方式,因為外部的引用方式增加了網(wǎng)絡的請求次數(shù);
2. async和defer區(qū)別async表示異步加載JavaScript文件,它的下載過程可以在HTML的解析過程中運行,加載完成之后立即執(zhí)行這個文件的代碼,執(zhí)行文件代碼的過程中會阻塞HTML的解析,它不保證文件加載的順序。
defer表示在HTML文檔解析之后再執(zhí)行加載完成JavaScript文件,JavaScript文件的下載過程可以在HTML的解析過程中進行,它是按照script標簽的先后順序來加載文件的。
map返回一個新數(shù)組
forEach遍歷數(shù)組,返回值為undefined
reduce累加器,遍歷時避開創(chuàng)建新數(shù)組減少冗(rong)余,返回值由參數(shù)callback決定
session會在一定時間內(nèi)保存在服務器上。當訪問增多時,會占用服務器的資源,所以考慮服務器性能方面,可以使用cookie
cookie存儲容量有限制,單個cookie保存數(shù)據(jù)不能超過4k,且很多瀏覽器限制一個站點最多保存20個cookie。對于seesion,其默認大小一般是1024k
localStorage本地存儲和cookie都保存在瀏覽器端,且都是同源的。每個域5MB
apply
接受2個參數(shù):一個是在其中運行的函數(shù)作用域(Scope),另一個可以是arguments也可以是Array的實例,經(jīng)典案例:#獲取數(shù)組中最大的值#;#使用push合并數(shù)組#;
call
和apply用法相同,只是除了第一個都是作用域之外,其余參數(shù)必須逐個列舉出來。經(jīng)典用例:#使用call調(diào)用匿名函數(shù)#
bind
接受1個參數(shù),返回一個新函數(shù),這個新函數(shù)的this值來自bind(context)函數(shù)傳遞的context
Function.prototype.bind = function(context){ var self = this; //原函數(shù) return function(){ //返回一個新函數(shù) return self.apply(context, arguments) } }6. 事件綁定有哪幾種,分別在什么情況下使用 7. 請解釋一下事件委托或事件代理 8. 異步編程有哪些 9. 異步編程中如何捕獲異常 10. 數(shù)組去重你會怎么寫
https://segmentfault.com/a/11...
思路一:
1.雙層循環(huán),外層循環(huán)元素,內(nèi)存循環(huán)時比較值
2.如果有相同的值則跳過(break),不相同則push近數(shù)組
思路二:利用splice直接在原數(shù)組進行操作(刪除元素時,需要更新數(shù)組長度)
思路三:利用對象的屬性不能相同的特點進行去重
思路四:數(shù)組遞歸去重
1.運用遞歸的思想
2.先排序,然后從最后開始比較,遇到相同,則刪除
思路五:利用indexOf以及forEach
思路六:利用indexOf以及sort
思路七:利用ES6的set
當在函數(shù)內(nèi)搜索一個變量時,如果函數(shù)內(nèi)沒有這個變量,那么此次搜索過程會隨著代碼執(zhí)行環(huán)境創(chuàng)建的作用域鏈往外逐層搜索
2.變量的生存周期全局變量的生存周期是永久的
對于函數(shù)內(nèi)var聲明的局部變量,當退出函數(shù)時,這些局部變量會隨著函數(shù)調(diào)用結束而被摧毀
局部變量所在的執(zhí)行環(huán)境還能被外界訪問,那么這個局部變量就有了不被摧毀的理由
4.閉包與內(nèi)存管理使用閉包的動機:主動將一些變量封裝在閉包中,以便未來還需要使用到它們。
把變量放在閉包中和放在全局作用域,對內(nèi)存的影響是一致的,這里并不能說成是內(nèi)存泄露。如果將來需要回收這些變量,我們可以手動把這些變量設為null
包裝函數(shù)嵌套太深,且被不推薦使用mixins模式
2.huge component組件太大,學習成本太高,高度集中化無法將細化功能抽離出來
3.confusing classes有時候不知道使用classes還是function創(chuàng)建函數(shù)
有時在lifecycle內(nèi)注冊完事件后,又需要在摧毀階段手動注銷事件
注冊監(jiān)聽事件后,又需要在組件變化時手動發(fā)布事件
let string = ""; Boolean(string) //false function return (1. redux和mobx區(qū)別{string&& //會報錯 )前面的不會進行bool類型轉換 }
具體參考:https://www.robinwieruch.de/r...
Redux受函數(shù)式編程影響,它總是返回一個新狀態(tài),而不是改變狀態(tài)。
//不要在Redux這樣做,因為這樣會改變數(shù)組 function addAuthor(state, action) { return state.authors.push(action.author) } //保持不變,總是返回一個新對象 function addAuthor(state, action) { return [...state.authors, action.author] }
state數(shù)據(jù)遵照標準化數(shù)據(jù)格式,可以保持state數(shù)據(jù)扁平化(flat state)和單一(身份)信息源(single source of truth) 。
{ post: { id: "a", authorId: "b", ... }, author: { id: "b", postIds: ["a", ...], ... } }
Mobx既有面向對象編程,也有反應式編程。它將你的state包裹在可觀察(Observable)的狀態(tài)中。因此,你可以在state中獲得所有可觀察的功能。
在Mobx里state是可變。因此可以直接改變state:
function addAuthor(author){ this.authors.push(author) }
數(shù)據(jù)結構state可以保持深層嵌套
在Redux中,狀態(tài)是只讀的,只能使用顯示操作actions來更改狀態(tài)。相反,在Mobx中,狀態(tài)允許讀寫,可以直接改變狀態(tài)without actions2. redux的缺點
https://stackoverflow.com/que...
例如:
//state內(nèi)的list引用redux中的list this.state={ list:this.props.list||[] } //component內(nèi)修改list值 this.setState({list:[1,2,3]}) //此時redux中的list也被改變,只是沒有將變化傳遞到action console.log(this.props.list) //[1,2,3]
redux的核心概念之一是 #state是不可變的#;使用Object.assign()合并對象無法實現(xiàn)深拷貝
3. mobx的缺點https://stackoverflow.com/que...
無法知道數(shù)據(jù)是在什么時候改變(或update)的,并且很難跟蹤(參照redux-logger和mobx-logger)
4. setState為什么是異步的why is setState asynchronous?
回答這個問題首先要闡述:調(diào)用setState時會發(fā)生什么?
調(diào)用setState時,React會將setState()的對象以“和解”(reconciliation)的過程合并到組件的當前狀態(tài)()并以此創(chuàng)建一個新的React元素樹(我理解為虛擬DOM樹)。
將新的DOM樹和setState之前的虛擬DOM樹進行相比較(diff),根據(jù)結果對UI進行精準響應。
因此個人理解為:對比過程需要消耗一定時間,為了防止阻塞所以將setState設置為異步
另一篇文章:從 setState promise 化的探討 體會 React 團隊設計思想
5. Virtual DOM (diff)算法https://github.com/livoras/bl...
算法實現(xiàn)
步驟一:用JS對象模擬DOM樹
步驟二:比較兩棵虛擬DOM樹的差異
這兩個樹的完全diff算法是一個時間復雜度O(n^3)的問題,但是在前端當中,很少會跨越層級地移動DOM元素。所以Virtual DOM只會對同一個層級的元素進行對比:
1.深度優(yōu)先遍歷,記錄差異
2.可能會有的差異類型
2.1 替換掉原來的節(jié)點
2.2 移動、刪除、新增子節(jié)點
2.3 修改節(jié)點的屬性
2.4 文本節(jié)點被改變
var REPLACE = 0 var REORDER = 1 var PROPS = 2 var TEXT = 3
3.列表對比算法
關鍵算法:#字符串的最小編輯距離#(Edition Distance); #Levenshtein Distance#; O(M * N)
步驟三:把差異應用到真正的DOM樹上
?
7. 在react中如何使用jQuery???
8. 在xx版本之后更新了哪些https://reactjs.org/versions/
收到這個問題前我還從來沒關心過每次發(fā)布新版本更新了哪些,這個問題讓我成長很多。
9. react做過哪些性能優(yōu)化 10. React Native手機端適配function scaleSize(size) { let screenW = Dimensions.get("window").width>Dimensions.get("window").height?Dimensions.get("window").height:Dimensions.get("window").width; const defaultWidth =375; // 在UI圖上的基礎寬度 const _scaleWidth = screenW / defaultWidth; return size * _scaleWidth; }4. vue 1. vue雙向綁定原理
https://www.jianshu.com/p/e42...
基本原理:
1.利用Object.defineProperty監(jiān)聽對象賦值動作
2.遍歷所有節(jié)點
3.使用觀察者模式對擁有v-model屬性的DOM節(jié)點訂閱上述時間
4.對擁有v-bind屬性的DOM節(jié)點進行發(fā)布事件
5.對表單標簽使用`addEventListener("input",function(e){/.../})監(jiān)聽事件
Object.defineProperty(vModelList, key, { enumerable: true, configurable: true, set: function (newVal) { // 發(fā)布 _observer.trigger(key, newVal) } });2. 正則貪婪匹配實現(xiàn)數(shù)據(jù)綁定(模板字符串)
https://segmentfault.com/a/11...
String.prototype.render = function(context){ return this.replace(/{{([^}]+)}}/g, (match, key) => (context[key]||match)); } "你好,{{name}},我們會在{{day}}天之內(nèi)通知面試結果。".render({name:"Niko",day:3})5. http 1. 什么是jsonp
https://www.zhihu.com/questio...
很簡單,就是利用 并提供一個回調(diào)函數(shù)來接收數(shù)據(jù)(函數(shù)名可約定,或通過地址參數(shù)傳遞)。 第三方產(chǎn)生的響應為json數(shù)據(jù)的包裝(故稱之為jsonp,即json padding),形如: callback({"name":"hax","gender":"Male"}) 這樣瀏覽器會調(diào)用callback函數(shù),并傳遞解析后json對象作為參數(shù)。本站腳本可在callback函數(shù)里處理所傳入的數(shù)據(jù)。 補充:“歷史遺跡”的意思就是,如果在今天重新設計的話,也許就不會允許這樣簡單的跨域了嘿,比如可能像XHR一樣按照CORS規(guī)范要求服務器發(fā)送特定的http頭。
從輸入URL到頁面加載發(fā)生了什么https://segmentfault.com/a/11...
1.DNS解析
2.TCP連接
3.發(fā)生HTTP請求
4.服務器處理請求并返回HTTP報文
5.瀏覽器解析渲染頁面
6.連接結束
禁止使用flexflex彈性布局
請使用flex完成
文章版權歸作者所有,未經(jīng)允許請勿轉載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/99063.html
摘要:對于,其默認大小一般是本地存儲和都保存在瀏覽器端,且都是同源的。把變量放在閉包中和放在全局作用域,對內(nèi)存的影響是一致的,這里并不能說成是內(nèi)存泄露。將新的樹和之前的虛擬樹進行相比較,根據(jù)結果對進行精準響應。 1. JavaScript 1. JavaScript文件在什么情況下會放在html哪個位置 https://zhuanlan.zhihu.com/p/... 對于必須要在DOM加載...
摘要:接下來,我會檢查每個頁面以確保它使用有用的標簽,包括標題標簽。這個問題讓面試官有機會了解潛在員工對工作難以勝任的部分。面試官可能需要考慮這種弱點對團隊的影響。面試官可能會發(fā)現(xiàn)自己公司的計劃與未來員工的職業(yè)目標是否保持一致。 翻譯:瘋狂的技術宅原文:https://www.indeed.com/hire/i... 本文首發(fā)微信公眾號:jingchengyideng歡迎關注,每天都給你...
閱讀 942·2021-09-07 09:58
閱讀 1491·2021-09-07 09:58
閱讀 2885·2021-09-04 16:40
閱讀 2506·2019-08-30 15:55
閱讀 2414·2019-08-30 15:54
閱讀 1371·2019-08-30 15:52
閱讀 434·2019-08-30 10:49
閱讀 2607·2019-08-29 13:21