如何正确地从Typescript的父组件继承?

问题描述

我将Vue v2与Typescript一起使用,并且尝试扩展父类

我的父类称为BaseSelect,看起来像这样:

<template>
  <select :value="value" @change="$emit('change',$event.target.value)">
    <option value="">default option</option>
    <slot />
  </select>
</template>

<script lang="ts">
import { Component,Model,Vue } from 'vue-property-decorator';

@Component({})
export default class BaseSelect extends Vue {
  @Model('change',{ type: String,required: false,default: '' })
  private readonly value!: string

  private valid = true;

  validate(): boolean {
    this.valid = !!this.value;
    return this.valid;
  }
}
</script>

我的孩子班级BaseSelectGender如下:

<template>
  <base-select :value="value" @change="$emit('change',$event)">
    <option value="male">I'm male</option>
    <option value="female">I'm female</option>
  </base-select>
</template>

<script lang="ts">
import { Component } from 'vue-property-decorator';
import { BaseSelect } from '@/components/base';

@Component({
  components: { BaseSelect },})
export default class BaseSelectGender extends BaseSelect {}
</script>

当我在代码中使用<base-select-gender>时,有BaseSelect组件的两个实例(因此,valid变量的两个不同实例):

  1. 由于继承而创建的第一个实例
  2. 由于子级中使用<base-select>而创建的第二个实例

valid变量更改时,这会导致一些问题,因为该变量的错误实例反映在DOM中。

现在我的问题是:如何扩展基类并使用它,或者至少扩展子组件模板部分中的HTML代码

解决方法

解决方法

所以我找到了一种解决方法,我使用 ref 属性来访问“内部”组件(template 部分中的那个)的属性和方法。

这允许我手动同步我需要的所有属性(确保这些属性不是 private)。

我的 BaseSelectGender 组件现在看起来像这样:

<template>
  <base-select 
    :value="value" 
    @change="$emit('change',$event)"
    v-bind="{ ...$attrs,...$props }"
    ref="inner"
  >
    <option value="male">I'm male</option>
    <option value="female">I'm female</option>
  </base-select>
</template>

<script lang="ts">
import { Component } from 'vue-property-decorator';
import { BaseSelect } from '@/components/base';

@Component({
  components: { BaseSelect }
})
export default class BaseSelectGender extends BaseSelect {
  get inner() {
    return this.$refs.inner as BaseSelect;
  }

  setValid(valid: boolean) {
    this.valid = valid;
    this.inner.setValid(valid);
  }

  validate(): boolean {
    this.valid = this.inner.validate();
    return this.valid;
  }
}
</script>

专业提示:使用 v-bind="{ ...$attrs,...$props }" 将所有属性和 props 从外部组件传递到内部组件。