css 合同打印print--水印

最近做合同模板,发现原本的添加水印的方式出现了新bug。或者说原有的那种方式,忽略了一种特殊的情况:样式强加的打印页(page-break-after: always;)。

Q:利用js获取合同网页的宽高,来动态计算添加水印,强制打印页部分,水印未添加上?

A:

原因分析: 先附上原本的那种js动态添加水印的方式(通过js给网页加上水印背景),能解决大部分场景的需求。但是,它却没法计算到强加打印页的那部分高度,导致水印加不上。举个例子:合同模板一般后面都会需要添加一些附加内容,原因分析:

附件二 租赁房屋平面图

附件三 房屋来源证明文件复印件

附件四 实际居住人信息表

js动态加载添加的方式,会去获取合同网页的高度。这部分,它只能获取到5行文本的高度,但是,实际上打印时,附件二 租赁房屋平面图附件三 房屋来源证明文件复印件都是单独的占用了一个打印页的,这就导致多出来的那部分一大片空白没有水印。
解决思路: 改用样式背景来解决。用position:fixed;加重复背景图的方式,代码如下:

/*水印*/
        .watermark{
            /*display: none;*/
            position: fixed;
            z-index: -1;
            left: 0;
            top: 0;
            width: 100%;
            /*height: 1134px;*/
            height: 100%;
            background: url(https://i.loli.net/2019/11/07/A81MQihFL4vaoY7.png) repeat 0 0;
            background-size: 220px 220px;
        }

这种方式就能覆盖到每个打印页,不管是内容自动撑开的还是样式强加打印页的那种都可以。缺点:你需要更换图片,比如需要3种水印:合同草稿,已备案,已签约。那么就需要3个图片,每次改动需要修改图片。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值