<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          Vue實(shí)戰(zhàn)中的一些小技巧

          共 8668字,需瀏覽 18分鐘

           ·

          2021-06-03 15:38

          作者:EasyMoment23

          juejin.cn/post/6966495817792389150

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

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

          舉個(gè)??,如果這樣寫,加載的時(shí)候會(huì)全部都加載進(jìn)來。

          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')
              }
            ]
          })

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

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

          ??

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

          異步組件那么強(qiáng),你是不是沒用過?

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

          ??

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

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

          ??

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

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

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

          ??

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

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

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

          那么強(qiáng)的.sync修飾符你為什么不用?

          如果你想要在父組件控制一個(gè)子組件的顯示隱藏,是不是還在傳一個(gè)prop和一個(gè)自定義方法,這樣會(huì)很麻煩,不妨試一試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>

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

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

          簡單介紹一下它們兩個(gè):

          attr里面。

          listeners里面。

          這里舉一個(gè)對(duì)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個(gè)比較好用的修飾符不知道大家有沒有用過,一個(gè)是lazy,一個(gè)是number,一個(gè)是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還能自定義屬性?

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

          ??

          // 父組件
          <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,而是一個(gè)checkbox或者一個(gè)radio呢?我不想接受一個(gè)value和input事件,我想接收一個(gè)更加語義化的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滾動(dòng)你的頁面嗎?

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

          ??

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

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

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

          ??

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

          因?yàn)檫@樣寫vue會(huì)認(rèn)為,你自定義了一個(gè)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可以幫助我們在切換組件的時(shí)候,保留上一個(gè)組件不被銷毀,它在管理后臺(tái)系統(tǒng)中比較常用。

          ??

          <keep-alive>
              <router-view></router-view>
          </keep-alive>
          瀏覽 36
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評(píng)論
          圖片
          表情
          推薦
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  四虎网站在线观看 | 国产无码精品区 | 国产一区二区三区视频在线播放 | 天堂在线8 | 琪琪先锋 torrent magnet 国产精品久久久久久久久久久久久免费看 |