vue 微信页面添加水印

this.$nextTick(function() {
                                   watermark({ watermark_txt: "<div>" + '123' + "</div><div>" + '456' + "</div>"});
                               })

function watermark(settings) {
        //默认设置
        var defaultSettings={
          watermark_txt:"text",
          watermark_x:70,//水印起始位置x轴坐标
          watermark_y:10,//水印起始位置Y轴坐标
          watermark_rows:100,//水印行数
          watermark_cols:2,//水印列数
          watermark_x_space:60,//水印x轴间隔
          watermark_y_space:40,//水印y轴间隔
          watermark_color:'#aaa',//水印字体颜色
          watermark_alpha:0.3,//水印透明度
          watermark_fontsize:'.26rem',//水印字体大小
          watermark_width:60,//水印宽度
          watermark_height:60,//水印高度
          watermark_angle:10//水印倾斜度数
        };
        //采用配置项替换默认值,作用类似jquery.extend
        if(arguments.length===1&&typeof arguments[0] ==="object" )
        {
          var src=arguments[0]||{};
          for(key in src)
          {
            if(src[key]&&defaultSettings[key]&&src[key]===defaultSettings[key])
              continue;
            else if(src[key])
              defaultSettings[key]=src[key];
          }
        }
   
        var oTemp = document.createDocumentFragment();
   
        //获取页面最大宽度
        var page_width = Math.max(document.body.scrollWidth,document.body.clientWidth) - 30;
        //获取页面最大高度
//        var page_height = Math.max(document.body.scrollHeight,document.body.clientHeight);
        var page_height = Math.max($("#iContainer").get(0).clientHeight,document.body.clientHeight,$("#iContainer").get(0).scrollHeight) - 20;
//        var page_height = $("#iContainer").get(0).scrollHeight;
       // console.log(page_height,$("#iContainer").outerHeight());
        
   
        //如果将水印列数设置为0,或水印列数设置过大,超过页面最大宽度,则重新计算水印列数和水印x轴间隔
        if (defaultSettings.watermark_cols == 0 || (parseInt(defaultSettings.watermark_x + defaultSettings.watermark_width *defaultSettings.watermark_cols + defaultSettings.watermark_x_space * (defaultSettings.watermark_cols - 1)) > page_width)) {
          defaultSettings.watermark_cols = parseInt((page_width-defaultSettings.watermark_x+defaultSettings.watermark_x_space) / (defaultSettings.watermark_width + defaultSettings.watermark_x_space));
          defaultSettings.watermark_x_space = parseInt((page_width - defaultSettings.watermark_x - defaultSettings.watermark_width * defaultSettings.watermark_cols) / (defaultSettings.watermark_cols - 1));
        }
        //如果将水印行数设置为0,或水印行数设置过大,超过页面最大长度,则重新计算水印行数和水印y轴间隔
        if (defaultSettings.watermark_rows == 0 || (parseInt(defaultSettings.watermark_y + defaultSettings.watermark_height * defaultSettings.watermark_rows + defaultSettings.watermark_y_space * (defaultSettings.watermark_rows - 1)) > page_height)) {
          defaultSettings.watermark_rows = parseInt((defaultSettings.watermark_y_space + page_height - defaultSettings.watermark_y) / (defaultSettings.watermark_height + defaultSettings.watermark_y_space));
          defaultSettings.watermark_y_space = parseInt(((page_height - defaultSettings.watermark_y) - defaultSettings.watermark_height * defaultSettings.watermark_rows) / (defaultSettings.watermark_rows - 1));
        }
        var x;
        var y;
        for (var i = 0; i < defaultSettings.watermark_rows; i++) {
          y = defaultSettings.watermark_y + (defaultSettings.watermark_y_space + defaultSettings.watermark_height) * i;
          for (var j = 0; j < defaultSettings.watermark_cols; j++) {
            x = defaultSettings.watermark_x + (defaultSettings.watermark_width + defaultSettings.watermark_x_space) * j;
            var mask_div = document.createElement('div');
            mask_div.id = 'mask_div' + i + j;
            mask_div.className = 'mask_div';
            mask_div.innerHTML = defaultSettings.watermark_txt;
            
            //设置水印div倾斜显示
            mask_div.style.webkitTransform = "rotate(-" + defaultSettings.watermark_angle + "deg)";
            mask_div.style.MozTransform = "rotate(-" + defaultSettings.watermark_angle + "deg)";
            mask_div.style.msTransform = "rotate(-" + defaultSettings.watermark_angle + "deg)";
            mask_div.style.OTransform = "rotate(-" + defaultSettings.watermark_angle + "deg)";
            mask_div.style.transform = "rotate(-" + defaultSettings.watermark_angle + "deg)";
            mask_div.style.visibility = "";
            mask_div.style.position = "absolute";
//            mask_div.style.left = x + 'px';
            mask_div.style.top = y + 'px';
            mask_div.style.overflow = "hidden";
            mask_div.style.zIndex = "9999999";
            mask_div.style.pointerEvents = "none";
            mask_div.style.opacity = defaultSettings.watermark_alpha;
            mask_div.style.fontSize = defaultSettings.watermark_fontsize;
            mask_div.style.fontFamily = defaultSettings.watermark_font;
            mask_div.style.color = defaultSettings.watermark_color;
            mask_div.style.textAlign = "center";
//            mask_div.style.width = defaultSettings.watermark_width + 'px';
//            mask_div.style.height = defaultSettings.watermark_height + 'px';
            mask_div.style.lineHeight = '.32rem';
            mask_div.style.display = "inline-block";
            oTemp.appendChild(mask_div);
          };
        };
        console.log($('.mask_div:odd'));
        document.body.appendChild(oTemp);
        $('.mask_div:odd').css({left:defaultSettings.watermark_x + 'px'});
      $('.mask_div:even').css({right:defaultSettings.watermark_x + 'px'});
}

最新文章

  1. AVL的删除写法的一个错误
  2. python字符编码(二)
  3. JSON 教程学习进度备忘
  4. redo文件一
  5. Newtonsoft.Json工具类
  6. ZOOKEEPER在CENTOS6上的再安装
  7. 社区发现(Community Detection)算法 [转]
  8. OpenCV——改变图像大小
  9. Sql Server 查看所有存储过程或视图的位置及内容
  10. (原+转)ROC曲线
  11. React+Redux开发实战项目【美团App】,没你想的那么难
  12. 变位词(0029)-swustoj
  13. django-站点管理
  14. spring配置文件注入到静态变量
  15. 第十七篇-使用RadioGroup实现单项选择
  16. HTML&amp;javaSkcript&amp;CSS&amp;jQuery&amp;ajax-Css
  17. [原][openstack-pike][compute node][issue-1]openstack-nova-compute.service holdoff time over, scheduling restart.
  18. ubuntu下查看windows的 txt 文件乱码
  19. OpenMP 旅行商问题,静态调度
  20. Spring(十五)之声明式事务

热门文章

  1. excache.xml作用
  2. java中Long类型和long类型的大小比较
  3. Android进阶之绘制-自定义View完全掌握(一)
  4. Leetcode之二分法专题-1011. 在 D 天内送达包裹的能力(Capacity To Ship Packages Within D Days)
  5. Go 面试每天一篇(第 2 天)
  6. leetcode 刷题记录(java)-持续更新
  7. ElasticSearch专栏
  8. 微信小程序那些令人眼泪汪汪的坑儿
  9. HDU 4607 Park Visit 树的最大直径
  10. CQ18阶梯赛第二场