64 lines
2.6 KiB
TypeScript
64 lines
2.6 KiB
TypeScript
|
|
// 获取父组件的参数,因为支付宝小程序不支持provide/inject的写法
|
|||
|
|
// this.$parent在非H5中,可以准确获取到父组件,但是在H5中,需要多次this.$parent.$parent.xxx
|
|||
|
|
interface VueInstance {
|
|||
|
|
$parent?: VueInstance;
|
|||
|
|
$options?: { name?: string };
|
|||
|
|
[key: string]: any;
|
|||
|
|
}
|
|||
|
|
|
|||
|
|
/**
|
|||
|
|
* 获取父组件参数
|
|||
|
|
* @param this 当前组件实例
|
|||
|
|
* @param name 父组件name
|
|||
|
|
* @param keys 需要获取的参数名数组或对象
|
|||
|
|
* @returns 父组件参数对象
|
|||
|
|
*/
|
|||
|
|
export default function getParent(
|
|||
|
|
this: VueInstance,
|
|||
|
|
name: string,
|
|||
|
|
keys: string[] | Record<string, any>
|
|||
|
|
): Record<string, any> {
|
|||
|
|
let parent = this.$parent;
|
|||
|
|
// 通过while历遍,这里主要是为了H5需要多层解析的问题
|
|||
|
|
while (parent) {
|
|||
|
|
// 父组件
|
|||
|
|
if (parent.$options?.name !== name) {
|
|||
|
|
// 如果组件的name不相等,继续上一级寻找
|
|||
|
|
parent = parent.$parent;
|
|||
|
|
} else {
|
|||
|
|
const data: Record<string, any> = {};
|
|||
|
|
// 判断keys是否数组,如果传过来的是一个数组,那么直接使用数组元素值当做键值去父组件寻找
|
|||
|
|
if (Array.isArray(keys)) {
|
|||
|
|
keys.forEach(val => {
|
|||
|
|
data[val] = parent?.[val] ? parent[val] : '';
|
|||
|
|
});
|
|||
|
|
} else {
|
|||
|
|
// 历遍传过来的对象参数
|
|||
|
|
for (const i in keys) {
|
|||
|
|
// 如果子组件有此值则用,无此值则用父组件的值
|
|||
|
|
// 判断是否空数组,如果是,则用父组件的值,否则用子组件的值
|
|||
|
|
if (Array.isArray(keys[i])) {
|
|||
|
|
if (keys[i].length) {
|
|||
|
|
data[i] = keys[i];
|
|||
|
|
} else {
|
|||
|
|
data[i] = parent[i];
|
|||
|
|
}
|
|||
|
|
} else if (keys[i] && keys[i].constructor === Object) {
|
|||
|
|
// 判断是否对象,如果是对象,且有属性,那么使用子组件的值,否则使用父组件的值
|
|||
|
|
if (Object.keys(keys[i]).length) {
|
|||
|
|
data[i] = keys[i];
|
|||
|
|
} else {
|
|||
|
|
data[i] = parent[i];
|
|||
|
|
}
|
|||
|
|
} else {
|
|||
|
|
// 只要子组件有传值,即使是false值,也是“传值”了,也需要覆盖父组件的同名参数
|
|||
|
|
data[i] = keys[i] || keys[i] === false ? keys[i] : parent[i];
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return data;
|
|||
|
|
}
|
|||
|
|
}
|
|||
|
|
return {};
|
|||
|
|
}
|