JS实现水印

本文介绍了一种使用JavaScript和CSS来实现实时旋转水印的方法。不同于传统的背景图片方式,该方法通过创建多个带有文本的div元素并应用特定样式,使其作为页面上的水印显示。文章还提供了一个示例函数createWaterMark,可以为页面添加包含当前日期的水印。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

JS实现水印

前段时间因项目有个需求需要在页面加上水印,查了一下资料,网上介绍的方法大都都是通过背景图片实现的,而我想通过div实现。


CSS样式

.watermark{
    opacity: 0.4;
    position: fixed;
    height: 45px;
    width: 160px;
    transform: rotate(315deg);
    -ms-transform: rotate(315deg);
    -moz-transform: rotate(315deg);
    -webkit-transform: rotate(315deg);
    -o-transform: rotate(315deg);
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
     user-select: none;
     pointer-events: none;
}

.watermark p{
    color: #dcdcdc;
}

js

/**
 * 水印
 * @param userName
 */
function createWaterMark(name){

    if(!name){
        return ;
    }
    var width = document.body.clientWidth;
    var height = document.body.clientHeight;

    var len = width/80;
    len = len.toFixed(0);
    var hen = height/80;
    hen = hen.toFixed(0);
    var init_top = 30;
    var dif_heigth = 0;
    if(height<1000){
        dif_heigth = height/3;
    }else {
        dif_heigth = height/8;
    }
    for(var j=0;j<hen;j++){
        for(var i=0;i<4;i++){
            var div =document.createElement("div");
            var p = document.createElement("p");
            p.innerHTML = name+getCurDate();
            div.setAttribute("class","watermark");
            div.style.marginLeft = (20+(i*width/4))+"px";
            div.style.top = (init_top+j*dif_heigth)+"px";

            div.appendChild(p);
            document.body.appendChild(div);
        }
    }
}



//获取当前日期
function getCurDate() {
    var date = new Date();
    var seperator1 = "-";
    var month = date.getMonth() + 1;
    var strDate = date.getDate();
    if (month >= 1 && month <= 9) {
        month = "0" + month;
    }
    if (strDate >= 0 && strDate <= 9) {
        strDate = "0" + strDate;
    }
    var currentdate = date.getFullYear() + seperator1 + month + seperator1 + strDate;
    return currentdate;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值