fix: propTypes.extend()方法已经废弃, 改为官方推荐的ES6+方法 (#2670)

Co-authored-by: 苗大 <caoshengmiao@hypergryph.com>
This commit is contained in:
Cherelle Spencer 2023-04-04 16:59:19 +08:00 committed by GitHub
parent 84a5fc1256
commit 02d41197b6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -1,5 +1,5 @@
import { CSSProperties, VNodeChild } from 'vue'; import { CSSProperties, VNodeChild } from 'vue';
import { createTypes, VueTypeValidableDef, VueTypesInterface } from 'vue-types'; import { createTypes, VueTypeValidableDef, VueTypesInterface, toValidableType } from 'vue-types';
export type VueNode = VNodeChild | JSX.Element; export type VueNode = VNodeChild | JSX.Element;
@ -8,8 +8,7 @@ type PropTypes = VueTypesInterface & {
readonly VNodeChild: VueTypeValidableDef<VueNode>; readonly VNodeChild: VueTypeValidableDef<VueNode>;
// readonly trueBool: VueTypeValidableDef<boolean>; // readonly trueBool: VueTypeValidableDef<boolean>;
}; };
const newPropTypes = createTypes({
const propTypes = createTypes({
func: undefined, func: undefined,
bool: undefined, bool: undefined,
string: undefined, string: undefined,
@ -18,17 +17,19 @@ const propTypes = createTypes({
integer: undefined, integer: undefined,
}) as PropTypes; }) as PropTypes;
propTypes.extend([ // 从 vue-types v5.0 开始extend()方法已经废弃当前已改为官方推荐的ES6+方法 https://dwightjack.github.io/vue-types/advanced/extending-vue-types.html#the-extend-method
{ class propTypes extends newPropTypes {
name: 'style', // a native-like validator that supports the `.validable` method
getter: true, static get style() {
type: [String, Object], return toValidableType('style', {
default: undefined, type: [String, Object],
}, });
{ }
name: 'VNodeChild',
getter: true, static get VNodeChild() {
type: undefined, return toValidableType('VNodeChild', {
}, type: undefined,
]); });
}
}
export { propTypes }; export { propTypes };