美文网首页前端开发那些事儿
组件二次封装继承组件的属性、方法和插槽

组件二次封装继承组件的属性、方法和插槽

作者: O槑頭槑腦 | 来源:发表于2021-01-04 21:45 被阅读0次

一、vue2.0使用方法

  • 1、通过 v-on="$listeners" 接受父级传递的方法传给子组件
    <van-cell-group>
      <van-field v-model="value" label="文本" placeholder="请输入用户名" v-on="$listeners">
      </van-field>
    </van-cell-group>
    
    • $listeners包含了父作用域中的 (不含 .native 修饰器的) v-on 事件监听器。它可以通过 v-on="$listeners" 传入内部组件——在创建更高层次的组件时非常有用。
  • 2、通过v-bind="$attrs" 接受父级传递的属性传递给子组件
    <van-cell-group>
      <van-field v-model="value" label="文本" placeholder="请输入用户名" v-bind="$attrs">
      </van-field>
    </van-cell-group>
    
    • $attrs包含了父作用域中不作为 prop 被识别 (且获取) 的 attribute 绑定 (class 和 style 除外)。当一个组件没有声明任何 prop 时,这里会包含所有父作用域的绑定 (class 和 style 除外),并且可以通过 v-bind="$attrs" 传入内部组件——在创建高级别的组件时非常有用。
  • 3、继承slot
    使用 $slots
    <van-cell-group>
      <van-field v-model="value" label="文本" placeholder="请输入用户名">
        <template v-for="(index, name) in $slots" :slot="name">
          <slot :name="name" />
        </template>
      </van-field>
    </van-cell-group>
    

使用完整示例

  • son.vue子页面二次封装其他组件
<template>
  <div>
    <van-cell-group>
      <van-field v-model="value" label="文本" placeholder="请输入用户名" v-bind="$attrs" v-on="$listeners">
       <template v-for="(index, name) in $slots" v-slot:[name]>
          <slot :name="name"/>
        </template>
      </van-field>
    </van-cell-group>
    <div>
      {{test}}
      <slot name="sonSlot"></slot>
    </div>
  </div>
</template>
<script>
import { Field } from 'vant'
export default {
  name: 'son',
  data () {
    return {
      value: '测试数据'
    }
  },
  created () {},
  props:{
    test: {
      default: '123',
      type: String
    }
  },
  components: {
    Field
  },
  computed: {},
  mounted () {},
  methods: {},
}
</script>
<style lang='scss' scoped>
</style>
  • 父级页面引用子组件
<template>
  <div id="app">
    <son :test="name" :maxlength="14" @focus="focus" :border="false">
      <p>测试测试测试</p>
      <div slot="label">左边label测试</div>
      <div slot="left-icon">
        <van-icon name="cart" />
      </div>
      <div slot="sonSlot"> 的恢复上课</div>
    </son>
  </div>
</template>
<script>
import son from './components/son'
export default {
  components: {
    son
  },
  data () {
    return {
      name: '123123'
    }
  },
  methods: {
    focus () {
      console.log('聚焦')
    }
  }
}
</script>
<style lang='scss' scoped>
</style>

二、vue3.0使用

$listeners对象在 Vue 3 中已被移除。现在事件监听器是 attrs 的一部分。 在 Vue 3 的虚拟 DOM 中,事件监听器现在只是以 on 为前缀的 attribute,这样就成了attrs 对象的一部分。

<van-field label="文本" placeholder="请输入用户名" v-bind="$attrs" />
  • 2、获取slot用 $slots

$slots 用来访问被插槽分发的内容

<van-field label="文本" placeholder="请输入用户名">
 <template v-for="(index, name) in $slots" v-slot:[name]>
   <slot :name="name"></slot>
 </template>
</van-field>

vue3.0使用完整示例

  • son.vue 子页面封装第三方组件
<template>
 <div>
     <van-field label="文本" placeholder="请输入用户名" v-bind="$attrs">
       <template v-for="(index, name) in $slots" v-slot:[name]>
         <slot :name="name"></slot>
       </template>
     </van-field>
   <div>
     {{msg}}
     <slot></slot>
   </div>
 </div>
</template>

<script>
export default {
 name: 'son',
 props: {
   msg: String
 },
 data () {
   return {
     value: '',
   }
 },
 mounted() {
   console.log(this.$attrs)
   console.log(this.$slots)
 }
}
</script>

<!-- Add "scoped" attribute to limit CSS to this component only -->
<style scoped>
</style>

  • 父级页面引用子组件
<template>
   <Son :maxlength="14" @focus="focusEvent" :msg="msgText" v-model="value">
    <template #label>左边文字测试</template>
    <template v-slot:left-icon>
      <van-icon name="like-o" />
    </template>
    <template #default>sdjkfsdf</template>
  </Son>
</template>

<script>
import Son from './components/son.vue'

export default {
  name: 'App',
  components: {
    Son
  },
  data () {
    return {
      msgText: '测试数据',
      value: 'value测试'
    }
  },
  methods: {
    focusEvent () {
      console.log('聚焦')
    }
  },
}
</script>

相关文章

  • 组件二次封装继承组件的属性、方法和插槽

    一、vue2.0使用方法 1、通过 v-on="$listeners"[https://cn.vuejs.org/...

  • Vue3:Slot 插槽

    1、匿名插槽 1.1 什么是插槽 插槽(Slot)是 vue 为组件的封装者提供的能力。允许开发者在封装组件时,把...

  • 【前端Vue】05 - [插槽 ,前端模块化开发,webpack

    1. 插槽 1.1 插槽的基本使用 组件的插槽: 组件的插槽也是为了让我们封装的组件更加具有扩展性。 让使用者可以...

  • slot插槽

    组件的插槽:组件的插槽也是为了让我们封装的组件更加具有拓展性。预留空间,让使用者可以决定组件内部的内容展示。 在移...

  • 插槽-slot

    组件的插槽: (1)组件的插槽是为了让我们封装的组件更加具有扩展性; (2)让使用者可以决定组件内部的一些内容到底...

  • vue-插槽

    1. 什么是插槽 插槽(Slot)是 vue 为组件的封装者提供的能力。允许开发者在封装组件时,把不确定的、希望由...

  • React-Native 高阶组件

    高阶函数 高阶组件(属性代理)普通组件还可以向高阶组件传值 高阶组件(反向继承) 普通组件的 static 方法怎...

  • vue 插槽的使用、分类

    1. 什么是插槽 插槽(Slot)是vue为组件的封装者提供的能力。允许开发者在封装组件时,把不确定、希望由用户指...

  • slot插槽的使用

    1.匿名插槽 不指定名字 2.具名插槽(name属性是必填) 3.作用域插槽 (可以传递数据) 父组件: 子组件:

  • Flutter中Flex布局介绍

    在Flutter中,Row组件和Column组件都继承自Flex组件(1).Flex组件和Row、Column属性...

网友评论

    本文标题:组件二次封装继承组件的属性、方法和插槽

    本文链接:https://www.haomeiwen.com/subject/forvoktx.html