Vue注意事項(xiàng)(遇到的坑)

要注意的細(xì)節(jié)

  • this.$nextTick是在下次 DOM 更新循環(huán)結(jié)束之后執(zhí)行延遲回調(diào),在修改數(shù)據(jù)之后使用 $nextTick,則可以在回調(diào)中獲取更新后的 DOM
// 如監(jiān)聽(tīng)某個(gè)數(shù)據(jù)變化,在數(shù)據(jù)變化后并且DOM也更新完,才執(zhí)行回調(diào)里面的內(nèi)容
watch() {
  // 監(jiān)聽(tīng)播放狀態(tài)
  playing(val) {
        const audio = this.$refs.audio
        this.$nextTick(() => {
          val ? audio.play() : audio.pause()
        })
      },
}
  • props 傳遞數(shù)組時(shí)設(shè)置default
props: {
      switches: {
        type: Array,
        default: () => []
      }
    },
  • 如果組件里用使用計(jì)時(shí)器
// 在組件銷(xiāo)毀時(shí)(即切換組件或關(guān)閉頁(yè)面),
// 調(diào)用destroyed方法清除計(jì)時(shí)器
destroyed(){
  clearTimeout(this.timer)
}
  • app.vue里給router-view外加keep-alive標(biāo)簽
// 好處 DOM會(huì)緩存在內(nèi)容中
// 切換導(dǎo)航時(shí)不會(huì)重復(fù)獲取數(shù)據(jù)
<keep-alive>
  <router-view></router-view>
</keep-alive>
  • 在 Vue 2.0 中,為自定義組件綁定原生事件必須使用 .native 修飾符:
<my-component @click.native="handleClick">Click Me</my-component>
  • filters 數(shù)據(jù)處理器,作用:在不改變的data 的情況下 輸出前段需要的格式數(shù)據(jù)。
{{ message | filterFun }}

new Vue({  
  // ...  
  filters: {  
    //  進(jìn)行格式轉(zhuǎn)換并返回
    filterFun: function (value) {  
      return value;
    }  

  }  
})  
//filter中可有傳多個(gè)參數(shù),默認(rèn)第一個(gè)為message的值,自定義參數(shù)從第二個(gè)開(kāi)始
filters: {  
    filterFun: function (value, sta1, sta2) {  
      return value;
    }  
  }  
  • .editorconfig 文件放在項(xiàng)目文件根目錄里(是代碼格式文件)

  • 事件綁定 :
    在 Vue 2.0 中,為自定義組件綁定原生事件必須使用 .native 修飾符:
    <my-component @click.native="handleClick">Click Me</my-component>

  • vue本地資源放到項(xiàng)目的 /static目錄下 ,才能引用(如圖片、js、css)

  • 引入組件 注意前面+./ 否則打包后可能讀取不到

import navTitle from './title.vue'

components:{
  navTitle
}
調(diào)用
<nav-title></nav-title>
  • 在vuejs2.0中,任何試圖在組件內(nèi)修改通過(guò)props傳入的父組件數(shù)據(jù)都被認(rèn)為是anti-pattern的,報(bào)以下錯(cuò)誤:
    Avoid mutating a prop directly since the value will be overwritten whenever the parent component re-renders

  • 計(jì)算屬性 是屬性 可以直接放入html里
  • 組件可以在data里定義常量 并用表達(dá)式賦值(不可以用函數(shù)賦值)
    如:獲取窗口寬度:

win_W: window.innerWidth || document.body.clientWidth

根組件綁定窗口改變事件
window.onresize = function(){
    _this_.win_W = window.innerWidth || document.body.clientWidth;
}
窗口改變時(shí),其他子組件也能得到
  • 子組件利用事件傳值,只能傳給上一級(jí)組件,如果需要傳給根組件,需要繼續(xù)定義、觸發(fā)事件
3級(jí)組件 ;  @click="trgSidebar"      
2級(jí)組件:   @trgSidebar="trgSidebar"
methods: {
    trgSidebar: () {
        this.$emit('trgSidebar');
    }
}
  • Vue 綁定class style 之類(lèi) 需要+ {}
<li :class="{ active: index ===0 }"></li>
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,563評(píng)論 6 544
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 99,694評(píng)論 3 429
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人,你說(shuō)我怎么就攤上這事。” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 178,672評(píng)論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我,道長(zhǎng),這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 63,965評(píng)論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 72,690評(píng)論 6 413
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 56,019評(píng)論 1 329
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,013評(píng)論 3 449
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 43,188評(píng)論 0 290
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 49,718評(píng)論 1 336
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 41,438評(píng)論 3 360
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 43,667評(píng)論 1 374
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,149評(píng)論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,845評(píng)論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 35,252評(píng)論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 36,590評(píng)論 1 295
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 52,384評(píng)論 3 400
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 48,635評(píng)論 2 380

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

  • 這篇筆記主要包含 Vue 2 不同于 Vue 1 或者特有的內(nèi)容,還有我對(duì)于 Vue 1.0 印象不深的內(nèi)容。關(guān)于...
    云之外閱讀 5,070評(píng)論 0 29
  • 下載安裝搭建環(huán)境 可以選npm安裝,或者簡(jiǎn)單下載一個(gè)開(kāi)發(fā)版的vue.js文件 瀏覽器打開(kāi)加載有vue的文檔時(shí),控制...
    冥冥2017閱讀 6,078評(píng)論 0 42
  • 1.安裝 可以簡(jiǎn)單地在頁(yè)面引入Vue.js作為獨(dú)立版本,Vue即被注冊(cè)為全局變量,可以在頁(yè)面使用了。 如果希望搭建...
    Awey閱讀 11,070評(píng)論 4 129
  • 此文基于官方文檔,里面部分例子有改動(dòng),加上了一些自己的理解 什么是組件? 組件(Component)是 Vue.j...
    陸志均閱讀 3,846評(píng)論 5 14
  • vue.js是什么 是一套構(gòu)建用戶(hù)界面的漸進(jìn)式框架 vue應(yīng)用組成 一個(gè) Vue 應(yīng)用由一個(gè)通過(guò)new Vue創(chuàng)建...
    多多醬_DuoDuo_閱讀 1,043評(píng)論 0 2