學習vue

今天把之前學過的vue複習了一遍,以爲當時學的不怎麼樣。因此就好好複習了基礎知識,都是些很是基礎的vue知識點javascript

代碼我放在GitHub 上了css

若是訪問不了訪問這個html

o( ̄▽ ̄)ブ😊😊😊前端

學習使用 vue

one

vue 基本結構

vue 實例控制 html 元素區域,就是咱們 new 出來的 vue 實例,當咱們導入包以後,在瀏覽器的內存中,就多了一個 Vue 構造函數 el 表示要控制哪一個區域vue

咱們 new 出來的這個 vm 對象,就是咱們 MVVM 中的 VM 調度者,data 中的數據能夠經過 vue 指令渲染到頁面中,程序員再也不手動操做 DOM 元素了【前端的 Vue 之類的框架,不提倡咱們去手動操做 DOM 元素了】java

往頁面顯示 data 中的數據和執行函數

使用 v-cloak 可以解決 插值表達式閃爍的問題,默認 v-text 是沒有閃爍問題的,v-text 會覆蓋元素中本來的內容,可是 插值表達式 只會替換本身的這個佔位符,不會把 整個元素的內容清空,v-bind 是 Vue 中,提供的用於綁定屬性的指令,注意: v-bind: 指令能夠被簡寫爲 :要綁定的屬性,v-bind 中,能夠寫合法的 JS 表達式,Vue 中提供了v-on: 事件綁定機制,也可簡寫@事件綁定機制git

  1. 如何定義一個基本的 Vue 代碼結構
  2. 插值表達式 和 v-text
  3. v-cloak
  4. v-html
  5. v-bind Vue 提供的屬性綁定機制 縮寫是 :
  6. v-on Vue 提供的事件綁定機制 縮寫是 @

實現一個滾動字幕的效果

思路:在定時器中,獲取字符串的第一個字符,和後面的全部字符,將第一個字符放到最後,不斷循環此操做,達到字幕的滾動,定義兩個函數控制開啓與中止,利用是否清除定時器程序員

methods: {
          lang() {
            if (this.intervalid != null) return;

            this.intervalid = setInterval(() => {
              var start = this.msg.substring(0, 1);
              var end = this.msg.substring(1);
              this.msg = end + start;// 在data上定義 定時器Id
            }, 50);
          },
          stop() {
            clearInterval(this.intervalid);
            this.intervalid = null;
          }
        }

事件修飾符

<div id="app">
  <!-- 使用  .stop  阻止冒泡 -->
  <div class="inner" @click="div1Handler">
    <input type="button" value="戳他" @click.stop="btnHandler" />
  </div>
  <!-- 使用 .prevent 阻止默認行爲 -->
  <a href="http://www.baidu.com" @click.prevent="linkClick">有問題,先去百度</a>

  <!-- 使用  .capture 實現捕獲觸發事件的機制 -->
  <div class="inner" @click.capture="div1Handler">
    <input type="button" value="戳他" @click="btnHandler" />
  </div>

  <!-- 使用 .self 實現只有點擊當前元素時候,纔會觸發事件處理函數 -->
  <div class="inner" @click.self="div1Handler">
    <input type="button" value="戳他" @click="btnHandler" />
  </div>

  <!-- 使用 .once 只觸發一次事件處理函數 -->
  <a href="http://www.baidu.com" @click.prevent.once="linkClick"
    >有問題,先去百度</a
  >

  <!-- 演示: .stop 和 .self 的區別 -->
  <div class="outer" @click="div2Handler">
    <div class="inner" @click="div1Handler">
      <input type="button" value="戳他" @click.stop="btnHandler" />
    </div>
  </div>

  <!-- .self 只會阻止本身身上冒泡行爲的觸發,並不會真正阻止 冒泡的行爲 -->
  <div class="outer" @click="div2Handler">
    <div class="inner" @click.self="div1Handler">
      <input type="button" value="戳他" @click="btnHandler" />
    </div>
  </div>
</div>

雙向數據綁定

v-bind 只能實現數據的單向綁定,從 M 自動綁定到 V, 沒法實現數據的雙向綁定github

使用 v-model 指令,能夠實現 表單元素和 Model 中數據的雙向數據綁定vue-router

注意: v-model 只能運用在 表單元素中

<h4>{{ msg }}</h4>
<input type="text" style="width: 100%;" v-model="msg" />

作一個簡單的計算器

methods: {
          calc() {
            switch (this.opt) {
              case "+":
                this.result = parseInt(this.n1) + parseInt(this.n2);
                break;
              case "-":
                this.result = parseInt(this.n1) - parseInt(this.n2);
                break;
              case "*":
                this.result = parseInt(this.n1) * parseInt(this.n2);
                break;
              case "/":
                this.result = parseInt(this.n1) / parseInt(this.n2);
                break;
            }
          }
        }

vue中的 class

<div id="app">
  <h1 class="red thin">這是一個很大很大的H1,大到你沒法想象!!!</h1>

  <!-- 第一種使用方式,直接傳遞一個數組,注意: 這裏的 class 須要使用  v-bind 作數據綁定 -->
  <h1 :class="['thin', 'italic']">
    這是一個很大很大的H1,大到你沒法想象!!!
  </h1>

  <!-- 在數組中使用三元表達式 -->
  <h1 :class="['thin', 'italic', flag?'active':'']">
    這是一個很大很大的H1,大到你沒法想象!!!
  </h1>

  <!-- 在數組中使用 對象來代替三元表達式,提升代碼的可讀性 -->
  <h1 :class="['thin', 'italic', {'active':flag} ]">
    這是一個很大很大的H1,大到你沒法想象!!!
  </h1>

  <!-- 在爲 class 使用 v-bind 綁定 對象的時候,對象的屬性是類名,因爲 對象的屬性可帶引號,也可不帶引號,因此 這裏我沒寫引號;  屬性的值 是一個標識符 -->
  <h1 :class="classObj">這是一個很大很大的H1,大到你沒法想象!!!</h1>
</div>

### vue 中的 style

<div id="app">
  <h1 :style="styleObj1">這是一個h1</h1>

  <h1 :style="[ styleObj1, styleObj2 ]">這是一個h1</h1>
</div>

vue 中的循環

<p v-for="(item, i) in list">索引值:{{i}} --- 每一項:{{item}}</p>
<p v-for="(user, i) in list">
  Id:{{ user.id }} --- 名字:{{ user.name }} --- 索引:{{i}}
</p>
<p v-for="(val, key, i) in user">
  值是: {{ val }} --- 鍵是: {{key}} -- 索引: {{i}}
</p>
<p v-for="count in 10">這是第 {{ count }} 次循環</p>
<p v-for="item in list" :key="item.id">
  <input type="checkbox" />{{item.id}} --- {{item.name}}
</p>

注意:在遍歷對象身上的鍵值對的時候, 除了 有 val key ,在第三個位置還有 一個 索引

in 後面咱們能夠放 普通數組,對象數組,對象, 還能夠放數字

注意:若是使用 v-for 迭代數字的話,前面的 count 值從 1 開始

注意: v-for 循環的時候,key 屬性只能使用 number 獲取 string

注意: key 在使用的時候,必須使用 v-bind 屬性綁定的形式,指定 key 的值
在組件中,使用 v-for 循環的時候,或者在一些特殊狀況中,若是 v-for 有問題,必須 在使用 v-for 的同時,指定 惟一的 字符串/數字 類型 :key 值

vue 中的判斷

v-if 的特色:每次都會從新刪除或建立元素

v-show 的特色: 每次不會從新進行 DOM 的刪除和建立操做,只是切換了元素的 display:none 樣式

v-if 有較高的切換性能消耗

v-show 有較高的初始渲染消耗

若是元素涉及到頻繁的切換,最好不要使用 v-if, 而是推薦使用 v-show

若是元素可能永遠也不會被顯示出來被用戶看到,則推薦使用 v-if

<input type="button" value="toggle" @click="flag=!flag" />
<h3 v-if="flag">由v-if控制</h3>
<h3 v-show="!flag">用v-show控制</h3>

小結

  1. MVC 和 MVVM 的區別

  2. 學習了 Vue 中最基本代碼的結構

  3. 插值表達式 v-cloak v-text v-html v-bind(縮寫是:) v-on(縮寫是@) v-model v-for v-if v-show

  4. 事件修飾符 : .stop .prevent .capture .self .once

  5. el 指定要控制的區域 data 是個對象,指定了控制的區域內要用到的數據 methods 雖然帶個 s 後綴,可是是個對象,這裏能夠自定義了方法

  6. 在 VM 實例中,若是要訪問 data 上的數據,或者要訪問 methods 中的方法, 必須帶 this

  7. 在 v-for 要會使用 key 屬性 (只接受 string / number)

  8. v-model 只能應用於表單元素

  9. 在 vue 中綁定樣式兩種方式 v-bind:class v-bind:style

two

品牌管理案例

分析:

在 Vue 中,使用事件綁定機制,爲元素指定處理函數的時候,若是加了小括號,就能夠給函數傳參了
涉及到的操做有增刪查

增長

分析:

  1. 獲取到 id 和 name ,直接從 data 上面獲取
  2. 組織出一個對象
  3. 把這個對象,調用 數組的 相關方法,添加到 當前 data 上的 list 中
  4. 注意:在 Vue 中,已經實現了數據的雙向綁定,每當咱們修改了 data 中的數據,Vue 會默認監聽到數據的改動,自動把最新的數據,應用到頁面上;

刪除

分析:

  1. 如何根據 Id,找到要刪除這一項的索引
  2. 若是找到索引了,直接調用 數組的 splice 方法

查找

分析

  1. 根據關鍵字,進行數據的搜索
  2. ES6 的 filter 方法都會對數組中的每一項,進行遍歷,執行相關的操做
  3. ES6 中,爲字符串提供了一個新方法,叫作 String.prototype.includes('要包含的字符串'),根據這個返回對應的元素

過濾器

過濾器中的 function ,第一個參數,已經被規定死了,永遠都是 過濾器 管道符前面 傳遞過來的數據

<p>{{ msg | msgFormat('瘋狂', '123') | test }}</p>

Vue.filter("msgFormat", function(msg, arg, arg2) {
  return msg.replace(/單純/g, arg + arg2);
});

Vue.filter("test", function(msg) {
  return msg + "========";
});

定義一個 Vue 全局的過濾器,名字叫作 msgFormat,字符串的 replace 方法,第一個參數,除了可寫一個 字符串以外,還能夠定義一個正則

全局的過濾器, 進行時間的格式化,所謂的全局過濾器,就是全部的 VM 實例都共享的

Vue.filter("dateFormat", function(dateStr, pattern = "") {
  // 根據給定的時間字符串,獲得特定的時間
  var dt = new Date(dateStr);

  //   yyyy-mm-dd
  var y = dt.getFullYear();
  var m = dt.getMonth() + 1;
  var d = dt.getDate();
  if (pattern.toLowerCase() === "yyyy-mm-dd") {
    return `${y}-${m}-${d}`;
  } else {
    var hh = dt.getHours();
    var mm = dt.getMinutes();
    var ss = dt.getSeconds();

    return `${y}-${m}-${d} ${hh}:${mm}:${ss}`;
  }
});

定義私有過濾器 : 在 filters 中定義,過濾器有兩個 條件 【過濾器名稱 和 處理函數】,過濾器調用的時候,採用的是就近原則,若是私有過濾器和全局過濾器名稱一致了,這時候 優先調用私有過濾器

自定義全局指令

使用 Vue.directive() 定義全局的指令 v-focus

其中:參數 1 : 指令的名稱,注意,在定義的時候,指令的名稱前面,不須要加 v- 前綴, 可是: 在調用的時候,必須 在指令名稱前 加上 v- 前綴來進行調用
參數 2: 是一個對象,這個對象身上,有一些指令相關的函數,這些函數能夠在特定的階段,執行相關的操做

Vue.directive("focus", {
  bind: function(el) {},
  inserted: function(el) {
    el.focus();
    // 和JS行爲有關的操做,最好在 inserted 中去執行,放置 JS行爲不生效
  },
  updated: function(el) {}
});

bind: 每當指令綁定到元素上的時候,會當即執行這個 bind 函數,只執行一次在每一個 函數中,第一個參數,永遠是 el ,表示 被綁定了指令的那個元素,這個 el 參數,是一個原生的 JS 對象在元素, 剛綁定了指令的時候,尚未 插入到 DOM 中去,這時候,調用 focus 方法沒有做用 由於,一個元素,只有插入 DOM 以後,才能獲取焦點

inserted: 表示元素 插入到 DOM 中的時候,會執行 inserted 函數【觸發 1 次】

updated: 當 VNode 更新的時候,會執行 updated, 可能會觸發屢次

樣式:只要經過指令綁定給了元素,無論這個元素有沒有被插入到頁面中去,這個元素確定有了一個內聯的樣式未來元素確定會顯示到頁面中,這時候,瀏覽器的渲染引擎必然會解析樣式,應用給這個元素,和樣式相關的操做,通常均可以在 bind 執行

自定義指令:用 directive 定義私有指令

directives: { // 自定義私有指令
        'fontweight': { // 設置字體粗細的
          bind: function (el, binding) {
            el.style.fontWeight = binding.value
          }
        },
        'fontsize': function (el, binding) { // 注意:這個 function 等同於 把 代碼寫到了 bind 和 update 中去
          el.style.fontSize = parseInt(binding.value) + 'px'
        }
      }

生命週期

var vm = new Vue({
  el: "#app",
  data: {
    msg: "ok"
  },
  methods: {
    show() {
      console.log("執行了show方法");
    }
  },
  beforeCreate() {
    // 這是咱們遇到的第一個生命週期函數,表示實例徹底被建立出來以前,會執行它
    // console.log(this.msg)
    // this.show()
    // 注意: 在 beforeCreate 生命週期函數執行的時候,data 和 methods 中的 數據都尚未沒初始化
  },
  created() {
    // 這是遇到的第二個生命週期函數
    // console.log(this.msg)
    // this.show()
    //  在 created 中,data 和 methods 都已經被初始化好了!
    // 若是要調用 methods 中的方法,或者操做 data 中的數據,最先,只能在 created 中操做
  },
  beforeMount() {
    // 這是遇到的第3個生命週期函數,表示 模板已經在內存中編輯完成了,可是還沒有把 模板渲染到 頁面中
    // console.log(document.getElementById('h3').innerText)
    // 在 beforeMount 執行的時候,頁面中的元素,尚未被真正替換過來,只是以前寫的一些模板字符串
  },
  mounted() {
    // 這是遇到的第4個生命週期函數,表示,內存中的模板,已經真實的掛載到了頁面中,用戶已經能夠看到渲染好的頁面了
    // console.log(document.getElementById('h3').innerText)
    // 注意: mounted 是 實例建立期間的最後一個生命週期函數,當執行完 mounted 就表示,實例已經被徹底建立好了,此時,若是沒有其它操做的話,這個實例,就靜靜的 躺在咱們的內存中,一動不動
  },

  // 接下來的是運行中的兩個事件
  beforeUpdate() {
    // 這時候,表示 咱們的界面尚未被更新【數據被更新了嗎?  數據確定被更新了】
    /* console.log('界面上元素的內容:' + document.getElementById('h3').innerText)
        console.log('data 中的 msg 數據是:' + this.msg) */
    // 得出結論: 當執行 beforeUpdate 的時候,頁面中的顯示的數據,仍是舊的,此時 data 數據是最新的,頁面還沒有和 最新的數據保持同步
  },
  updated() {
    console.log("界面上元素的內容:" + document.getElementById("h3").innerText);
    console.log("data 中的 msg 數據是:" + this.msg);
    // updated 事件執行的時候,頁面和 data 數據已經保持同步了,都是最新的
  }
});

生命週期總的來講分三個部分:數據,掛載,更新,每一個部分都有兩個階段:前和後

vue-resource

getInfo:當發起 get 請求以後, 經過 .then 來設置成功的回調函數,經過 result.body 拿到服務器返回的成功的數據

postInfo:發起 post 請求 , application/x-wwww-form-urlencoded,手動發起的 Post 請求,默認沒有表單格式,因此,有的服務器處理不了,經過 post 方法的第三個參數, { emulateJSON: true } 設置 提交的內容類型 爲 普通表單數據格式

jsonpInfo:發起 JSONP 請求

若是咱們經過全局配置了,請求的數據接口 根域名,則 ,在每次單獨發起 http 請求的時候,請求的 url 路徑,應該以相對路徑開頭,前面不能帶 / ,不然 不會啓用根路徑作拼接;

three

過渡類名實現動畫

  1. 使用 transition 元素,把 須要被動畫控制的元素,包裹起來,transition 元素,是 Vue 官方提供的
  2. 自定義兩組樣式,來控制 transition 內部的元素實現動畫

v-enter 【這是一個時間點】 是進入以前,元素的起始狀態,此時尚未開始進入

v-leave-to 【這是一個時間點】 是動畫離開以後,離開的終止狀態,此時,元素 動畫已經結束了

v-enter-active 【入場動畫的時間段】

v-leave-active 【離場動畫的時間段】

若要修改 V-這個前綴,能夠這麼作

.my-enter,
.my-leave-to {
  opacity: 0;
  transform: translateY(70px);
}

.my-enter-active,
.my-leave-active {
  transition: all 0.8s ease;
}
<transition name="my">
  <h6 v-if="flag2">這是一個H6</h6>
</transition>

鉤子函數實現動畫

動畫鉤子函數的第一個參數:el,表示 要執行動畫的那個 DOM 元素,是個原生的 JS DOM 對象,能夠認爲 , el 是經過 document.getElementById('') 方式獲取到的原生 JS DOM 對象

beforeEnter: 表示動畫入場以前,此時,動畫還沒有開始,能夠 在 beforeEnter 中,設置元素開始動畫以前的起始樣式

enter: 表示動畫 開始以後的樣式,

done, 起始就是 afterEnter 這個函數,也就是說:done 是 afterEnter 函數的引用

afterEnter 動: 畫完成以後,會調用 afterEnter

<transition
  @before-enter="beforeEnter"
  @enter="enter"
  @after-enter="afterEnter"
>
  <div class="ball" v-show="flag"></div>
</transition>
methods: {
          beforeEnter(el) {
            // 設置小球開始動畫以前的,起始位置
            el.style.transform = "translate(0, 0)";
          },
          enter(el, done) {
            // 這句話,沒有實際的做用,可是,若是不寫,出不來動畫效果;
            // 能夠認爲 el.offsetWidth 會強制動畫刷新
            el.offsetWidth;
            el.style.transform = "translate(150px, 450px)";
            el.style.transition = "all 1s ease";
            done();
          },
          afterEnter(el) {
            // console.log('ok')
            this.flag = !this.flag;
          }
        }

在實現列表過渡的時候,若是須要過渡的元素,是經過 v-for 循環渲染出來的,不能使用 transition 包裹,須要使用 transitionGroup,若是要爲 v-for 循環建立的元素設置動畫,必須爲每個 元素 設置 :key 屬性,給 ransition-group 添加 appear 屬性,實現頁面剛展現出來時候,入場時候的效果, 經過 爲 transition-group 元素,設置 tag 屬性,指定 transition-group 渲染爲指定的元素,若是不指定 tag 屬性,默認,渲染爲 span 標籤

<transition-group appear tag="ul">
  <li v-for="(item, i) in list" :key="item.id" @click="del(i)">
    {{item.id}} --- {{item.name}}
  </li>
</transition-group>

建立組件

方式一

使用 Vue.extend 來建立全局的 Vue 組件

var com1 = Vue.extend({
  template: "<h3>這是使用 Vue.extend 建立的組件</h3>" // 經過 template 屬性,指定了組件要展現的HTML結構
});

使用 Vue.component('組件的名稱', 建立出來的組件模板對象)
Vue.component('myCom1', com1)
若是使用 Vue.component 定義全局組件的時候,組件名稱使用了 駝峯命名,則在引用組件的時候,須要把 大寫的駝峯改成小寫的字母,同時,兩個詞以前,使用 - 連接;

若是不使用駝峯,則直接拿名稱來使用便可;
Vue.component('mycom1', com1)

Vue.component 第一個參數:組件的名稱,未來在引用組件的時候,就是一個 標籤形式 來引入 它的
第二個參數: Vue.extend 建立的組件 ,其中 template 就是組件未來要展現的 HTML 內容

方式二

Vue.component("mycom2", {
  template:
    "<div><h3>這是直接使用 Vue.component 建立出來的組件</h3><span>123</span></div>"
});

注意:不管是哪一種方式建立出來的組件,組件的 template 屬性指向的模板內容,必須有且只能有惟一的一個根元素

方式三

在 被控制的 #app 外面,使用 template 元素,定義組件的 HTML 模板結

<template id="tmpl">
  <div>
    <h1>
      這是經過 template
      元素,在外部定義的組件結構,這個方式,有代碼的只能提示和高亮
    </h1>
    <h4>好用,不錯!</h4>
  </div>
</template>
Vue.component("mycom3", {
  template: "#tmpl"
});

定義私有組件

components: { // 定義實例內部私有組件的
        login: {
          template: '#tmpl2'
        }

組件的 data 和 methods

  1. 組件能夠有本身的 data 數據
  2. 組件的 data 和 實例的 data 有點不同,實例中的 data 能夠爲一個對象,可是 組件中的 data 必須是一個方法
  3. 組件中的 data 除了必須爲一個方法以外,這個方法內部,還必須返回一個對象才行;
  4. 組件中 的 data 數據,使用方式,和實例中的 data 使用方式徹底同樣!!!

組件切換

方式一

<div id="app">
  <a href="" @click.prevent="flag=true">登陸</a>
  <a href="" @click.prevent="flag=false">註冊</a>

  <login v-if="flag"></login>
  <register v-else="flag"></register>
</div>

方式二

Vue 提供了 component ,來展現對應名稱的組件, component 是一個佔位符, :is 屬性,能夠用來指定要展現的組件的名稱

<div id="app">
  <a href="" @click.prevent="comName='login'">登陸</a>
  <a href="" @click.prevent="comName='register'">註冊</a>

  <component :is="comName"></component>
</div>

組件切換時的動畫

經過 mode 屬性,設置組件切換時候的 模式

<transition mode="out-in">
  <component :is="comName"></component>
</transition>

four

父組件傳值給子組件

父組件,能夠在引用子組件的時候, 經過 屬性綁定(v-bind:) 的形式, 把 須要傳遞給 子組件的數據,以屬性綁定的形式,傳遞到子組件內部,供子組件使用

子組件中,默認沒法訪問到 父組件中的 data 上的數據 和 methods 中的方法

子組件中的 data 數據,並非經過 父組件傳遞過來的,而是子組件自身私有的,好比: 子組件經過 Ajax ,請求回來的數據,均可以放到 data 身上; data 上的數據,都是可讀可寫的;

注意: 組件中的 全部 props 中的數據,都是經過 父組件傳遞給子組件的,props 中的數據,都是隻讀的,沒法從新賦值

props: ['parentmsg']把父組件傳遞過來的 parentmsg 屬性,先在 props 數組中,定義一下,這樣,才能使用這個數據,只讀,寫的話會報警告

父組件傳方法給子組件

父組件向子組件 傳遞 方法,使用的是 事件綁定機制; v-on, 當咱們自定義了 一個 事件屬性以後,那麼,子組件就可以,經過某些方式,來調用 傳遞進去的 這個 方法了

當點擊子組件的按鈕的時候,如何 拿到 父組件傳遞過來的 func 方法,並調用這個方法???

emit 英文原意: 是觸發,調用、發射的意思,能夠用 emit

評論組件

分析:發表評論的業務邏輯

  • 評論數據存到哪裏去??? 存放到了 localStorage 中 localStorage.setItem('cmts', '')
  • 先組織出一個最新的評論數據對象
  • 想辦法,把 第二步中,獲得的評論對象,保存到 localStorage 中:
  • localStorage 只支持存放字符串數據, 要先調用 JSON.stringify

  • 在保存 最新的 評論數據以前,要先從 localStorage 獲取到以前的評論數據(string), 轉換爲 一個 數組對象, 而後,把最論, push 到這個數組

  • 若是獲取到的 localStorage 中的 評論字符串,爲空不存在, 則 能夠 返回一個 '[]' 讓 JSON.parse 去轉換

  • 把 最新的 評論列表數組,再次調用 JSON.stringify 轉爲 數組字符串,而後調用 localStorage.setItem()

ref 獲取 DOM 元素和組件

ref 是 英文單詞 【reference】 值類型 和 引用類型 referenceError

能夠經過下面這些方式對應組件和 DOM 中的數據和方法

this.$refs.mylogin.msg
this.$refs.mylogin.show()
this.$refs.myh3.innerText
document.getElementById('myh3').innerText

路由的基本使用

建立一個路由對象, 當 導入 vue-router 包以後,在 window 全局對象中,就有了一個 路由的構造函數,叫作 VueRouter,在 new 路由對象的時候,能夠爲 構造函數,傳遞一個配置對象

route : 這個配置對象中的 route 表示 【路由匹配規則】 的意思

每一個路由規則,都是一個對象,這個規則對象,身上,有兩個必須的屬性:屬性 1 是 path, 表示監聽 哪一個路由連接地址;屬性 2 是 component, 表示,若是 路由是前面匹配到的 path ,則展現 component 屬性對應的那個組件

注意: component 的屬性值,必須是一個 組件的模板對象, 不能是 組件的引用名稱;

var routerObj = new VueRouter({
  routes: [
    // { path: '/', component: login },
    { path: "/", redirect: "/login" }, // 這裏的 redirect 和 Node 中的 redirect 徹底是兩碼事
    { path: "/login", component: login },
    { path: "/register", component: register }
  ],
  linkActiveClass: "myactive"
});

<router-view></router-view>
vue-router 提供的元素,專門用來 看成佔位符的,未來,路由規則,匹配到的組件,就會展現到這個 router-view 中去,咱們能夠把 router-view 認爲是一個佔位符

router-link 默認渲染爲一個 a 標籤

<router-link to="/login" tag="span">登陸</router-link>
<router-link to="/register">註冊</router-link>

路由規則中定義參數

若是在路由中,使用 查詢字符串,給路由傳遞參數,則 不須要修改 路由規則的 path 屬性

方式一

<router-link to="/login?id=10&name=zs">登陸</router-link>

var login = {
  template:
    "<h1>登陸 --- {{ $route.query.id }} --- {{ $route.query.name }}</h1>",
  data() {
    return {
      msg: "123"
    };
  }
};

方式二

<router-link to="/login/12/ls">登陸</router-link>

{ path: '/login/:id/:name', component: login }

template: '<h1>登陸 --- {{ $route.params.id }} --- {{ $route.params.name }}</h1>'

路由嵌套

使用 children 屬性,實現子路由,同時,子路由的 path 前面,不要帶 / ,不然永遠以根路徑開始請求,這樣不方便咱們用戶去理解 URL 地址

routes: [
  {
    path: "/account",
    component: account,
    children: [
      { path: "login", component: login },
      { path: "register", component: register }
    ]
  }
];

router-view

<router-view></router-view>
<div class="container">
  <router-view name="left"></router-view>
  <router-view name="main"></router-view>
</div>
routes: [
  {
    path: "/",
    components: {
      default: header,
      left: leftBox,
      main: mainBox
    }
  }
];
相關文章
相關標籤/搜索