vue面試筆記

vue面試筆記

雙向數(shù)據(jù)綁定 Object.defineProperty()+發(fā)布訂閱模式

  • vue通過Object.defineProperty()來劫持各個(gè)屬性得getter和setter,在數(shù)據(jù)變動(dòng)時(shí)發(fā)布消息給訂閱者嗽元,觸發(fā)相應(yīng)回調(diào)翩迈。當(dāng)在vue實(shí)例得data中定義或者觸發(fā)吐葱,vue會(huì)遍歷它的屬性残吩,并通過Object.defineProperty()將他們轉(zhuǎn)為getter/setter癣亚。用戶雖然看不到getter/setter颤霎,在內(nèi)部他們讓vue追蹤依賴蛤虐,在屬性被訪問或被修改時(shí)通知變化
  • vue的數(shù)據(jù)雙向綁定將MVVM作為數(shù)據(jù)綁定的入口党饮,整合Observer,Compile和Watcher三者驳庭,通過Observer來監(jiān)聽自己的model數(shù)據(jù)變化刑顺,通過Compile來解析編譯模板指令(vue中用來解析{{}}這個(gè)的),最終利用Watcher搭起observer和compile之間的通信橋梁饲常,達(dá)到數(shù)據(jù)變化->視圖更新蹲堂;視圖交互變化(input)->數(shù)據(jù)model變更
    body:
        div id='app'
            input id=txt
            p id=show
        /div
    /body
    script
        Object.defineProperty(obj,'txt', {
            get: function() {
                return obj
            },
            set: function(newValue) {
                document.getElementById('txt').value = newValue
                document.getElementById('show').innerHTML = newValue
            }
        })
        document.addEventListener('keyup', function(e) {
            obj.txt = e.target.value
        })

vue組件傳值

  • 父向子傳值 子組件通過props方法接受數(shù)據(jù)
  • 子向父傳值 $emit
  • 兄弟間傳值 eventBus 新建一個(gè)vue實(shí)例作為中轉(zhuǎn)站,(項(xiàng)目比較斜从佟)
  • vuex管理
    • store mutations/actions commit

vue路由實(shí)現(xiàn):hash模式 和 history模式

  • hash模式:在瀏覽器中符號(hào)'#',#以及#后面的字符稱之為hash柒竞,用window.location.hash讀取播聪;
  • hash雖然在URL中朽基,但不被包括在http請(qǐng)求中布隔,對(duì)服務(wù)端無用,hash不會(huì)重載頁面稼虎,后端無需對(duì)路由全覆蓋衅檀,也不會(huì)返回404
  • history模式:history采用H5新特效;它提供兩個(gè)方法:pushState(),replaceState()可以對(duì)瀏覽器歷史記錄棧進(jìn)行修改霎俩,以及popState事件可以監(jiān)聽到狀態(tài)變更哀军。
  • history模式下,前端的URL必須和實(shí)際向后端發(fā)起請(qǐng)求的URL一致茸苇,如果后端缺少對(duì)/xxx/xxx的路由處理排苍,將放回404沦寂。此時(shí)后端需要對(duì)全路由實(shí)現(xiàn)覆蓋学密,如果URL匹配不到任何靜態(tài)資源,應(yīng)該返回一個(gè)頁面

vue單頁面

  • vue的目標(biāo)通過盡可能簡單的API實(shí)現(xiàn)響應(yīng)的數(shù)據(jù)綁定和組合的視圖組件传藏,核心是一個(gè)響應(yīng)的數(shù)據(jù)綁定系統(tǒng)腻暮。
  • MVVM、數(shù)據(jù)驅(qū)動(dòng)毯侦、組件化哭靖、輕量、簡潔侈离、模塊友好试幽。最低只支持到IE9、不利于SEO(可通過服務(wù)端進(jìn)行渲染組件)卦碾;首屏加載較慢铺坞,不可以通過瀏覽器實(shí)現(xiàn)后退前進(jìn)功能

計(jì)算屬性computed

  • 在模板中放入太多的邏輯會(huì)讓模板過重且難以維護(hù),在需要對(duì)數(shù)據(jù)進(jìn)行復(fù)雜處理洲胖,且可能多此使用的情況下d济榨,盡量使用computed。
    • 數(shù)據(jù)處理結(jié)構(gòu)清晰
    • 依賴于數(shù)據(jù)绿映,數(shù)據(jù)更新擒滑,處理結(jié)果自動(dòng)更新
    • 計(jì)算屬性內(nèi)部this指向vm實(shí)例
    • 在template調(diào)用時(shí),直接寫計(jì)算屬性名即可
    • 常用getter方法獲取數(shù)據(jù)叉弦,setter方法設(shè)置數(shù)據(jù)
    • 不管依賴的數(shù)據(jù)是否發(fā)生改變丐一,methods都會(huì)重新計(jì)算,當(dāng)依賴的數(shù)據(jù)不變的時(shí)候淹冰,computed會(huì)從緩存中獲取數(shù)據(jù)而不是重新計(jì)算
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末钝诚,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子榄棵,更是在濱河造成了極大的恐慌凝颇,老刑警劉巖潘拱,帶你破解...
    沈念sama閱讀 218,941評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異拧略,居然都是意外死亡芦岂,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門垫蛆,熙熙樓的掌柜王于貴愁眉苦臉地迎上來禽最,“玉大人,你說我怎么就攤上這事袱饭〈ㄎ蓿” “怎么了?”我有些...
    開封第一講書人閱讀 165,345評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵虑乖,是天一觀的道長懦趋。 經(jīng)常有香客問我,道長疹味,這世上最難降的妖魔是什么仅叫? 我笑而不...
    開封第一講書人閱讀 58,851評(píng)論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮糙捺,結(jié)果婚禮上诫咱,老公的妹妹穿的比我還像新娘。我一直安慰自己洪灯,他們只是感情好坎缭,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著签钩,像睡著了一般掏呼。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上边臼,一...
    開封第一講書人閱讀 51,688評(píng)論 1 305
  • 那天哄尔,我揣著相機(jī)與錄音,去河邊找鬼柠并。 笑死岭接,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的臼予。 我是一名探鬼主播鸣戴,決...
    沈念sama閱讀 40,414評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼粘拾!你這毒婦竟也來了窄锅?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,319評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤缰雇,失蹤者是張志新(化名)和其女友劉穎入偷,沒想到半個(gè)月后追驴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡疏之,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年殿雪,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片锋爪。...
    茶點(diǎn)故事閱讀 40,096評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡丙曙,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出其骄,到底是詐尸還是另有隱情亏镰,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評(píng)論 5 346
  • 正文 年R本政府宣布拯爽,位于F島的核電站索抓,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏某抓。R本人自食惡果不足惜纸兔,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評(píng)論 3 331
  • 文/蒙蒙 一惰瓜、第九天 我趴在偏房一處隱蔽的房頂上張望否副。 院中可真熱鬧,春花似錦崎坊、人聲如沸备禀。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽曲尸。三九已至,卻和暖如春男翰,著一層夾襖步出監(jiān)牢的瞬間另患,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評(píng)論 1 271
  • 我被黑心中介騙來泰國打工蛾绎, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留昆箕,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,308評(píng)論 3 372
  • 正文 我出身青樓租冠,卻偏偏與公主長得像鹏倘,于是被迫代替她去往敵國和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子顽爹,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 主要還是自己看的纤泵,所有內(nèi)容來自官方文檔。 介紹 Vue.js 是什么 Vue (讀音 /vju?/镜粤,類似于 vie...
    Leonzai閱讀 3,353評(píng)論 0 25
  • Vue 實(shí)例 屬性和方法 每個(gè) Vue 實(shí)例都會(huì)代理其 data 對(duì)象里所有的屬性:var data = { a:...
    云之外閱讀 2,214評(píng)論 0 6
  • VUE介紹 Vue的特點(diǎn)構(gòu)建用戶界面捏题,只關(guān)注View層簡單易學(xué)玻褪,簡潔、輕量公荧、快速漸進(jìn)式框架 框架VS庫庫归园,是一封裝...
    多多醬_DuoDuo_閱讀 2,712評(píng)論 1 17
  • 一. Vue核心小知識(shí)點(diǎn) 1、vue中 key 值的作用 key 的特殊屬性主要用在 Vue的虛擬DOM算法稚矿,在新...
    倚劍闖天涯_閱讀 1,751評(píng)論 0 12
  • 項(xiàng)目地址 learn-zhihu 本項(xiàng)目是知乎日?qǐng)?bào)的學(xué)習(xí)筆記庸诱,原項(xiàng)目可以點(diǎn)擊這里查看 Build Setup Fo...
    tuionf閱讀 946評(píng)論 0 0