<template>
<div>
<div @click="downs()">点击下载图片</div>
</div>
</template>
<script>
export default {
data(){
return{
}
},
methods:{
downloadIamge(imgsrc, name) {
//下载图片地址和图片名
var image = new Image();
// 解决跨域 Canvas 污染问题
image.setAttribute("crossOrigin", "anonymous");
image.onload = function() {
var canvas = document.createElement("canvas");
canvas.width = image.width;
canvas.height = image.height;
var context = canvas.getContext("2d");
context.drawImage(image, 0, 0, image.width, image.height);
var url = canvas.toDataURL("image/png"); //得到图片的base64编码数据
var a = document.createElement("a"); // 生成一个a元素
var event = new MouseEvent("click"); // 创建一个单击事件
a.download = name || "photo"; // 设置图片名称
a.href = url; // 将生成的URL设置为a.href属性
a.dispatchEvent(event); // 触发a的单击事件
};
image.src = imgsrc;
},
// 改downs这个函数就行,downloadIamge(‘图片下载地址’,图片名字)
downs() {
// 主要是为了名字不重复
var name = new Date().getTime();
this.downloadIamge('https://gimg2.baidu.com/image_search/src=http%3A%2F%2Fimg.jj20.com%2Fup%2Fallimg%2F4k%2Fs%2F02%2F2109242332225H9-0-lp.jpg&refer=http%3A%2F%2Fimg.jj20.com&app=2002&size=f9999,10000&q=a80&n=0&g=0n&fmt=auto?sec=1653725776&t=6e5c81216ab4ae15d426ed7529f33946', '二维码');
}
},
mounted(){
console.log(this.$store)
// console.log(this.$store.state.name)
}
}
</script>
<style scoped>
</style>
效果图