问题描述
我将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
变量的两个不同实例):
- 由于继承而创建的第一个实例
- 由于子级中使用
<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 从外部组件传递到内部组件。