vue-teleporter
v1.0.1
Published
一种 Vue 组件函数式渲染方案,允许开发者在调用/使用阶段,函数式地传送/渲染/挂载 Vue 组件。A functional rendering scheme for Vue components, allowing developers to teleport/render/mount Vue components in a functional way during the call/use phase.
Downloads
2
Readme
vue-teleporter
Introduction
Vue-teleporter is a functional rendering scheme for Vue components, allowing developers to teleport/render/mount Vue components in a functional way during the call/use phase.
Cooperate with await/promise to code in a process oriented manner, reducing developers' burden of maintaining the mount points, visibility, data flow and other pain points of traditional modal boxes (declaratively write down pop-up components in advance).
Interface
The package vue-teleporter exposes a container component and two functions:
teleport
is consistent with the input parameters ofh
,teleport
can be understood as the alias ofh
;teleport
will directly render the teleported component into the container and return to the manual unmount function;- Emitting a
return
event on the teleported component will cause it to be unmounted; - If the
return
event listener is defined, it will be called when the teleported component is unmounted.
If you are completely unfamiliar with the h function, you can first read the corresponding documents of Vue2 or Vue3 versions to have a general impression of its input data structure, but this is not necessary.
Life Cycle
Convention: when the teleported component
emits
areturn
event, the vue-teleporter considers that it has completed the task of collecting data, and automatically unmounts/destroys it.The
teleport
function returns anunmount
function. Calling it will forcibly unmount the previously teleported single component, and the incoming parameters will also be forwarded to thereturn
event listener.vue-teleporter also exposes the
unmountAllTeleportedComponents
method, which can be called when the project route changes to unmount all teleported components.Internally, it is guaranteed that the
return
event listener will be called only once (it is necessary and sufficient for the teleported component to be unmounted and thereturn
event listener to be called).
Get Started Quickly
install:
npm i vue-teleporter
In App.vue or other suitable place to insert the Teleported Component Container:
<!-- Vue2/Vue3 -->
<template>
<div id="app">
...
<TeleportedComponentContainer></TeleportedComponentContainer>
</div>
</template>
<!-- Vue3 only -->
<template>
<div id="app">
...
</div>
<teleport>
<TeleportedComponentContainer></TeleportedComponentContainer>
</teleport>
</template>
<script>
import {TeleportedComponentContainer} from 'vue-teleporter';
export default {
name: 'App',
components: {
TeleportedComponentContainer,
}
}
</script>
use the teleport
method to teleport/render/mount a component (to the Teleported Component Container):
import MyConfirm from '... MyConfirm.vue';
import {teleport} from 'vue-teleporter';
async function my_Vue2_confirm(message): Promise<boolean> {
return new Promise(function (resolve) {
var manualUnmount = teleport(MyConfirm, {
props: {
message,
},
on: {
return($event) {
resolve($event);
},
},
});
});
}
async function my_Vue3_confirm(message): Promise<boolean> {
return new Promise(function (resolve) {
var manualUnmount = teleport(MyConfirm, {
message,
onReturn($event) {
resolve($event);
}
});
});
}
Emitting a return
event on the teleported MyConfirm.vue component:
<template>
<div style="
position: fixed; top: 50vh; left: 50vw; translate: -50% -50%;
padding: 1em; box-shadow: 0 0 .5em #aaa;"
>
<p>
{{ message }}
</p>
<div>
<button @click="$emit('return', false);">Cancel</button>
<button @click="$emit('return', true);">Ok</button>
</div>
</div>
</template>
<script>
export default {
props: ['message']
}
</script>
After the event listener in my_Vue_confirm function is triggered (gets the business result), you can continue to execute the subsequent logic. When the teleported component emits a return event, it will be unmounted automatically by vue-teleporter.
Best Practices
teleport
function returns a new function, which can be called to unmount the teleported component:
async function my_Vue3_confirm(message): Promise<boolean> {
return new Promise(function (resolve) {
var manualUnmount = teleport(MyConfirm, {
message,
onReturn($event) {
resolve($event);
}
});
// Manually unmount the teleported component without operation within 5 seconds.
setTimeout(function () {
manualUnmount(false); // It is deemed to be canceled.
}, 5_000);
});
}
When the route changes, call the unmountAllTeleportedComponents
function to unmount all teleported components:
import {unmountAllTeleportedComponents} from 'vue-teleporter';
router.beforeEach(function (to, from, next) {
setTimeout(unmountAllTeleportedComponents);
next();
});
In this case, when the return event listener is called back, there is no input parameter.
Use JSX syntax:
setTimeout(teleport(
<div
style="
position: fixed; top: 1em; right: 1em;
z-index: 9999; background-color: #eee;
"
>
Prompt information, automatically close after 3 seconds.
</div>
), 3000);
You may think that you can continue to encapsulate a set of UI frameworks.
It is unnecessary. Please consider directly reusing third-party modal box components:
<template>
<el-dialog :visible="true" @close="$emit('return', false);">
<p>
{{ message }}
</p>
<div>
<button @click="$emit('return', false);">Cancel</button>
<button @click="$emit('return', true);">Ok</button>
</div>
</el-dialog>
</template>
<script>
export default {
props: ['message']
}
</script>
Now we don't need to pay attention to the visible attribute, It is always true during the life cycle of teleported components.