亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

關于vue組件事件屬性穿透詳解

 更新時間:2019年10月28日 09:21:34   作者:莫西摩西  
今天小編就為大家分享一篇關于vue組件事件屬性穿透詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

組件事件屬性穿透

屬性

$attrs包含從父組件傳過來的屬性,但不包含子組件中prop中的屬性以及class和style,所以對于那些html元素原生屬性,可以不用再子組件中聲明,直接從父組件中傳進來就好

// 子組件
<template>
 <div>
   <input type="text" name="" id="" v-bind="$attrs" v-on='listeners'/>
 </div>
</template>
 props: {
  test: {
   type: String,
   default: '123456'
  }
 },
 created () {
  console.log(`props:%o`, this.$props) // {test: '測試'}
  console.log('attrs:%o', this.$attrs) // {value: '測試'}
 },

 // 父組件
 <myInput :value="value" :class="class_" :style='style' :test='test' @input1="input"/>
  data () {
  return {
   style: {
    color: 'red'
   },
   value: '測試',
   class_: 'test',
   test: '測試'
  }
 }

注意:

由于在這個組件中input并不是根元素,默認情況下父組件的不被認作 props 的特性綁定將會“回退”且作為普通的 HTML 特性應用在子組件的根元素上,在該例子中根節(jié)點div會有value="測試"的屬性,所以子組件需要設置 inheritAttrs: false去掉根元素默認行為,這樣就可以通過實例屬性 $attrs 可以讓這些特性生效,且可以通過 v-bind 顯性的綁定到非根元素上。

在子組件修改props,卻不會修改父組件,這是因為extractPropsFromVNodeData中是通過淺復制將父組件中數(shù)據(jù)傳遞給props的。 淺復制意味著在子組件中對對象和數(shù)組的props進行修改還是會影響父組件,這就違背了單向數(shù)據(jù)流的設計。因此需要避免這種情況出現(xiàn)。

事件

$listeners包含了父作用域中的 (不含 .native 修飾器的) v-on 事件監(jiān)聽器。它可以通過 v-on="$listeners" 傳入內部組件
 computed: {
  listeners () {
   return {
    ...this.$listeners,
    // 下面寫需要從子組件事件傳值到從父組件中的
    input: e => {
     this.$emit('input1', e.target.value)
    }
   }
  }
 },

以上這篇關于vue組件事件屬性穿透詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue項目在線上服務器訪問失敗原因分析

    vue項目在線上服務器訪問失敗原因分析

    這篇文章主要介紹了vue項目在線上服務器訪問失敗原因分析,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • Vue在 Nuxt.js 中重定向 404 頁面的方法

    Vue在 Nuxt.js 中重定向 404 頁面的方法

    這篇文章主要介紹了Vue在 Nuxt.js 中重定向 404 頁面的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • vue中音頻wavesurfer.js的使用方法

    vue中音頻wavesurfer.js的使用方法

    這篇文章主要為大家詳細介紹了vue中音頻wavesurfer.js的使用方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • Vue3+echarts5踩坑以及resize方法報錯的解決

    Vue3+echarts5踩坑以及resize方法報錯的解決

    這篇文章主要介紹了Vue3+echarts5踩坑以及resize方法報錯的解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • 如何解決this.$refs.form.validate()不執(zhí)行的問題

    如何解決this.$refs.form.validate()不執(zhí)行的問題

    這篇文章主要介紹了如何解決this.$refs.form.validate()不執(zhí)行的問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • vue+element表格導出為Excel文件

    vue+element表格導出為Excel文件

    這篇文章主要為大家詳細介紹了vue+element表格導出為Excel文件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • 關于vant折疊面板默認展開問題

    關于vant折疊面板默認展開問題

    這篇文章主要介紹了關于vant折疊面板默認展開問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue0.1的過濾代碼如何添加到Vue2.0直接使用

    Vue0.1的過濾代碼如何添加到Vue2.0直接使用

    Vue0.1的過濾代碼如何添加到Vue2.0直接使用,這篇文章主要介紹了過濾代碼添加到Vue2.0用的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-08-08
  • Vxe-Table開發(fā)中的各種坑以及避坑指南

    Vxe-Table開發(fā)中的各種坑以及避坑指南

    vxe-table是一個全功能的Vue表格,滿足絕大部分對Table的一切需求,與任意組件庫完美兼容,下面這篇文章主要給大家介紹了關于Vxe-Table開發(fā)中各種坑以及避坑的相關資料,需要的朋友可以參考下
    2022-09-09
  • 關于antd-vue?a-menu菜單綁定路由的相關問題

    關于antd-vue?a-menu菜單綁定路由的相關問題

    這篇文章主要介紹了關于antd-vue?a-menu菜單綁定路由的相關問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10

最新評論