25 lines
610 B
TypeScript
25 lines
610 B
TypeScript
|
export function antPortal(Vue) {
|
||
|
return Vue.directive('ant-portal', {
|
||
|
inserted(el, binding) {
|
||
|
const { value } = binding;
|
||
|
const parentNode = typeof value === 'function' ? value(el) : value;
|
||
|
if (parentNode !== el.parentNode) {
|
||
|
parentNode.appendChild(el);
|
||
|
}
|
||
|
},
|
||
|
componentUpdated(el, binding) {
|
||
|
const { value } = binding;
|
||
|
const parentNode = typeof value === 'function' ? value(el) : value;
|
||
|
if (parentNode !== el.parentNode) {
|
||
|
parentNode.appendChild(el);
|
||
|
}
|
||
|
},
|
||
|
});
|
||
|
}
|
||
|
|
||
|
export default {
|
||
|
install: Vue => {
|
||
|
antPortal(Vue);
|
||
|
},
|
||
|
};
|