• 后台管理系统加水印(react)


    效果

    代码图片

    代码

    1. window.waterMark = function (config) {
    2. var defaultConfig = {
    3. content: `我是水印`,
    4. fontSize: '16px',
    5. opacity: 0.3,
    6. rotate: '-15',
    7. color: '#ADADAD',
    8. modalId: 'J_waterMarkModalByXHMAndDHL',
    9. };
    10. config = Object.assign({}, defaultConfig, config);
    11. var existMarkModalDom = document.getElementById(config.modalId);
    12. if (existMarkModalDom) {
    13. document.body.removeChild(existMarkModalDom);
    14. }
    15. var markModalDom = document.createElement('div');
    16. markModalDom.setAttribute('id', config.modalId);
    17. markModalDom.style['position'] = 'fixed';
    18. markModalDom.style['top'] = 0;
    19. markModalDom.style['left'] = 0;
    20. markModalDom.style['bottom'] = 0;
    21. markModalDom.style['right'] = 0;
    22. markModalDom.style['background-color'] = 'transparent';
    23. markModalDom.style['pointer-events'] = 'none';
    24. markModalDom.style['z-index'] = 9999;
    25. markModalDom.style['overflow'] = 'hidden';
    26. var markContentDom = document.createElement('span');
    27. markContentDom.style['position'] = 'relative';
    28. markContentDom.style['display'] = 'inline-block';
    29. markContentDom.style['max-width'] = '33%';
    30. markContentDom.style['min-width'] = '400px';
    31. markContentDom.style['padding'] = '80px 0';
    32. markContentDom.style['height'] = '100px';
    33. markContentDom.style['text-align'] = 'center';
    34. markContentDom.style['opacity'] = config.opacity;
    35. markContentDom.style['pointer-events'] = 'none';
    36. var markContentTxtDom = document.createElement('span');
    37. markContentTxtDom.innerHTML = config.content;
    38. markContentTxtDom.style['position'] = 'absolute';
    39. markContentTxtDom.style['display'] = 'inline-block';
    40. markContentTxtDom.style['pointer-events'] = 'none';
    41. markContentTxtDom.style['top'] = '50%';
    42. markContentTxtDom.style['left'] = '80%';
    43. markContentTxtDom.style['transform'] = 'translate(-50%, -50%) rotate(' + config.rotate + 'deg)';
    44. markContentTxtDom.style['font-size'] = config.fontSize;
    45. markContentTxtDom.style['color'] = config.color;
    46. markContentDom.appendChild(markContentTxtDom);
    47. var contentHtml = markContentDom.outerHTML;
    48. var allContentHtml = '';
    49. for (var i = 0; i < 100; i++) {
    50. allContentHtml += contentHtml;
    51. }
    52. markModalDom.innerHTML = allContentHtml;
    53. document.body.appendChild(markModalDom);
    54. };

    使用方法

    • components文件夹下创建Watermark文件夹
    • Watermark文件夹下创建index.js文件
    • 将以上代码粘贴进去
    • 在项目入口文件引入   import './components/Watermark/index'

    • 直接调用   waterMark() //全局加水印

    操作完看看效果吧!!!

    注:本人前端小白 ,如有不对的地方还请多多指教

  • 相关阅读:
    Ascii码表
    【C++】常用遍历算法
    Sublime Text教程
    linux进程回收
    CodeLab:一款让你体验丝滑般的云化JupyterLab
    基于VR元宇宙技术搭建林业生态模拟仿真教学系统
    头歌——机器学习——逻辑回归如何实现分类
    Visual Studio 2019下编译OpenCV 4.7 与OpenCV 4.7 contrib
    【面试高频题】难度 2/5,回溯算法经典运用
    【已解决】Linux清空日志文件,再写入日志内容,出现^@字符
  • 原文地址:https://blog.csdn.net/m0_63788547/article/details/137963167