摘要:采用了新舊的對比,獲取差異的,最后一次性的更新到真實上。對基本屬性進行監(jiān)聽對對象進行監(jiān)聽對對象某一個屬性監(jiān)聽監(jiān)聽自定義指令全局指令,第一個參數(shù)是指令名,第二個參數(shù)是一個對象,對象內(nèi)部有個的函數(shù),函數(shù)里有這個參數(shù),表示綁定了這個指令的元素。
11.vue 虛擬DOM的理解
Web界面由DOM樹(樹的意思是數(shù)據(jù)結(jié)構(gòu))來構(gòu)建,當其中一部分發(fā)生變化時,其實就是對應某個DOM節(jié)點發(fā)生了變化,???????? 虛擬DOM就是為了解決瀏覽器性能問題而被設計出來的。如前,若一次操作中有10次更新DOM的動作,虛擬DOM不會立即操作DOM,而是將這10次更新的diff內(nèi)容保存到本地一個JS對象中,最終將這個JS對象一次性attch到DOM樹上,再進行后續(xù)操作,避免大量無謂的計算量。所以,用JS對象模擬DOM節(jié)點的好處是,頁面的更新可以先全部反映在JS對象(虛擬DOM)上,操作內(nèi)存中的JS對象的速度顯然要更快,等更新完成后,再將最終的JS對象映射成真實的DOM,交由瀏覽器去繪制。 采用了新舊DOM的對比,獲取差異的DOM,最后一次性的更新到真實DOM上。
12.動態(tài)組件
有時候在不同組件之間進行動態(tài)切換是非常有用的,比如在一個多標簽的界面里,可以將多個子組件都掛載在同一個位置,通過變量來切換組件,實現(xiàn)tab菜單這樣的效果。 可以通過Vue的元素加一個特殊的is特性來實現(xiàn) 在示例中,currentTabComponent 可以包括 已注冊組件的名字,或 一個組件的選項對象
13.vue的kepp-alive
是vue的一個內(nèi)置組件,可以使被包含的組件保留狀態(tài),避免重新渲染。 包含動態(tài)組件是,會緩存不活動的組件實例,而不是銷毀他們, keep-alive是一個抽象組件,它自身不會渲染一個DOM元素,也不會出現(xiàn)在父組件鏈中, 當組件在內(nèi)被切換,它的 activated 和 deactivated 這兩個生命周期鉤子函數(shù)將會被對應執(zhí)行。 include:字符串或正則表達式,只有名稱匹配的組件會被緩存 exclude:字符串或正則表達式,名稱匹配的不會被緩存 max:數(shù)字,最多可緩存多少實例 1)搭配動態(tài)組件使用 將會緩存is成立時匹配到的zu"jian 2)include 將會緩存name名為a、b的組件 3)exclude 將會緩存name名為**非**a、b的組件 4)使用$route.meta的keepAlive屬性 將會緩存滿足if條件的組件
14.watch和計算屬性
計算屬性: *用于簡單場合,比如計算,合并字符串等; *計算屬性會依賴于他使用的data中的屬性,只要是依賴的屬性值有改變,則自動重新調(diào)用一下計算屬性; *如果他所依賴的這些屬性值沒有發(fā)生改變,那么計算屬性的值是從緩存中來的,而不是重新編譯,那么性能要高一些,所以vue中盡可能使用computed替代watch。 1)計算屬性基于依賴進行緩存。 watch屬性: *用于耗時的,可以異步的獲取遠程服務上的數(shù)據(jù)這樣的操作。
1)對基本屬性進行監(jiān)聽 watch: { str: function (newValue, oldValue) {} }
2)對對象進行監(jiān)聽watch: {obj: {handle: (){}, deep: true}
3)對對象某一個屬性監(jiān)聽 watch : { "obj.prop": {} }
4)route監(jiān)聽watch: { "$route": function(){} }
15.自定義指令
全局指令:Vue.directive() Vue.directive("foucs",{ inserted(el){ } }), 第一個參數(shù)foucs是指令名,第二個參數(shù)是一個對象,對象內(nèi)部有個inserted的函數(shù),函數(shù)里有el這個參數(shù),el表示綁定了這個指令的dom元素。 Vue.directive("gqs",{ bind() { // 當指令綁定到 HTML 元素上時觸發(fā).**只調(diào)用一次** console.log("bind triggerd") }, inserted() { // 當綁定了指令的這個HTML元素插入到父元素上時觸發(fā)(在這里父元素是 `div#app`)**.但不保證,父元素已經(jīng)插入了 DOM 文檔.** console.log("inserted triggerd") }, updated() { // 所在組件的`VNode`更新時調(diào)用. console.log("updated triggerd") }, componentUpdated() { // 指令所在組件的 VNode 及其子 VNode 全部更新后調(diào)用。 console.log("componentUpdated triggerd") }, unbind() { // 只調(diào)用一次,指令與元素解綁時調(diào)用. console.log("unbind triggerd") }
})
16.組件之間的通信
1)父組件-->子組件 父向子傳遞數(shù)據(jù)通過props,通過設置標簽的屬性傳遞數(shù)據(jù),在子組件用props接受。 **父組件代碼**//在子組件上v-bind:title-text綁定一個showTitleTxt **子組件代碼** {{thisTitleTxt}} 2)子組件-->父組件 **在子組件中創(chuàng)建一個按鈕,給按鈕綁定一個點擊事件,在該事件的的函數(shù)中使用$emit來觸發(fā)一個自定義事件,并傳遞一個參數(shù)。 methods:{ sendMsg:function(){ this.$emit("listenToChild","傳遞的數(shù)據(jù)"); } } **在父組件引入子組件的標簽內(nèi)監(jiān)聽該自定義事件,并添加一個處理該事件的方法。methods:{ showMsg:function(msg){ console.log(msg);//傳遞來的數(shù)據(jù) } } 3)非父子組件通信(中央事件總線eventBus) 全局注冊,在main.js let EventBus = new Vue(); Vue.prototype.bus=bus; 局部使用 新建EventBus.js import Vue from "vue" export const EventBus = new Vue() 在需要的組件中引用 import EventBus from "../EventBus.js"; 注冊之后,在firstChild組件中,import引入js,接著在firstChild組件添加按鈕并綁定一個點擊事件 methods:{ sendMsg:function(){ EventBus.$emit("userEvent","轉(zhuǎn)遞的數(shù)據(jù)") } } 在secondChild組件中,引入時間總線 mounted(){ EventBus.$on("userEvent",function(msg){ console.log(msg);//傳遞過來的數(shù)據(jù) }); }
17.過濾器
18.vue-loader的作用
太深入的還沒用到,只是簡單的了解過。 vue-loader:解析和轉(zhuǎn)換.vue文件,提取出其中的邏輯代碼,script、style、template,再分別把他們交給對應的loader去處理。 css-loader:加載由vue-loader提取出來的style代碼。 vue-template-compiler:把vue-loader提取出來的HTML模板編譯成對應的可執(zhí)行的script代碼。 vue-loader的作用就是提取。
19.vue組件中data為什么必須是函數(shù)?
在nue Vue()中data是可以作為一個對象進行操作的,然而在component中,data只能用函數(shù)的方式存在,不能直接讓對象賦值給他。 當data是一個函數(shù)時,每個實例可以維護一份被返回對象的獨立的拷貝,這樣各個實例中的data就不會相互影響,是獨立的。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/105324.html
摘要:特意對前端學習資源做一個匯總,方便自己學習查閱參考,和好友們共同進步。 特意對前端學習資源做一個匯總,方便自己學習查閱參考,和好友們共同進步。 本以為自己收藏的站點多,可以很快搞定,沒想到一入?yún)R總深似海。還有很多不足&遺漏的地方,歡迎補充。有錯誤的地方,還請斧正... 托管: welcome to git,歡迎交流,感謝star 有好友反應和斧正,會及時更新,平時業(yè)務工作時也會不定期更...
摘要:獲取的對象范圍方法獲取的是最終應用在元素上的所有屬性對象即使沒有代碼,也會把默認的祖宗八代都顯示出來而只能獲取元素屬性中的樣式。因此對于一個光禿禿的元素,方法返回對象中屬性值如果有就是據(jù)我測試不同環(huán)境結(jié)果可能有差異而就是。 花了很長時間整理的前端面試資源,喜歡請大家不要吝嗇star~ 別只收藏,點個贊,點個star再走哈~ 持續(xù)更新中……,可以關注下github 項目地址 https:...
摘要:收集的一些前端面試題從面試題發(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...
摘要:收集的一些前端面試題從面試題發(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...
摘要:平日學習接觸過的網(wǎng)站積累,以每月的形式發(fā)布。年以前看這個網(wǎng)址概況在線地址前端開發(fā)群月報提交原則技術(shù)文章新的為主。 平日學習接觸過的網(wǎng)站積累,以每月的形式發(fā)布。2017年以前看這個網(wǎng)址:http://www.kancloud.cn/jsfron... 概況 在線地址:http://www.kancloud.cn/jsfront/month/82796 JS前端開發(fā)群月報 提交原則: 技...
閱讀 2173·2023-04-25 20:45
閱讀 1087·2021-09-22 15:13
閱讀 3655·2021-09-04 16:48
閱讀 2589·2019-08-30 15:53
閱讀 943·2019-08-30 15:44
閱讀 960·2019-08-30 15:43
閱讀 1014·2019-08-29 16:33
閱讀 3444·2019-08-29 13:08