欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue實戰(zhàn)中的一些實用小魔法匯總

 更新時間:2021年06月15日 12:00:18   作者:EasyMoment23  
這篇文章主要給大家介紹了關(guān)于vue實戰(zhàn)中一些實用小魔法的相關(guān)資料,這些技巧和竅門,可以幫助你成為更好的Vue開發(fā)人員,需要的朋友可以參考下

能讓你首次加載更快的路由懶加載,怎么能忘?

路由懶加載可以讓我們的包不需要一次把所有的頁面的加載進來,只加載當(dāng)前頁面的路由組件就行。

舉個🌰,如果這樣寫,加載的時候會全部都加載進來。

const router = new VueRouter({
  routes:[
    {
      path: '/',
      name: 'Home',
      component: Home
    },
    {
      path: '/about',
      name: 'About',
      component: About
    }
  ]
})

所以,應(yīng)該避免上面的寫法,盡量使用懶加載

懶加載寫法,結(jié)合webpack的import食用

const router = new VueRouter({
  routes:[
    {
      path: '/',
      name: 'Home',
      component: () => import(/* webpackChunkName: "home" */ '../views/Home.vue')
    },
    {
      path: '/about',
      name: 'About',
      component: () => import(/* webpackChunkName: "about" */ '../views/About.vue')
    }
  ]
})

你是否還記得有一個叫Object.freeze的方法?

應(yīng)該所有同學(xué)都知道,vue初始化的時候會將data里面的數(shù)據(jù)都搞成響應(yīng)式數(shù)據(jù)吧。但是,我們在寫業(yè)務(wù)邏輯的時候會有些數(shù)據(jù)一初始化就永遠不會改變,它根本就不需要被vue做成響應(yīng)式數(shù)據(jù),因此我們應(yīng)該將這些不用改變的數(shù)據(jù)通過Object.freeze方法凍結(jié)它,避免vue初始化的時候,做一些無用的操作。

🌰

export default {
  data:()=>({
    list:Object.freeze([{title:'我永遠不需要改變,我不需要響應(yīng)式'}])
  })
}

異步組件那么強,你是不是沒用過?

異步組件可以讓我們在需要一些組件時才將它加載進來,而不是一初始化就加載進來,這跟路由懶加載時一個概念。

🌰

export default {
  components:{
    AsyncComponent:()=>import(/* webpackChunkName: "AsyncComponent" */ './Async')
  }
}

首次加載的包是不包含改組件代碼的

當(dāng)點擊觸發(fā)某種行為引進的包是這樣的

異步組件還有一種比較完善的寫法

🌰

export default {
  components:{
    AsyncComponent:()=>({
      component:import(/* webpackChunkName: "AsyncComponent" */ './Async'),
      delay:200, // 延遲幾毫秒,默認200
      timeout:3000, // 加載幾毫米之后就超時,觸發(fā)error組件
      loading:LoadingComponent, // 組件未加載回來前顯示
      error:ErrorComponent // 組件超時時顯示
    })
  }
}

你是不是還在computed中使用this?

我猜還有很多同學(xué),在computed屬性中通過this.xxx去拿data里面的數(shù)據(jù),和methods里面的方法吧,或許還會通過this.$store去拿vuex的state,和commit等,甚至,還會通過this.$route去獲取路由里面的數(shù)據(jù)吧。其實,我們可以避免這些丑陋的this,它甚至?xí)o我們帶來看不見的性能問題。實現(xiàn)上,我們通過this能訪問到的數(shù)據(jù),在computed的第一個參數(shù)上都能結(jié)構(gòu)出來。

🌰

export default {
   haha({$attrs,$route,$store,$listeners,$ref}){
     // 還能結(jié)構(gòu)很多屬性,可自行打印康康
     return 
   }
}

如何避免v-if和v-for一起使用?

為什么要避免v-if和v-for在同一個元素上同時使用呢?因為在vue的源碼中有一段代碼時對指令的優(yōu)先級的處理,這段代碼是先處理v-for再處理v-if的。所以如果我們在同一層中一起使用兩個指令,會出現(xiàn)一些不必要的性能問題,比如這個列表有一百條數(shù)據(jù),再某種情況下,它們都不需要顯示,當(dāng)vue還是會循環(huán)這個100條數(shù)據(jù)顯示,再去判斷v-if,因此,我們應(yīng)該避免這種情況的出現(xiàn)。

不好的🌰

    <h3 v-if="status" v-for="item in 100" :key="item">{{item}}</h3>

好的🌰

    <template v-if="status" >
        <h3 v-for="item in 100" :key="item">{{item}}</h3>
    </template>

那么強的.sync修飾符你為什么不用?

如果你想要在父組件控制一個子組件的顯示隱藏,是不是還在傳一個prop和一個自定義方法,這樣會很麻煩,不妨試一試sync修飾符。

🌰

 // 父組件
 
 template>
  <div>
    <Toggle :show.sync = 'show'></Toggle>
  </div>
</template>

//Toggle 組件

<template>
  <div>
    <div v-if="show">
    展示和隱藏組件
  </div>
  <button @click="test">隱藏組件</button>
  </div>
</template>
<script>

export default {
  props:['show'],
  methods: {
    test(){
      this.$emit('update:show',false)
    }
  }
}
</script>

$attr和$listeners讓你封裝組件如魚得水!

$attr和$listeners可能很多同學(xué)沒怎么去使用,其實它們讓我們對一些組件庫的組件二次封裝,非常好用的。

簡單介紹一下它們兩個:

$attr:如果一個組件不但傳了prop需要的屬性,還傳了prop之外的其他屬性,那么這些屬性都會被收集到$attr里面。

$listeners:如果一個組件傳了自定義事件,但子組件沒有通過emit觸發(fā),那么這些自定義方法都會被收集到$listeners里面。

這里舉一個對ElementUI的Tabel組件簡單的二次封裝的🌰

<el-table 
   v-bind="$attrs"
   v-on="$listeners">
   <template v-for="item in column">
    <el-table-column v-bind="item" />
   </template>
</el-table>
<script>
export default {
  props:{
      column:{
        type:Array,
        required:true
      }
   }
}
<script>

v-model還有這么好的修飾符!

v-model上有3個比較好用的修飾符不知到大家有沒有用過,一個是lazy,一個是number,一個是trim。

lazy:可以將@input事件變成@blur事件

number:只能輸入數(shù)字值

trim:清空兩邊的空格

🌰

   //lazy
   <input v-model.lazy="msg" />
   //number
   <input v-model.number="msg" />
   //trim
   <input v-model.trim="msg" />

你是否知道v-model還能自定義屬性?

如果想在一個自定義的Input組件上使用v-model,那么就要在子組件,介紹一個value,和觸發(fā)input事件,v-model的默認語法糖就是這兩個東西的組合。

🌰

// 父組件
<template>
  <div>
    <CustomInput v-model='msg' />
  </div>
</template>

//CustomInput

<template>
  <div>
    <input type="text" :value="value" @input="test">
  </div>
</template>
<script>
export default {
  props:['value'],
  methods: {
    test(e){
      this.$emit('input',e.target.value)
    }
  },
}
</script>

但是,如果組件里面不是input,而是一個checkbox或者一個radio呢?我不想接受一個value和input事件,我想接收一個更加語義化的checked和change事件,那該怎么辦?

🌰

// 父組件不需改變
...
//CustomInput
<template>
  <div>
    <input type="checkbox" :checked="checked" @change="test">
  </div>
</template>
<script>
 props:['checked'],
 model:{
    props:'checked',
    event:'change'
  },
  methods: {
    test(e){
      this.$emit('change',e.target.checked)
    }
  }
}
</script>

你還在用瀏覽器的scrollTop滾動你的頁面嗎?

有些時候我們在操作一下頁面的滾動行為,那么我們第一時間就會想到scrollTop。其實我們還有第二個選擇就是VueRouter給我們提供的scrollBehavior鉤子。

🌰

const router = new VueRouter({
  routes:[...] ,
  scrollBehavior(to,from,position){
      // position參數(shù)可自行打印康康,點擊瀏覽器左右箭頭會觸發(fā)
      return{
          // 這里可以返回很多參數(shù),下面簡單列就幾個,詳情自己康康官網(wǎng)
          x:100,
          y:100,
          selector:#app,
          offset:200,
          //等等
      }
  }
})

你在子組件上定義的原生事件不生效?

有時候我們想在子組件上面監(jiān)聽一些事件,比如click,但是不論你怎么點,它都沒反應(yīng),為什么呢?

🌰

<template>
    <div>
        <Child @click="test"></Child>
    </div>
</template>
<script>
    methods:{
        test(){}
    }
</script>

因為這樣寫vue會認為,你自定義了一個click事件,要在子組件通過$emit('click')觸發(fā)才行。如果我就是要在父組件觸發(fā)呢?那就要用到native修飾符了。

🌰

<template>
    <div>
        <Child @click.native="test"></Child>
    </div>
</template>
<script>
    methods:{
        test(){}
    }
</script>

用keep-alive緩存一下你的頁面狀態(tài)吧!

keep-alive可以幫助我們在切換組件的時候,保留上一個組件不被銷毀,它在管理后臺系統(tǒng)中比較常用。

🌰

<keep-alive>
    <router-view></router-view>
</keep-alive>

總結(jié)

到此這篇關(guān)于vue實戰(zhàn)中的一些實用小魔法的文章就介紹到這了,更多相關(guān)vue實戰(zhàn)技巧內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解Vue依賴收集引發(fā)的問題

    詳解Vue依賴收集引發(fā)的問題

    這篇文章主要介紹了Vue依賴收集引發(fā)的問題,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-04-04
  • vue實現(xiàn)商品多選功能

    vue實現(xiàn)商品多選功能

    這篇文章主要為大家詳細介紹了vue實現(xiàn)商品多選功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • 基于Vue實現(xiàn)文件拖拽上傳功能

    基于Vue實現(xiàn)文件拖拽上傳功能

    文件拖拽上傳功能現(xiàn)在已經(jīng)隨處可見,大家應(yīng)該都用過了吧,那么它具體是怎么實現(xiàn)的大家有去了解過嗎,今天我們一起來實現(xiàn)一下這個功能,并封裝一個拖拽上傳組件吧
    2024-03-03
  • Vue?elementUI表單嵌套表格并對每行進行校驗詳解

    Vue?elementUI表單嵌套表格并對每行進行校驗詳解

    element-ui中有詳細的各種表格及表格方法,下面這篇文章主要給大家介紹了關(guān)于Vue?elementUI表單嵌套表格并對每行進行校驗的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-01-01
  • Vue實現(xiàn)簡單可擴展甘特圖的方法詳解

    Vue實現(xiàn)簡單可擴展甘特圖的方法詳解

    Ganttastic是一個小型的Vue.js組件,用于在Web應(yīng)用程序上呈現(xiàn)一個可配置的、可拖動的甘特圖。本文就將用它來實現(xiàn)簡單可擴展的甘特圖,感興趣的可以嘗試一下
    2022-11-11
  • vue 中使用 watch 出現(xiàn)了如下的報錯的原因分析

    vue 中使用 watch 出現(xiàn)了如下的報錯的原因分析

    這篇文章主要介紹了vue 中使用 watch 出現(xiàn)了如下的報錯信息的原因分析及解決方法,本文附有代碼解決方案,非常不錯,需要的朋友可以參考下
    2019-05-05
  • Vue.js之render函數(shù)使用詳解

    Vue.js之render函數(shù)使用詳解

    這篇文章主要介紹了Vue.js之render函數(shù)使用詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-09-09
  • Vue開發(fā)Sort組件代碼詳解

    Vue開發(fā)Sort組件代碼詳解

    這篇文章主要介紹了Vue開發(fā)Sort組件,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2021-10-10
  • Vue數(shù)據(jù)增刪改查與表單驗證的實現(xiàn)流程介紹

    Vue數(shù)據(jù)增刪改查與表單驗證的實現(xiàn)流程介紹

    這篇文章主要介紹了Vue數(shù)據(jù)增刪改查與表單驗證的實現(xiàn),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-10-10
  • VueUse功能精簡你的dependencies

    VueUse功能精簡你的dependencies

    這篇文章主要為大家介紹了VueUse功能精簡你的dependencies實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07

最新評論