Vue based browser local printing or async template printing(基于vue的浏览器局部打印或模板/异步模板打印)
yarn add vue3-use-print
/**
* @param dom DOM元素
* @param options.before 打印之前回调
* @param options.after 打印之后回调
*/
export default function usePrint(
dom: HTMLElement,
options?: {
before?: Function;
after?: Function;
}
): void;
/**
* @param component vue组件
* @param props 组件props
* @param options.before 打印之前回调
* @param options.after 打印之后回调
* @param options.timeout 打印超时时间
*/
export default function usePrint(
component: ReturnType<typeof defineAsyncComponent>,
props?: Record<string, any>,
options?: {
before?: Function;
after?: Function;
timeout?: number;
}
): void;
<script setup lang="ts">
import { shallowRef, defineAsyncComponent } from 'vue'
import usePrint from 'vue3-use-print'
import LocalTemp from './template/LocalTemp.vue'
import ComponentTemp from './template/ComponentTemp.vue'
const AsyncCompTemp = defineAsyncComponent(() => import('./template/AsyncCompTemp.vue'))
const localTempRef = shallowRef()
</script>
<template>
<!-- 传递"DOM"元素进行打印 -->
<button @click="usePrint(localTempRef)">
local print(局部打印)
</button>
<div ref="localTempRef">
<PrintTemp />
</div>
<!-- 传递"Component"组件进行打印 -->
<el-button @click="usePrint(ComponentTemp)">
component print(模板打印)
</el-button>
<!-- 传递"Async Component"组件进行打印 -->
<el-button @click="usePrint(AsyncCompTemp)">
async print(异步模板打印)
</el-button>
</template>