使用Javascript实现网页水印(非图片水印)

作者:小菜 更新时间:2025-03-15 点击数:
简介:1.1 定义在一些B/S结构的应用系统中,有很多页面是需要有水印的。

常见的就是公文系统、合同系统等。

大家常常关注的是网站图片增加水印,而很少关注页面水印。

刚去G

【菜科解读】

1.1 定义

在一些B/S结构的应用系统中,有很多页面是需要有水印的。

常见的就是公文系统、合同系统等。

大家常常关注的是网站图片增加水印,而很少关注页面水印。

刚去Google了一圈,关于页面水印的文章的数量为几乎为0. 本文中,流牛木马就与大家一起交流一下有关制作网页水印的心得。

本文讨论以下的情形: 新增水印的方法需要用Javascript完成,并要求能够方便地加入到原有的页面中,不能影响到已有的功能。

1.2 预期目标

就图片水印实现方案来说,我们预期至少包括以下几个目标:

1. 实现悬浮、半透明的图片水印

2. 包含水印的页面,所有元素均为只读(不可写)

3. 在包含框架页面中,可以控制任意一个子页面或父页面的水印生成

4. 在页面放大、缩小(resize过程)后,需要在保证页面不刷新的前提下,重新生成适应页面大小的新水印,以保证所有内容都被水印覆盖,并且不会因水印图片范围过大而产生滚动条。

5. 支持IE6\7\8浏览器。

暂不考虑其他浏览器。

1.3 效果图

加密前:

加密后:

可以打开附件里的文件进行查看。

2 实现步骤2.1 基本构思

加密的过程是一个Javascript函数执行过程,所以我们首先应该考虑用Javascript操作DOM对象的方式。

在已有的HTML页面中,新建一个DOM对象在Body节点下。

该对象的长、宽均经过计算,保证在覆盖全部页面内容的同时又不产生滚动条。

将该对象覆盖到原有的页面之上,设置背景图,并设置为透明。

创建新DOM元素:

使用document对象里的createElement方法。

创建元素后,设置它的z-index为一个大整数,保证它能够比已有网页的最大z-index大,才能完成 覆盖 。

计算新对象大小:

利用三个DOM对象值: clientWidth 、scrollHeight与clientHeight.

网页中一般不会出现横向滚动条,故不使用scrollWidth.

而纵向的滚动条就很常见了。

为了保证页面内容全部覆盖,在未出现滚动条的时候,使用clientHeight,出现滚动条后,则使用scrollHeight。

设置透明:

利用Alpha值。

Alpha是IE支持的css filter。

2.2 应变细节

有一个小细节是很有意思的,前文也提过了,就是resize的过程。

试想,当一个页面打开的时候是550px 400px,那么自然会生成550px 400px大小的水印。

但当用户对它进行最大化时,页面没有刷新,不会重新执行生成水印的函数,那么以前生产的水印图片就太小了。

如下图所示的情况。

请注意,它的右侧、下侧都是没有水印的。

为了应对这种情况,我们就需要对body的onresize()函数进行处理。

如果以前定义没有onresize()函数,则直接添加onresize();如果以前有onresize()函数,则对之进行修改。

2.3 最终代码

考虑到框架页面需要考虑的情况,该方法包括三个参数: 目标页面对象、目标页面字符串、 背景图片。

function GetWaterMarked(targetObj,jpgUrl,targetStr ) {

var windowobj=targetObj;

var waterMarkPicUrl=jpgUrl;

var controlWindowStr=targetStr;

if(windowobj.document.getElementById("waterMark") != null)

return;

var m = "waterMark";

var newMark = windowobj.document.createElement("div");

newMark.id = m;

newMark.style.position = "absolute";

newMark.style.zIndex = "9527";

newMark.style.top = "0px";

newMark.style.left = "0px";

newMark.style.width = windowobj.document.body.clientWidth;

if( parseInt(windowobj.document.body.scrollHeight) > parseInt(windowobj.document.body.clientHeight) )

{

newMark.style.height = windowobj.document.body.scrollHeight;

}else

{

newMark.style.height = windowobj.document.body.clientHeight;

}

newMark.style.backgroundImage = "url("+ waterMarkPicUrl +")";

newMark.style.filter = "alpha(opacity=50)";

windowobj.document.body.appendChild(newMark);

var markStr = "var sobj ="+controlWindowStr+".document.getElementById('waterMark');sobj.style.width ="+controlWindowStr+".document.body.clientWidth;sobj.style.height ="+controlWindowStr+".document.body.clientHeight;";

if(windowobj.document.body.onresize != null)

{

var oldResiae = windowobj.document.body.onresize.toString();

var oldResiaeStr = oldResiae.substr(oldResiae.indexOf("{")+1);

var oldResiaeStr= oldResiaeStr.substr(0,oldResiaeStr.lastIndexOf("}"));

oldResiaeStr+=";"+markStr;

windowobj.document.body.onresize = new Function(oldResiaeStr);

}

else

{

windowobj.document.body.onresize = new Function(markStr);

}

}

3 原有页面处理需要在原有的标签处加入一个onload方法。

如:

4 附件http://files.cnblogs.com/azure/%E6%B0%B4%E5%8D%B0.rar

_________________________________________________________________________________

关于扩展到非IE浏览器:

有很多朋友问起如何扩展到非IE浏览器。

我文中有提到设置水印图片透明的方式,那是一种仅适用于IE的方式。

要在其他浏览器中的设置图片透明,也是很容易的。

我还没有做测试,请各位看官自行参考这篇帖子:

http://dancewithnet.com/2009/09/06/css-opacity/

使用,Javascript,实现,网页,水印,非,图片,概述

PPTV和百度开放平台合作实现即时播放</a> <a href="/comment_49647_1.h

细心的网民最近使用百度搜索视频,可能发现百度开放平台合作可以即时播放了.百度正式推出了应用开放平台,"PPTV直播"作为"百度娱乐"的重要内容位列该平台娱乐推荐榜首位。

据悉,网友在百度搜集框内搜集"湖南卫视直播"、"江苏卫视直播"、"东方卫视直播"等各大电视台的直播内容时,即可在搜集效果中,直接观看到PPTV提供的相关视频内容。

该项应用一出,便受到广大网民的一致好评。

下载地址: PPTV网络电视(PPLive)V3.5.1.0039去广告VIP版 百度搜集页面中PPTV直播效果 2010年上半年,网民数量高达3.84亿,我国网络视频市场规模为8.30亿元。

颠末奥运会、天下杯等重大事件的直播考验后,PPTV网络电视一跃成为网民生活中必不要少的观看平台。

这次,百度公司正式宣布推出全新的应用开放平台,以期推动更多互联网优质应用资源与网民需求直接对接,方便网民"即搜即用"。

这一理念与PPTV网络电视一直以来希望将更多及时的直播资讯精准传递给网民的目的不谋而合。

PPTV,和,百度,开放,平台,合作,实现,即时,播放,

如何使用U盘开机重装系统

想重装系统不会怎么办?菜科网一键重装系统轻松在线帮您搞定系统重装问题。

软件支持 在线重装、U盘制作、自定义重装 等多种模式。

简介:随着科技的快速发展,电脑已经成为我们日常生活中不可或缺的工具。

然而,由于各种原因,我们有时候需要重装系统以解决一些问题或提升电脑性能。

而使用U盘开机重装系统成为了一种快速且便捷的方法。

本文将为大家介绍如何使用U盘开机重装系统,帮助大家轻松解决系统问题。

工具原料:系统版本:Windows 10、Mac OS品牌型号:戴尔XPS、苹果MacBook Pro软件版本: Rufus 3.10、TransMac 14.1一、准备U盘和系统镜像文件1、首先,准备一根容量充足的U盘,一般来说,8GB的U盘就足够了。

2、然后,下载相应的系统镜像文件,可以通过官方网站或第三方软件下载合法的系统镜像文件。

3、使用Rufus等工具将系统镜像文件写入U盘。

二、设置电脑启动顺序1、连接准备好的U盘到需要重装系统的电脑上。

2、进入电脑的BIOS设置界面,一般是通过按下电源按钮后按下F2、F10或Delete键进入。

3、在BIOS设置界面中,找到启动选项并将U盘设置为首选启动设备。

4、保存设置并退出BIOS界面。

三、开机重装系统1、重新启动电脑,并按照屏幕上的提示按任意键进入系统安装界面。

2、选择语言、时区和键盘布局等设置,然后点击下一步。

3、接着,选择“自定义安装”或“清空并安装新系统”选项,根据个人需求选择适合自己的选项。

4、在磁盘选择界面,选择要安装系统的磁盘,并点击下一步开始安装系统。

四、总结通过使用U盘开机重装系统,我们可以轻松解决电脑系统问题,并提升电脑性能。

在操作过程中,注意保存重要数据,避免数据丢失。

同时,选择合适的系统镜像文件和工具版本也是非常重要的。

希望本文的介绍能够帮助大家快速掌握使用U盘开机重装系统的方法,让我们的电脑始终保持良好的运行状态。

标签: 注意:本站所刊载的文章均为学习交流之用,请勿用于商业用途。

对于商业使用,请联系各自版权所有者,否则法律问题自行承担。

Win7系统升级指南:全面解析升级步骤与要点 Win7系统损坏修复教程:详细步骤助你快速解决问题 简介:随着科技的快速发展,电脑已经成为我们日常生活中不可或缺的工具。

然而,由于各种原因,我们有时候需要重装系统以解决一些问题或提升电脑性能。

而使用U盘开机重装系统成为了一种快速且便捷的方法。

本文将为大家介绍如何使用U盘开机重装系统,帮助大家轻松解决系统问题。

工具原料:系统版本:Windows 10、Mac OS品牌型号:戴尔XPS、苹果MacBook Pro软件版本: Rufus 3.10、TransMac 14.1一、准备U盘和系统镜像文件1、首先,准备一根容量充足的U盘,一般来说,8GB的U盘就足够了。

2、然后,下载相应的系统镜像文件,可以通过官方网站或第三方软件下载合法的系统镜像文件。

3、使用Rufus等工具将系统镜像文件写入U盘。

二、设置电脑启动顺序1、连接准备好的U盘到需要重装系统的电脑上。

2、进入电脑的BIOS设置界面,一般是通过按下电源按钮后按下F2、F10或Delete键进入。

3、在BIOS设置界面中,找到启动选项并将U盘设置为首选启动设备。

4、保存设置并退出BIOS界面。

三、开机重装系统1、重新启动电脑,并按照屏幕上的提示按任意键进入系统安装界面。

2、选择语言、时区和键盘布局等设置,然后点击下一步。

3、接着,选择“自定义安装”或“清空并安装新系统”选项,根据个人需求选择适合自己的选项。

4、在磁盘选择界面,选择要安装系统的磁盘,并点击下一步开始安装系统。

四、总结通过使用U盘开机重装系统,我们可以轻松解决电脑系统问题,并提升电脑性能。

在操作过程中,注意保存重要数据,避免数据丢失。

同时,选择合适的系统镜像文件和工具版本也是非常重要的。

希望本文的介绍能够帮助大家快速掌握使用U盘开机重装系统的方法,让我们的电脑始终保持良好的运行状态。

菜科网系统致力于解决 Windows 系统重装解决方案,提供高效、安全、免费的系统重装服务。

加入收藏
               

使用Javascript实现网页水印(非图片水印)

点击下载文档

格式为doc格式

  • 账号登录
社交账号登录