给页面添加水印

这里使用了vue中的自定义指令

  • main.js

      // vue 全局指令 --- 模块/组件式添加水印
      Vue.directive('watermark',(el,binding)=>{
        function addWaterMarker(str,parentNode,font,textColor){// 水印文字,父元素,字体,文字颜色
            var can = document.createElement('canvas');
            parentNode.appendChild(can);
            can.width = 150;
            can.height = 100;
            can.style.display = 'none';
            var cans = can.getContext('2d');
            cans.rotate(-20 * Math.PI / 180);
            cans.font = font || "13px Microsoft JhengHei";
            cans.fillStyle = textColor || "rgba(180, 180, 180, 0.2)";
            cans.textAlign = 'left';
            cans.textBaseline = 'Middle';
            cans.fillText(str, can.width / 14, can.height);
            parentNode.style.backgroundImage = "url(" + can.toDataURL("image/png") + ")";
        }
        addWaterMarker(binding.value.text, el, binding.value.font, binding.value.textColor)
      })
    
  • 使用(index.vue)

      <div class="maincont" v-watermark="{text: msgval, textColor:'#ddd'}">
            <div v-html="valtxt"></div>
    	</div>
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值