vue 使用class創(chuàng)建和清除水印的示例代碼
更新時間:2020年12月25日 10:14:02 作者:紫藤蘿yu
這篇文章主要介紹了vue 使用class創(chuàng)建和清除水印的示例代碼,幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下
頁面添加水印的方法有很多,以下舉例使用class定義的方法進行水印內容渲染:
1、新建文件:WatermarkClass.js
export default class WatermarkClass {
constructor({id="watermarkID", str = "", fontSize = 18, width = 400, height = 400, fillStyle="#333333", opacity = 1 }) {
this.id = id;
this.str = str;
this.fontSize = fontSize;
this.width = width;
this.height = height;
this.fillStyle = fillStyle
this.opacity = opacity;
}
// 繪制水印
draw() {
if (document.getElementById(this.id) !== null) {
document.body.removeChild(document.getElementById(this.id));
}
const canvas = document.createElement("canvas");
// 設置canvas畫布大小
canvas.width = this.width;
canvas.height = this.height;
const ctx = canvas.getContext("2d");
ctx.rotate(-(15 * Math.PI) / 180); // 水印旋轉角度
ctx.font = `${this.fontSize}px Vedana`;
ctx.fillStyle = this.fillStyle;
ctx.textAlign = "center";
ctx.textBaseline = "middle";
this.str.split(",").forEach((item, index) => {
ctx.fillText(item, canvas.width / 2, canvas.height / 2 + (index * this.fontSize + 10)); // 水印在畫布的位置x,y軸
});
const div = document.createElement("div");
div.id = this.id;
div.style.pointerEvents = "none";
div.style.top = "30px";
div.style.left = "10px";
div.style.opacity = this.opacity;
div.style.position = "fixed";
div.style.zIndex = "999999";
div.style.width = `${document.documentElement.clientWidth}px`;
div.style.height = `${document.documentElement.clientHeight}px`;
div.style.background = `url(${canvas.toDataURL("image/png")}) left top repeat`;
document.body.appendChild(div);
}
setOptions({fontSize = 18, width = 300, height = 300, opacity = 1, str = ""}) {
this.fontSize = fontSize;
this.width = width;
this.height = height;
this.fillStyle = fillStyle
this.opacity = opacity;
this.str = str;
this.draw();
}
// 繪制
render() {
this.draw();
window.onresize = () => {
this.draw();
};
}
// 移除水印
removeWatermark() {
if (document.getElementById(this.id) !== null) {
document.body.removeChild(document.getElementById(this.id));
}
}
}
2、在頁面種引入使用:
import watermarkClass from "@/libs/watermarkClass";
export default {
name: "App",
mounted: function () {
this.initWatermark()
},
methods: {
initWatermark() {
// 方法一
let watermark = new watermarkClass({
id: "watermarkID",
str: "紫藤蘿-watermarkClass",
fontSize: 20,
width: 300,
height: 200,
fillStyle: "#dddddd",
opacity: 0.4,
});
watermark.render();
// 5秒后,清除水印
setTimeout(() => {
watermark.removeWatermark();
}, 5000);
}
},
};
以上就是vue 使用class創(chuàng)建和清除水印的示例代碼的詳細內容,更多關于vue 創(chuàng)建和清除水印的資料請關注腳本之家其它相關文章!
相關文章
vue+element搭建后臺小總結 el-dropdown下拉功能
這篇文章主要為大家詳細介紹了vue+element搭建后臺小總結,el-dropdown下拉功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-09-09
Vue.js項目實戰(zhàn)之多語種網站的功能實現(租車)
這篇文章主要介紹了Vue.js項目實戰(zhàn)之多語種網站(租車)的功能實現 ,需要的朋友可以參考下2019-08-08
解決vue與node模版引擎的渲染標記{{}}(雙花括號)沖突問題
這篇文章主要介紹了解決vue與node模版引擎的渲染標記{{}}(雙花括號)沖突問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09
vue中v-for和v-if一起使用之使用compute的示例代碼
這篇文章主要介紹了vue中v-for和v-if一起使用之使用compute的相關知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-05-05

