vue#onErrorCaptured TypeScript Examples
The following examples show how to use
vue#onErrorCaptured.
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example #1
Source File: helper.ts From vue-i18n-next with MIT License | 4 votes |
export function mount(
targetComponent: Parameters<typeof createApp>[0],
i18n: I18n,
options: Partial<MountOptions> = {}
): Promise<Wrapper> {
const TargetComponent = targetComponent
const installI18n = isBoolean(options.installI18n)
? options.installI18n
: true
return new Promise((resolve, reject) => {
// NOTE: only supports props as an object
const propsData = reactive(
assign(
// @ts-ignore
initialProps(TargetComponent.props || {}),
options.propsData
)
)
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function setProps(partialProps: Record<string, any>) {
assign(propsData, partialProps)
return nextTick()
}
// eslint-disable-next-line @typescript-eslint/no-explicit-any
const slots: Record<string, (propsData: any) => VNode> = {}
const Wrapper = defineComponent({
emits: ['ready'],
setup(_props, { emit }) {
const componentInstanceRef = shallowRef<ComponentPublicInstance>()
onErrorCaptured(err => {
reject(err)
return true
})
return () => {
return h(
// eslint-disable-next-line @typescript-eslint/no-explicit-any
TargetComponent as any,
{
ref: componentInstanceRef,
onVnodeMounted() {
emit('ready', componentInstanceRef.value)
},
...propsData
},
slots
)
}
}
})
const app = createApp(Wrapper, {
onReady: (instance: ComponentPublicInstance) => {
resolve({ app, vm: instance, rootEl, setProps, html, find })
}
})
if (options.provide) {
const keys = getKeys(options.provide)
for (const key of keys) {
// eslint-disable-next-line @typescript-eslint/no-explicit-any
app.provide(key, options.provide[key as any])
}
}
if (options.components) {
for (const key in options.components) {
app.component(key, options.components[key])
}
}
if (options.slots) {
for (const key in options.slots) {
slots[key] = compileSlot(options.slots[key])
}
}
installI18n && app.use(i18n)
const rootEl = document.createElement('div')
document.body.appendChild(rootEl)
try {
app.mount(rootEl)
} catch (e) {
return reject(e)
}
function html() {
return rootEl.innerHTML
}
function find(selector: string) {
return rootEl.querySelector(selector)
}
activeWrapperRemovers.push(() => {
app.unmount()
rootEl.remove()
})
})
}