在新业务需求中,碰到这样一个场景,需要将后端返回的表格数据,保存至本地或者保存至剪切板,直接发送给用户使用。
1. 将内容转换成图片并保存至本地
1.1 交互效果
如图所示,想要点击复制按钮后,将下面这个图标转换成图片的形式,并保存至本地
1.2 实现代码
- 下载插件库:
yarn add html2canvas file-saver
html 页面设置
<el-button type="success" size="mini" @click="copyCharts">复制下面列表内容</el-button>
<el-table
id="savethepage"
...
>
...
</table>
js 实现逻辑
import html2canvas from 'html2canvas'
import { saveAs } from 'file-saver'
async copyCharts() {
const element: any = document.querySelector('#savethepage')
try {
const canvas = await html2canvas(element)
const imgUrl = canvas.toDataURL('image/png')
const blob = await fetch(imgUrl).then(res => res.blob())
saveAs(blob, 'screenshot.png')
} catch (error) {
console.error('Error:', error)
}
// 为确保操作,也可以使用让用户点击一下图表在进行保存,相当于一次内部才知道的确认操作
// element.addEventListener('click', async () => {
// try {
// const canvas = await html2canvas(element);
// const imgUrl = canvas.toDataURL('image/png');
// const blob = await fetch(imgUrl).then(res => res.blob());
// saveAs(blob, 'screenshot.png');
// } catch (error) {
// console.error('Error:', error);
// }
// });
}
2. 将页面内容转换成图片并复制到剪切板
2.1 交互效果
如图所示,想要点击复制按钮后,将下面这个图标转换成图片的形式,并复制到剪切板,当使用粘贴功能时,可以通过Command + V的形式直接粘贴出该图片
2.2 实现代码
html 页面设置
<el-button type="success" size="mini" @click="copyCharts">复制下面列表内容</el-button>
<el-table
id="savethepage"
...
>
...
</table>
js 逻辑
import html2canvas from 'html2canvas'
async copyCharts() {
const element: any = document.querySelector('#savethepage')
try {
const canvas = await html2canvas(element)
console.log(canvas, '生成canvas对象')
const imgUrl = canvas.toDataURL('image/png')
const blob = await fetch(imgUrl).then(res => res.blob())
await navigator.clipboard.write([
new ClipboardItem({
['image/png']: blob
})
])
} catch (error) {
console.error('Error:', error)
}
}
3. 实现逻辑及API使用
上述实现方式
- 我们先是通过 html2canvas 将DOM元素转换成canvas画布
- 之后使用canvas.toDataURL将canvas转换成base64图片地址
- 再生成图片的blob信息
- 通过blob信息进行图片保存至本地
saveAs
或剪切板navigator.clipboard.write
3.1 html2canvas
- html2canvas是一款开源的JavaScript库,用于将HTML页面渲染成一个Canvas元素,可以将整个页面或者特定的DOM元素转换为图片。可以使用它生成图片,用于分享等功能。
- 这种图片是根据DOM来的,我们可以将特定的DOM元素获取到,之后通过该API的处理,变成一张canvas画布
3.2 canvas.toDataURL
canvas.toDataURL(type, encoderOptions);
- type:生成图片类型,默认是PNG格式,图片分辨率为96dpi
- encoderOptions:范围 0~1,用来选定图片的质量,默认0.92,超出范围会自动被设置成默认值
- 返回值是一个数据url,是base64组成的图片的源数据、可以直接赋值给图片的src属性。
3.3 Navigator.clipboard
剪贴板 Clipboard API 为 Navigator 接口添加了只读属性 clipboard,该属性返回一个可以读写剪切板内容的 Clipboard 对象。在 Web 应用中,剪切板 API 可用于实现剪切、复制、粘贴的功能。
如果有用,点个赞呗~
总结用法,希望可以帮助到你,
我是Ably,你无须超越谁,只要超越昨天的自己就好~