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

1. 能讓你首次加載更快的路由懶加載

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

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

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

應(yīng)該所有同學(xué)都知道芳撒,vue初始化的時(shí)候會(huì)將data里面的數(shù)據(jù)都搞成響應(yīng)式數(shù)據(jù)吧。但是未桥,我們?cè)趯憳I(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)酷师,你是不是沒用過讶凉?
異步組件可以讓我們?cè)谛枰恍┙M件時(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í)顯示
    })
  }
}

3. 你是不是還在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 
   }
}

4. 如何避免v-if和v-for一起使用拨脉?

為什么要避免v-if和v-for在同一個(gè)元素上同時(shí)使用呢哆姻?因?yàn)樵趘ue的源碼中有一段代碼時(shí)對(duì)指令的優(yōu)先級(jí)的處理,這段代碼是先處理v-for再處理v-if的玫膀。所以如果我們?cè)谕粚又幸黄鹗褂脙蓚€(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>

5. 那么強(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>

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

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

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

attr里面琼梆。

listeners里面性誉。

這里舉一個(gè)對(duì)ElementUI的Tabel組件簡(jiǎn)單的二次封裝的例子

<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>

7. 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)語(yǔ)法糖就是這兩個(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è)更加語(yǔ)義化的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>

8. 你還在用瀏覽器的scrollTop滾動(dòng)你的頁(yè)面嗎?

有些時(shí)候我們?cè)诓僮饕幌马?yè)面的滾動(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ù),下面簡(jiǎn)單列就幾個(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緩存一下你的頁(yè)面狀態(tài)吧爽柒!
keep-alive可以幫助我們?cè)谇袚Q組件的時(shí)候吴菠,保留上一個(gè)組件不被銷毀,它在管理后臺(tái)系統(tǒng)中比較常用浩村。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末做葵,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子心墅,更是在濱河造成了極大的恐慌酿矢,老刑警劉巖榨乎,帶你破解...
    沈念sama閱讀 207,113評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異瘫筐,居然都是意外死亡蜜暑,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,644評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門严肪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來史煎,“玉大人,你說我怎么就攤上這事驳糯∑螅” “怎么了?”我有些...
    開封第一講書人閱讀 153,340評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵酝枢,是天一觀的道長(zhǎng)恬偷。 經(jīng)常有香客問我,道長(zhǎng)帘睦,這世上最難降的妖魔是什么袍患? 我笑而不...
    開封第一講書人閱讀 55,449評(píng)論 1 279
  • 正文 為了忘掉前任,我火速辦了婚禮竣付,結(jié)果婚禮上诡延,老公的妹妹穿的比我還像新娘。我一直安慰自己古胆,他們只是感情好肆良,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,445評(píng)論 5 374
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著逸绎,像睡著了一般惹恃。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上棺牧,一...
    開封第一講書人閱讀 49,166評(píng)論 1 284
  • 那天巫糙,我揣著相機(jī)與錄音,去河邊找鬼颊乘。 笑死参淹,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的乏悄。 我是一名探鬼主播承二,決...
    沈念sama閱讀 38,442評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼纲爸!你這毒婦竟也來了亥鸠?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,105評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎负蚊,沒想到半個(gè)月后神妹,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,601評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡家妆,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,066評(píng)論 2 325
  • 正文 我和宋清朗相戀三年鸵荠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片伤极。...
    茶點(diǎn)故事閱讀 38,161評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡蛹找,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出哨坪,到底是詐尸還是另有隱情庸疾,我是刑警寧澤,帶...
    沈念sama閱讀 33,792評(píng)論 4 323
  • 正文 年R本政府宣布当编,位于F島的核電站届慈,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏忿偷。R本人自食惡果不足惜金顿,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,351評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望鲤桥。 院中可真熱鬧揍拆,春花似錦、人聲如沸茶凳。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,352評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)慧妄。三九已至顷牌,卻和暖如春剪芍,著一層夾襖步出監(jiān)牢的瞬間塞淹,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,584評(píng)論 1 261
  • 我被黑心中介騙來泰國(guó)打工罪裹, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留饱普,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,618評(píng)論 2 355
  • 正文 我出身青樓状共,卻偏偏與公主長(zhǎng)得像套耕,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子峡继,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,916評(píng)論 2 344

推薦閱讀更多精彩內(nèi)容