1.MVVM
model-view-viewModel,model是數據與業務邏輯,view是UI界面,viewModel是一個對象用於實現model與view的同步。
ViewModel 經過雙向數據綁定把 View 層和 Model 層鏈接了起來。css
2.雙向數據綁定
vue.js 是採用數據劫持結合發佈者-訂閱者模式的方式,經過Object.defineProperty()
來劫持各個屬性的setter
,getter
,在數據變更時發佈消息給訂閱者,觸發相應的監聽回調。html
3.MVVM 與MVC
主要區別是controller控制器演變成了viewModel,不用手動將model數據更新到view,減小了大量dom操做,提高了頁面渲染性能。vue
4.生命週期
建立前/後:
在beforeCreate階段,vue實例的掛載元素el和數據對象data都爲undefined,還未初始化。
在created階段,vue實例的數據對象data有了,el尚未。
載入前/後:
在beforeMount階段,vue實例的$el和data都初始化了,但仍是掛載以前爲虛擬的dom節點,data.message還未替換。
在mounted階段,vue實例掛載完成,data.message成功渲染。
更新前/後:
當data變化時,會觸發beforeUpdate和updated方法。
銷燬前/後:
在執行destroy方法後,對data的改變不會再觸發周期函數,說明此時vue實例已經解除了事件監聽以及和dom的綁定,可是dom結構依然存在node
5.父子組件通訊
父組件在標籤上定義傳值,子組件經過props接受傳值;父組件在標籤上定義傳遞方法,子組件經過$emit調用父組件的方法並傳遞參數。webpack
6.組件的定義使用
通常在components目錄建立自定義組件;在須要的頁面導入import from;在components屬性上面注入自定義組件;在template視圖view中使用;ios
7.關於路由
聲明式路由:<router-link :to="">
編程式路由:
router.push({ name: 'user', params: { userId: 123 }});命名的路由
router.push({ path: 'register', query: { plan: 'private' }});帶查詢參數的路由,有path會忽視paramses6
8.vue配合webpack 按需加載
不進行頁面按需加載引入方式:import home from '../../common/home.vue'
進行頁面按需加載的引入方式:const home = r => require.ensure( [], () => r (require('../../common/home.vue')))web
9.關於store
state:全局狀態;
getter:store的擴展,相似state的計算屬性
mapState/mapGetter輔助函數幫助咱們生成計算屬性,通常結合擴展運算符...mapState()用於vue實例中的computed:
mutations:包含事件類型和回調函數:
state: {
count: 1
},
mutations: {
increment (state,n) {
// 變動狀態
state.count += n;
}
}
調用:store.commit('increment',10);
mutation 都是同步事務
actions: actions 提交的是 mutations,而不是直接變動狀態;actions能夠包含異步操做;實際的購物車示例,涉及到調用異步 API 和分發多重 mutation
actions: {
checkout ({ commit, state }, products) {
// 把當前購物車的物品備份起來
const savedCartItems = [...state.cart.added]
// 發出結帳請求,而後樂觀地清空購物車
commit(types.CHECKOUT_REQUEST)
// 購物 API 接受一個成功回調和一個失敗回調
shop.buyProducts(
products,
// 成功操做
() => commit(types.CHECKOUT_SUCCESS),
// 失敗操做
() => commit(types.CHECKOUT_FAILURE, savedCartItems)
)
}
}
module:模塊兒vue-router
10.<keep-alive></keep-alive> 緩存不活動的組件實例,主要用於保留組件狀態或避免從新渲染。npm
11.v-el提供一個在頁面上已存在的 DOM 元素做爲 Vue 實例的掛載目標.能夠是 CSS 選擇器,也能夠是一個 HTMLElement 實例
12.vue使用插件的步驟
通常在入口js文件main.js中vue實例化以前,採用import導入,或者採用require導入,而後vue.use()
例如:
import ElementUI from 'element-ui'
import VueAwesomeSwiper from 'vue-awesome-swiper'
Vue.use(ElementUI)
Vue.use(VueAwesomeSwiper)
13.vue中經常使用的生命週期鉤子函數
created:實例已經建立完成以後調用,實例已經完成數據觀測,屬性和方法的運算,watch/event事件回調。掛在階段沒有開始,$el屬性目前還不可見;
mounted:el被新建立的$el替換,並掛載到實例上去以後調用該鉤子,
activated: keep-alive 組件激活時調用
14.activeclass 是vue-router模塊的router-link組件的屬性。
15.怎麼定義vue-router的動態路由?如何獲取傳過來的動態參數?
在router目錄下的index.js文件中,對path屬性加上/:id;
使用router對象的params.id;this.$route.query或者this.$route.params
16.vue-router有哪幾種導航鉤子?
全局導航鉤子:
//定義一個路由
const router = new VueRouter({ ... })
// 點擊導航前調用
router.beforeEach((to, from, next) => {})
// 點擊導航後調用
router.afterEach(route => {})
單個路由獨享的鉤子:
const router = new VueRouter({
routes: [
{
path: '/foo',
component: Foo,
beforeEnter: (to, from, next) => {},
}
]
});
組件內的鉤子:
beforeRouteEnter (to, from, next) {},
beforeRouteUpdate (to, from, next) {},
beforeRouteLeave (to, from, next) {}
router.beforeEach(to,from,next),做用:跳轉前進行判斷攔截。
17.什麼是vue生命週期
答: Vue 實例從建立到銷燬的過程,就是生命週期。也就是從開始建立、初始化數據、編譯模板、掛載Dom→渲染、更新→渲染、卸載等一系列過程,咱們稱這是 Vue 的生命週期。
18.vue生命週期的做用是什麼
答:它的生命週期中有多個事件鉤子,讓咱們在控制整個Vue實例的過程時更容易造成好的邏輯。
19.vue生命週期總共有幾個階段
答:能夠總共分爲8個階段:建立前/後, 載入前/後,更新前/後,銷燬前/銷燬後
20.第一次頁面加載會觸發哪幾個鉤子
第一次頁面加載時會觸發 beforeCreate, created, beforeMount, mounted 這幾個鉤子
21.DOM 渲染在 哪一個週期中就已經完成
答:DOM 渲染在 mounted 中就已經完成了。
22.簡單描述每一個週期具體適合哪些場景
beforecreate : 能夠在這加個loading事件,在加載實例時觸發
created : 初始化完成時的事件寫在這裏,如在這結束loading事件,異步請求也適宜在這裏調用
mounted : 掛載元素,獲取到DOM節點
updated : 若是對數據統一處理,在這裏寫上相應函數
beforeDestroy : 能夠作一個確認中止事件的確認框
nextTick : 更新數據後當即操做dom
//改變數據
vm.message = 'changed'
//想要當即使用更新後的DOM。這樣不行,由於設置message後DOM尚未更新
console.log(vm.$el.textContent) // 並不會獲得'changed'
//這樣能夠,nextTick裏面的代碼會在DOM更新後執行
Vue.nextTick(function(){
console.log(vm.$el.textContent) //能夠獲得'changed'
})
23.說出至少4種vue當中的指令和它的用法?
v-if:判斷是否隱藏;v-for:數據循環;v-bind:綁定一個屬性;v-model:實現雙向綁定
24.vue-loader是什麼?使用它的用途有哪些?
.vue文件的一個加載器,解析和轉換.vue文件,將其中的js css html提取並交由相應的解析器。
用途:js能夠寫es六、style樣式能夠scss或less、template能夠加jade等
25.scss是什麼?在vue.cli中的安裝使用步驟是?有哪幾大特性?
答:css的預編譯。
使用步驟:
第一步:先裝css-loader、node-loader、sass-loader等加載器模塊
第二步:在build目錄找到webpack.base.config.js,在那個extends屬性中加一個拓展.scss
第三步:在同一個文件,配置一個module屬性
第四步:而後在組件的style標籤加上lang屬性 ,例如:lang=」scss」
特性:
能夠用變量,例如($變量名稱=值);
能夠用混合器,例如()
能夠嵌套
26.爲何使用key?
避免某些標籤元素的複用;採用v-for渲染列表時,若是數據項的順序變了,若是不用key,vue就會複用已存在的元素,達不到想要的真實順序。
27.VNode是什麼?虛擬 DOM是什麼?
Vue在 頁面上渲染的節點,及其子節點稱爲「虛擬節點 (Virtual Node)」,簡寫爲「VNode」。「虛擬 DOM」是由 Vue 組件樹創建起來的整個 VNode 樹的稱呼。
28.$set
Vue 不能檢測到對象屬性的添加或刪除。Vue 不能檢測如下變更的數組:
1. 當你利用索引直接設置一個項時,例如: vm.item[index] = newValue
2. 當你修改數組的長度時,例如: vm.items.length = newLength
可使用Vue.set(object, key, value) 和 this.$set(object, key, value)
29.插槽<slot>
30.axios是什麼?怎麼使用?描述使用它實現登陸功能的流程?
答:請求後臺資源的模塊。npm install axios -S裝好,而後發送的是跨域,需在配置文件中config/index.js進行設置。
後臺若是是Tp5則定義一個資源路由。js中使用import進來,而後.get或.post。返回在.then函數中若是成功,失敗則是在.catch函數中
31.axios+tp5進階中,調用axios.post(‘api/user’)是進行的什麼操做?axios.put(‘api/user/8′)呢?
答:跨域,添加用戶操做,更新操做。
32.自定義指令(v-check、v-focus)的方法有哪些?它有哪些鉤子函數?還有哪些鉤子函數參數?
答:
全局定義指令:在vue對象的directive方法裏面有兩個參數,一個是指令名稱,另一個是函數。
組件內定義指令:directives
鉤子函數:bind(綁定事件觸發)、inserted(節點插入的時候觸發)、update(組件內相關更新)
鉤子函數參數:el、binding
33.Vue的雙向數據綁定原理是什麼?(vue data是怎麼實現的?)
答:vue.js 是採用數據劫持結合發佈者-訂閱者模式的方式,經過Object.defineProperty()來劫持各個屬性的setter,getter,在數據變更時發佈消息給訂閱者,觸發相應的監聽回調。
具體步驟:
第一步:須要observe的數據對象進行遞歸遍歷,包括子屬性對象的屬性,都加上 setter和getter
這樣的話,給這個對象的某個值賦值,就會觸發setter,那麼就能監聽到了數據變化
第二步:compile解析模板指令,將模板中的變量替換成數據,而後初始化渲染頁面視圖,並將每一個指令對應的節點綁定更新函數,添加監聽數據的訂閱者,一旦數據有變更,收到通知,更新視圖
第三步:Watcher訂閱者是Observer和Compile之間通訊的橋樑,主要作的事情是:
一、在自身實例化時往屬性訂閱器(dep)裏面添加本身
二、自身必須有一個update()方法
三、待屬性變更dep.notice()通知時,能調用自身的update()方法,並觸發Compile中綁定的回調,則功成身退。
第四步:MVVM做爲數據綁定的入口,整合Observer、Compile和Watcher三者,經過Observer來監聽本身的model數據變化,經過Compile來解析編譯模板指令,最終利用Watcher搭起Observer和Compile之間的通訊橋樑,達到數據變化 -> 視圖更新;視圖交互變化(input) -> 數據model變動的雙向綁定效果。
34.聊聊你對Vue.js的template編譯的理解? 答:簡而言之,就是先轉化成AST樹,再獲得的render函數返回VNode(Vue的虛擬DOM節點) 詳情步驟: 首先,經過compile編譯器把template編譯成AST語法樹(abstract syntax tree 即 源代碼的抽象語法結構的樹狀表現形式), compile是createCompiler的返回值,createCompiler是用以建立編譯器的。另外compile還負責合併option。 而後,AST會通過generate(將AST語法樹轉化成render funtion字符串的過程)獲得render函數,render的返回值是VNode, VNode是Vue的虛擬DOM節點,裏面有(標籤名、子節點、文本等等)