主頁 > 企業開發 > 學習vue

學習vue

2020-10-03 15:02:18 企業開發

今天把以前學過的vue復習了一遍,覺得當時學的不怎么樣,所以就好好復習了基礎知識,都是些非常基礎的vue知識點

代碼我放在GitHub 上了

如果訪問不了訪問這個

o( ̄▽ ̄)ブ??????

學習使用 vue

one

vue 基本結構

vue 實體控制 html 元素區域,就是我們 new 出來的 vue 實體,當我們匯入包之后,在瀏覽器的記憶體中,就多了一個 Vue 建構式 el 表示要控制哪個區域

我們 new 出來的這個 vm 物件,就是我們 MVVM 中的 VM 調度者,data 中的資料可以通過 vue 指令渲染到頁面中,程式員不再手動操作 DOM 元素了【前端的 Vue 之類的框架,不提倡我們去手動操作 DOM 元素了】

往頁面顯示 data 中的資料和執行函式

使用 v-cloak 能夠解決 插值運算式閃爍的問題,默認 v-text 是沒有閃爍問題的,v-text 會覆寫元素中原本的內容,但是 插值運算式 只會替換自己的這個占位符,不會把 整個元素的內容清空,v-bind 是 Vue 中,提供的用于系結屬性的指令,注意: v-bind: 指令可以被簡寫為 :要系結的屬性,v-bind 中,可以寫合法的 JS 運算式,Vue 中提供了v-on: 事件系結機制,也可簡寫@事件系結機制

  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  @click="div1Handler">
    <input type="button" value="https://www.cnblogs.com/ycoder/p/戳他" @click.stop="btnHandler" />
  </div>
  <!-- 使用 .prevent 阻止默認行為 -->
  <a href="http://www.baidu.com" @click.prevent="linkClick">有問題,先去百度</a>

  <!-- 使用  .capture 實作捕獲觸發事件的機制 -->
  <div  @click.capture="div1Handler">
    <input type="button" value="https://www.cnblogs.com/ycoder/p/戳他" @click="btnHandler" />
  </div>

  <!-- 使用 .self 實作只有點擊當前元素時候,才會觸發事件處理函式 -->
  <div  @click.self="div1Handler">
    <input type="button" value="https://www.cnblogs.com/ycoder/p/戳他" @click="btnHandler" />
  </div>

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

  <!-- 演示: .stop 和 .self 的區別 -->
  <div  @click="div2Handler">
    <div  @click="div1Handler">
      <input type="button" value="https://www.cnblogs.com/ycoder/p/戳他" @click.stop="btnHandler" />
    </div>
  </div>

  <!-- .self 只會阻止自己身上冒泡行為的觸發,并不會真正阻止 冒泡的行為 -->
  <div  @click="div2Handler">
    <div  @click.self="div1Handler">
      <input type="button" value="https://www.cnblogs.com/ycoder/p/戳他" @click="btnHandler" />
    </div>
  </div>
</div>

雙向資料系結

v-bind 只能實作資料的單向系結,從 M 自動系結到 V, 無法實作資料的雙向系結

使用 v-model 指令,可以實作 表單元素和 Model 中資料的雙向資料系結

注意: 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 >這是一個很大很大的H1,大到你無法想象!!!</h1>

  <!-- 第一種使用方式,直接傳遞一個陣列,注意: 這里的 class 需要使用  v-bind 做資料系結 -->
  <h1 :>
    這是一個很大很大的H1,大到你無法想象!!!
  </h1>

  <!-- 在陣列中使用三元運算式 -->
  <h1 :>
    這是一個很大很大的H1,大到你無法想象!!!
  </h1>

  <!-- 在陣列中使用 物件來代替三元運算式,提高代碼的可讀性 -->
  <h1 :>
    這是一個很大很大的H1,大到你無法想象!!!
  </h1>

  <!-- 在為 class 使用 v-bind 系結 物件的時候,物件的屬性是類名,由于 物件的屬性可帶引號,也可不帶引號,所以 這里我沒寫引號;  屬性的值 是一個識別符號 -->
  <h1 :>這是一個很大很大的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="https://www.cnblogs.com/ycoder/p/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  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 >
  <router-view name="left"></router-view>
  <router-view name="main"></router-view>
</div>
routes: [
  {
    path: "/",
    components: {
      default: header,
      left: leftBox,
      main: mainBox
    }
  }
];

watch屬性和computed

watch用來檢測變化,一旦data中的資料改變就會執行watch中的操作,可以用來檢測路由的變化

watch: {
        '$route.path': function (newVal, oldVal) {
          if (newVal === '/login') {
            console.log('歡迎進入登錄頁面')
          } else if (newVal === '/register') {
            console.log('歡迎進入注冊頁面')
          }
        }
      }

在 computed 中,可以定義一些 屬性,這些屬性,叫做 【計算屬性】, 計算屬性的,本質,就是 一個方法,只不過,我們在使用 這些計算屬性的時候,是把 它們的 名稱,直接當作 屬性來使用的;并不會把 計算屬性,當作方法去呼叫;

注意1: 計算屬性,在參考的時候,一定不要加 () 去呼叫,直接把它 當作 普通 屬性去使用就好了;
注意2: 只要 計算屬性,這個 function 內部,所用到的 任何 data 中的資料發送了變化,就會 立即重新計算 這個 計算屬性的值
注意3: 計算屬性的求值結果,會被快取起來,方便下次直接使用; 如果 計算屬性方法中,所以來的任何資料,都沒有發生過變化,則,不會重新對 計算屬性求值;

轉載請註明出處,本文鏈接:https://www.uj5u.com/qiye/151758.html

標籤:JavaScript

上一篇:3分鐘接入socket.io使用

下一篇:node post 大資料無回應超時

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • IEEE1588PTP在數字化變電站時鐘同步方面的應用

    IEEE1588ptp在數字化變電站時鐘同步方面的應用 京準電子科技官微——ahjzsz 一、電力系統時間同步基本概況 隨著對IEC 61850標準研究的不斷深入,國內外學者提出基于IEC61850通信標準體系建設數字化變電站的發展思路。數字化變電站與常規變電站的顯著區別在于程序層傳統的電流/電壓互 ......

    uj5u.com 2020-09-10 03:51:52 more
  • HTTP request smuggling CL.TE

    CL.TE 簡介 前端通過Content-Length處理請求,通過反向代理或者負載均衡將請求轉發到后端,后端Transfer-Encoding優先級較高,以TE處理請求造成安全問題。 檢測 發送如下資料包 POST / HTTP/1.1 Host: ac391f7e1e9af821806e890 ......

    uj5u.com 2020-09-10 03:52:11 more
  • 網路滲透資料大全單——漏洞庫篇

    網路滲透資料大全單——漏洞庫篇漏洞庫 NVD ——美國國家漏洞庫 →http://nvd.nist.gov/。 CERT ——美國國家應急回應中心 →https://www.us-cert.gov/ OSVDB ——開源漏洞庫 →http://osvdb.org Bugtraq ——賽門鐵克 →ht ......

    uj5u.com 2020-09-10 03:52:15 more
  • 京準講述NTP時鐘服務器應用及原理

    京準講述NTP時鐘服務器應用及原理京準講述NTP時鐘服務器應用及原理 安徽京準電子科技官微——ahjzsz 北斗授時原理 授時是指接識訓通過某種方式獲得本地時間與北斗標準時間的鐘差,然后調整本地時鐘使時差控制在一定的精度范圍內。 衛星導航系統通常由三部分組成:導航授時衛星、地面檢測校正維護系統和用戶 ......

    uj5u.com 2020-09-10 03:52:25 more
  • 利用北斗衛星系統設計NTP網路時間服務器

    利用北斗衛星系統設計NTP網路時間服務器 利用北斗衛星系統設計NTP網路時間服務器 安徽京準電子科技官微——ahjzsz 概述 NTP網路時間服務器是一款支持NTP和SNTP網路時間同步協議,高精度、大容量、高品質的高科技時鐘產品。 NTP網路時間服務器設備采用冗余架構設計,高精度時鐘直接來源于北斗 ......

    uj5u.com 2020-09-10 03:52:35 more
  • 詳細解讀電力系統各種對時方式

    詳細解讀電力系統各種對時方式 詳細解讀電力系統各種對時方式 安徽京準電子科技官微——ahjzsz,更多資料請添加VX 衛星同步時鐘是我京準公司開發研制的應用衛星授時時技術的標準時間顯示和發送的裝置,該裝置以M國全球定位系統(GLOBAL POSITIONING SYSTEM,縮寫為GPS)或者我國北 ......

    uj5u.com 2020-09-10 03:52:45 more
  • 如何保證外包團隊接入企業內網安全

    不管企業規模的大小,只要企業想省錢,那么企業的某些服務就一定會采用外包的形式,然而看似美好又經濟的策略,其實也有不好的一面。下面我通過安全的角度來聊聊使用外包團的安全隱患問題。 先看看什么服務會使用外包的,最常見的就是話務/客服這種需要大量重復性、無技術性的服務,或者是一些銷售外包、特殊的職能外包等 ......

    uj5u.com 2020-09-10 03:52:57 more
  • PHP漏洞之【整型數字型SQL注入】

    0x01 什么是SQL注入 SQL是一種注入攻擊,通過前端帶入后端資料庫進行惡意的SQL陳述句查詢。 0x02 SQL整型注入原理 SQL注入一般發生在動態網站URL地址里,當然也會發生在其它地發,如登錄框等等也會存在注入,只要是和資料庫打交道的地方都有可能存在。 如這里http://192.168. ......

    uj5u.com 2020-09-10 03:55:40 more
  • [GXYCTF2019]禁止套娃

    git泄露獲取原始碼 使用GET傳參,引數為exp 經過三層過濾執行 第一層過濾偽協議,第二層過濾帶引數的函式,第三層過濾一些函式 preg_replace('/[a-z,_]+\((?R)?\)/', NULL, $_GET['exp'] (?R)參考當前正則運算式,相當于匹配函式里的引數 因此傳遞 ......

    uj5u.com 2020-09-10 03:56:07 more
  • 等保2.0實施流程

    流程 結論 ......

    uj5u.com 2020-09-10 03:56:16 more
最新发布
  • 使用Django Rest framework搭建Blog

    在前面的Blog例子中我們使用的是GraphQL, 雖然GraphQL的使用處于上升趨勢,但是Rest API還是使用的更廣泛一些. 所以還是決定回到傳統的rest api framework上來, Django rest framework的官網上給了一個很好用的QuickStart, 我參考Qu ......

    uj5u.com 2023-04-20 08:17:54 more
  • 記錄-new Date() 我忍你很久了!

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 大家平時在開發的時候有沒被new Date()折磨過?就是它的諸多怪異的設定讓你每每用的時候,都可能不小心踩坑。造成程式意外出錯,卻一下子找不到問題出處,那叫一個煩透了…… 下面,我就列舉它的“四宗罪”及應用思考 可惡的四宗罪 1. Sa ......

    uj5u.com 2023-04-20 08:17:47 more
  • 使用Vue.js實作文字跑馬燈效果

    實作文字跑馬燈效果,首先用到 substring()截取 和 setInterval計時器 clearInterval()清除計時器 效果如下: 實作代碼如下: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta ......

    uj5u.com 2023-04-20 08:12:31 more
  • JavaScript 運算子

    JavaScript 運算子/運算子 在 JavaScript 中,有一些運算子可以使代碼更簡潔、易讀和高效。以下是一些常見的運算子: 1、可選鏈運算子(optional chaining operator) ?.是可選鏈運算子(optional chaining operator)。?. 可選鏈操 ......

    uj5u.com 2023-04-20 08:02:25 more
  • CSS—相對單位rem

    一、概述 rem是一個相對長度單位,它的單位長度取決于根標簽html的字體尺寸。rem即root em的意思,中文翻譯為根em。瀏覽器的文本尺寸一般默認為16px,即默認情況下: 1rem = 16px rem布局原理:根據CSS媒體查詢功能,更改根標簽的字體尺寸,實作rem單位隨螢屏尺寸的變化,如 ......

    uj5u.com 2023-04-20 08:02:21 more
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 08:01:50 more
  • 如何在 vue3 中使用 jsx/tsx?

    我們都知道,通常情況下我們使用 vue 大多都是用的 SFC(Signle File Component)單檔案組件模式,即一個組件就是一個檔案,但其實 Vue 也是支持使用 JSX 來撰寫組件的。這里不討論 SFC 和 JSX 的好壞,這個仁者見仁智者見智。本篇文章旨在帶領大家快速了解和使用 Vu ......

    uj5u.com 2023-04-20 08:01:37 more
  • 【Vue2.x原始碼系列06】計算屬性computed原理

    本章目標:計算屬性是如何實作的?計算屬性快取原理以及洋蔥模型的應用?在初始化Vue實體時,我們會給每個計算屬性都創建一個對應watcher,我們稱之為計算屬性watcher ......

    uj5u.com 2023-04-20 08:01:31 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:01:10 more
  • http1.1與http2.0

    一、http是什么 通俗來講,http就是計算機通過網路進行通信的規則,是一個基于請求與回應,無狀態的,應用層協議。常用于TCP/IP協議傳輸資料。目前任何終端之間任何一種通信方式都必須按Http協議進行,否則無法連接。tcp(三次握手,四次揮手)。 請求與回應:客戶端請求、服務端回應資料。 無狀態 ......

    uj5u.com 2023-04-20 08:00:32 more