• 后台管理系统加水印(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() //全局加水印

    操作完看看效果吧!!!

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

  • 相关阅读:
    panads基础入门
    理解深度可分离卷积
    网上商城项目(购物车下单、支付)
    python 文件查找性能对比 python与powershell
    [LMKD] [Android] 进程OomAdj调整分析:OomAdj调整次数(2)
    【React实战】create-react-app整合electron打造第一个桌面app
    k8s笔记19--grafana配置node监控面板
    入门力扣自学笔记76 C++ (题目编号324)
    FRED应用:激光二极管光源耦合到光纤的仿真
    Zookeeper系列文章—入门
  • 原文地址:https://blog.csdn.net/m0_63788547/article/details/137963167