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

理理Vue細(xì)節(jié)(推薦)

 更新時間:2019年04月16日 09:01:25   作者:陳煜侖  
這篇文章主要介紹了Vue細(xì)節(jié),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

 1. 動態(tài)屬性名:可使用表達(dá)式來設(shè)置動態(tài)屬性名或方法名:

<!-- 屬性name -->
<a :[name]="url"> ... </a>
<!-- 計算屬性sss和s -->
<img :[sss]="/img/test.png"/> 
<!-- 方法change1和change2 -->
<img :[change1()]="change2()"/>

data: {
  name: 'href',
  sss: 'src'
}

注意:要避免空格和引號等,且需要小寫,可使用計算屬性來應(yīng)對復(fù)雜表達(dá)式,都需要使用[]

2. computed/methods/watch

computed可使用get/set

 computed: {
    top() {
      return 'top'
    },
    name: {
      get () {
        return this.name
      },
      set (val) {
        this.name = val
      }
    }
  }

computed可緩存,但不可傳參,會根據(jù)data中的屬性變化而變化,即是根據(jù)響應(yīng)式依賴來變化,而Date不是響應(yīng)式依賴,即不會變化;method則每次都會進(jìn)行計算,但可傳參。

watch用于處理異步或開銷較大的操作,如輸入搜索時。

3. style綁定

  1. 直接對象或變量對象
  2. 計算屬性
  3. 直接style或style對象
<!-- 屬性名可加引號也可不加,屬性小駝峰 -->
<div :style="{ 'color': 'red', fontSize: fontSize + 'px' }">樣式3</div>
  1.  數(shù)組結(jié)合三目/數(shù)組結(jié)合對象
data: {
 isActive: true,
 activeClass: 'active'
}
<!-- 使用數(shù)組時變量和字符串需要通過引號來區(qū)分 -->
<div :class="[isActive ? activeClass : '', 'errorClass']"></div>
<!-- 使用對象時類名不加引號可表示變量也可表示字符串 -->
<div :class="[{ active: isActive }, 'errorClass']"></div>

 4. v-if條件渲染

可使用template包裹元素,template會被當(dāng)成不可見的包裹元素

<template v-if="ok">
  <h1>Title</h1>
  <p>Paragraph 1</p>
  <p>Paragraph 2</p>
</template>

多條件判斷

<div v-if="type === 'A'">
 A
</div>
<div v-else-if="type === 'B'">
 B
</div>
<div v-else-if="type === 'C'">
 C
</div>
<div v-else>
 Not A/B/C
</div>

5. key

添加key防止vue重復(fù)利用不想被重復(fù)利用的元素,如下的input如果不添加key,則vue會重復(fù)使用key,進(jìn)而input的value值在切換后還會被保留,因為vue僅僅替換了placeholder

<template v-if="loginType === 'username'">
 <label>Username</label>
 <input placeholder="Enter your username" key="username-input">
</template>
<template v-else>
 <label>Email</label>
 <input placeholder="Enter your email address" key="email-input">
</template>

6. v-if和v-show

v-if是組件的銷毀和重建,如果初始條件為false,則什么都不做,直到變?yōu)檎?,所以切換開銷高,運行條件很少改變時適用
v-show是display:none和block之間的CSS切換,基于渲染,不管初始條件如何都會渲染,所以初始渲染開銷高,切換頻率高時適用

7. v-for

  1. 可使用in或者of
  2. 也可遍歷對象:v-for="(value, key, index) in obj"
  3. 可根據(jù)template渲染多個組合元素:
<ul>
 <template v-for="item in items">
  <li>{{ item.msg }}</li>
  <li class="divider"></li>
 </template>
</ul>

8. v-for和v-if

v-for優(yōu)先級更高,所以v-if會重復(fù)運行于每個v-for循環(huán)中,所以盡量不要一起使用,可先使用計算屬性對數(shù)據(jù)進(jìn)行過濾再遍歷。

9. 更改響應(yīng)式數(shù)據(jù)

  1. Vue.set(object, key, value)
  2. this.$set(object, key, value)
  3. this.items.splice(index, 1, newValue)
  4. 批量添加屬性:
// 不要直接Object.assign(this.items, {age: 18}
this.items = Object.assign({}, this.items, {
 age: 18,
 favoriteColor: 'Vue Green'
})

10. 事件修飾符

  1. .passive:滾動的默認(rèn)事件會立即出發(fā),即告訴瀏覽器不想阻止默認(rèn)事件的觸發(fā),可提升移動端性能
<div :scroll.passive="onScroll">...</div>
  1. .capture:添加事件監(jiān)聽器時使用事件捕獲模式,即元素自身觸發(fā)的事件先在此處理,然后才交由內(nèi)部元素進(jìn)行處理
  2. .self:只當(dāng)在 event.target 是當(dāng)前元素自身時觸發(fā)處理函數(shù),即事件不是從內(nèi)部元素觸發(fā)的
  3. .once:點擊事件只會觸發(fā)一次
  4. 鍵盤修飾符:<input v-on:keyup.enter="submit">

11. v-model

選擇框

<!-- 單選框時,picked為字符串 "a",不是布爾值 -->
<input type="radio" value="a" v-model="picked">

<!-- 多選框時,toggle默認(rèn)值設(shè)為字符串或布爾值時得到布爾值,設(shè)為數(shù)組時得到的是value值-->
<input type="checkbox" value="b" v-model="toggle">

<!-- 當(dāng)選中第一個選項時,selected為字符串value的值 "abc" -->
<select v-model="selected">
 <option value="abc">ABC</option>
</select>

修飾符.lazy:在change時而非input時更新 <input v-model.lazy="msg" >

注:change事件是在input失去焦點時觸發(fā),即用于單選、多選框和選擇框,而input事件是在value值變化時觸發(fā),但腳本改變value值時不會觸發(fā),即用于text和textarea

修飾符.number:輸入值轉(zhuǎn)為數(shù)值

修飾符.trim:過濾收尾空白字符

12. Prop

使用v-bind="obj"會將對象的每個屬性都作為一個獨立的prop傳入進(jìn)去,所以接受時也需要逐個屬性接收。

<test v-bind="obj"></test>

props雖然是單向數(shù)據(jù)流,但對于引用類型,子組件還是可以改變父組件的狀態(tài)。

props會在組件實例創(chuàng)建之前進(jìn)行驗證,所以實例的屬性再default或validator中是不可用的。

13. 自定義事件

自定義事件需要注意事件名為小寫或-分隔,因為$emit('BaseEvent')雖然事件名不會變,但在html中該事件名會被轉(zhuǎn)化為小寫,不會監(jiān)聽到。

14. slot

具名插槽

<base-layout>
 <template v-slot:header>
  <h1>Here might be a page title</h1>
 </template>
<!-- 默認(rèn)插槽也可不用加上template和v-slot -->
 <template v-slot:default>
  <p>A paragraph for the main content.</p>
  <p>And another one.</p>
 </template>
 <template v-slot:footer>
  <p>Here's some contact info</p>
 </template>
</base-layout>

作用域插槽

<!-- current-user組件 -->
<span>
 <slot :user="user">
  {{ user.lastName }}
 </slot>
</span>

<!-- 父級組件通過自定義名稱訪問子級作用域 -->
<current-user>
 <template v-slot:default="slotProps">
  {{ slotProps.user.firstName }}
 </template>
</current-user>

<!-- 支持縮寫和解構(gòu) -->
<current-user>
 <template #default="{ user = { firstName: Gust } }">
  {{ user.firstName }}
 </template>
</current-user>

15. 組件通信

  1. vuex/eventBus
  2. prop/$emit
  3. $children/$parent
  4. provide/inject
  5. $refs
// 父或祖先級
provide: function () {
 return {
  getMap: this.getMap
 }
}

// 后代級
inject: ['getMap']

 16. scope

scoped 屬性會自動添加一個唯一的屬性 (比如 data-v-21e5b78) 為組件內(nèi) CSS 指定作用域,編譯的時候 .list-container:hover 會被編譯成類似 .list-container[data-v-21e5b78]:hover

17. 路由

區(qū)分:this.$router指路由器,this.$route指當(dāng)前路由

通配符:捕獲所有路由或 404 Not found路由

 // 含通配符的路由都要放在最后,因為優(yōu)先級由定義順序決定
{
 // 會匹配所有路徑
 path: '*'
}
{
 // 會匹配以 `/user-` 開頭的任意路徑
 path: '/user-*'
}

當(dāng)使用一個通配符時,$route.params內(nèi)會自動添加一個名為 pathMatch 參數(shù)。它包含了 URL 通過通配符被匹配的部分:

// 給出一個路由 { path: '/user-*' }
this.$router.push('/user-admin')
this.$route.params.pathMatch // 'admin'
// 給出一個路由 { path: '*' }
this.$router.push('/non-existing')
this.$route.params.pathMatch // '/non-existing'

點擊 <router-link :to="..."> 等同于調(diào)用 router.push(...)方法,因為<router-link>會在內(nèi)部調(diào)用該方法,進(jìn)而在history棧添加一個新的記錄

使用了push時,如果提供的path不完整,則params會被忽略,需要提供路由的 name 或手寫完整的帶有參數(shù)的 path:

const userId = '123'
router.push({ name: 'user', params: { userId }}) // -> /user/123
router.push({ path: `/user/${userId}` })     // -> /user/123
// 這里的 params 不生效
router.push({ path: '/user', params: { userId }}) // -> /user

router.push/router.replace/router.go 效仿于 window.history.pushState/window.history.replaceState/window.history.go

命名視圖:router-view可設(shè)置名字,如果router-view沒有設(shè)置名字,那么默認(rèn)為 default

<router-view></router-view>
<router-view name="a"></router-view>
<router-view name="b"></router-view>

const router = new VueRouter({
 routes: [
  {
   path: '/',
   components: {
    default: Foo,
    a: Bar,
    b: Baz
   } 
  }
 ]
})

路由使用props:可將路由參數(shù)設(shè)置為組件屬性

const User = {
 props: ['id'],
 template: '<div>User {{ id }}</div>'
}
// 通過布爾值設(shè)置
const router = new VueRouter({
 routes: [
  { path: '/user/:id', component: User, props: true },

  // 對于包含命名視圖的路由,你必須分別為每個命名視圖添加 `props` 選項:
  {
   path: '/user/:id',
   components: { default: User, sidebar: Sidebar },
   props: { default: true, sidebar: false }
  }
 ]
})

// 通過函數(shù)設(shè)置query 
// URL /search?q=vue 會將 {name: 'vue'} 作為屬性傳遞給 SearchUser 組件
const router = new VueRouter({
 routes: [
  { path: '/search', component: SearchUser, props: (route) => ({ name: route.query.q }) }
 ]
})

beforeRouteEnter:可使用beforeRouteEnter來提前獲取接口數(shù)據(jù),同時需要在next后才能訪問到實例:

beforeRouteEnter(to, from, next) {
 axios('/text.json').then(res => {
  next(vm => {
   vm.datas = res
  })
 })
}

路由設(shè)置有參數(shù)時,如果跳轉(zhuǎn)頁面后再通過返回鍵返回時,路由會保留有參數(shù),如果通過push跳轉(zhuǎn)返回,則不會保留該參數(shù),這在第三方調(diào)用模塊傳參時需要注意。

18. loader

Vue Loader編譯單文件的template塊時,會將所有遇到的URL資源轉(zhuǎn)為webpack模塊請求:

// <img src="../image.png">將會被編譯成為:
createElement('img', {
 attrs: {
  src: require('../image.png') // 現(xiàn)在這是一個模塊的請求了
 }
})

資源URL轉(zhuǎn)換規(guī)則

  1. 如果是絕對路徑,例如 /images/foo.png),則會原樣保留。
  2. 如果路徑以.開頭,將會被看作相對的模塊依賴,并按照你的本地文件系統(tǒng)上的目錄結(jié)構(gòu)進(jìn)行解析。
  3. 如果路徑以~開頭,其后的部分將會被看作模塊依賴。
  4. 如果路徑以 @ 開頭,也會被看作模塊依賴。

以上所述是小編給大家介紹的Vue細(xì)節(jié)詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • element-ui中table組件的toggleRowSelection()方法使用

    element-ui中table組件的toggleRowSelection()方法使用

    這篇文章主要介紹了element-ui中table組件的toggleRowSelection()方法使用,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue3中的 $attrs 與 Attributes 繼承

    vue3中的 $attrs 與 Attributes 繼承

    這篇文章主要介紹了vue3中的 $attrs 與 Attributes 繼承的相關(guān)資料,首先介紹了什么是Attributes 繼承,結(jié)合實例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧
    2024-02-02
  • VUE3中h()函數(shù)和createVNode()函數(shù)的使用解讀

    VUE3中h()函數(shù)和createVNode()函數(shù)的使用解讀

    這篇文章主要介紹了VUE3中h()函數(shù)和createVNode()函數(shù)的使用解讀,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue中使用file-saver導(dǎo)出文件的全過程記錄

    vue中使用file-saver導(dǎo)出文件的全過程記錄

    這篇文章主要給大家介紹了關(guān)于vue中使用file-saver導(dǎo)出文件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2022-02-02
  • 詳解關(guān)于Vue單元測試的幾個坑

    詳解關(guān)于Vue單元測試的幾個坑

    這篇文章主要介紹了關(guān)于Vue單元測試的幾個坑,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • Vue+Element?switch組件的使用示例代碼詳解

    Vue+Element?switch組件的使用示例代碼詳解

    這篇文章主要介紹了Vue+Element?switch組件的使用,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-06-06
  • Vue表單綁定的實例代碼(單選按鈕,選擇框(單選時,多選時,用 v-for 渲染的動態(tài)選項)

    Vue表單綁定的實例代碼(單選按鈕,選擇框(單選時,多選時,用 v-for 渲染的動態(tài)選項)

    本文通過實例代碼給大家介紹了Vue表單綁定(單選按鈕,選擇框(單選時,多選時,用 v-for 渲染的動態(tài)選項)的相關(guān)知識,非常不錯,具有一定的參考借鑒價值 ,需要的朋友可以參考下
    2019-05-05
  • vue2.0學(xué)習(xí)之a(chǎn)xios的封裝與vuex介紹

    vue2.0學(xué)習(xí)之a(chǎn)xios的封裝與vuex介紹

    最近在研究Vuex2.0,搞了好幾天終于有點頭緒了。下面這篇文章主要給大家介紹了關(guān)于vue2.0學(xué)習(xí)之a(chǎn)xios的封裝與vuex的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-05-05
  • 通過vue如何設(shè)置header

    通過vue如何設(shè)置header

    這篇文章主要介紹了通過vue如何設(shè)置header,每個項目都有頭部但是內(nèi)容不一樣;這種情況我們可以考慮在app.vue中創(chuàng)建公共頭部,那么怎么配置公共頭部header,下面小編通過實例代碼詳細(xì)講解,需要的朋友可以參考下
    2023-02-02
  • vue如何使用vue slot封裝公共組件

    vue如何使用vue slot封裝公共組件

    這篇文章主要介紹了vue如何使用vue slot封裝公共組件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-05-05

最新評論