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

常见的就是公文系统、合同系统等。
大家常常关注的是网站图片增加水印,而很少关注页面水印。
刚去G
【菜科解读】
在一些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,实现,网页,水印,非,图片,概述收藏备用!拉萨社保卡里的个账的钱如何给家人使用?(2025
拉萨职工社保卡上的个人账户如何共济给家人?这些要点需注意随新社通小编来了解一下:拉萨社保卡怎么共享给家人?家庭成员共享如何绑定?社保卡里的职工个人账户如何共济给家人?社保卡里的余额给家人使用,需要怎么绑定呢,主要可以通过以下几种方式实现:一、电子社保卡亲情服务此外,还可以通过电子社保卡的亲情服务功能,为家人提供便捷的电子社保卡签发和应用服务。
具体步骤如下:打开电子社保卡首页,点击右上角“我的”-“亲情服务”。
点击“添加”,验证电子社保卡密码后,阅读并同意添加亲情账户告知书。
输入要开通人的姓名、社保号码、亲情关系,点击“添加亲情账户”并上传身份凭证(小于16岁需同时上传人脸正面照)。
亲情服务绑定对象进行人脸识别操作,认证通过后则开通亲情服务成功。
通过电子社保卡亲情服务,可以帮家人查询个人社保权益单、进行社保待遇资格认证、办理社保网上转移申请等,同时也可以使用社保卡里的余额。
二、社保卡绑定家人通过社保卡的家庭共享功能,可以将社保卡的余额绑定给家人使用。
具体操作步骤如下:社会保险服务个人网页自助办理:登陆个人网页,进入社保业务办理-医疗业务办理-个人账户家庭共享-新增绑定,输入亲属社保电脑号、亲属身份证号及亲属关系,提交保存,即完成绑定。
到社保分局医疗保险窗口申请办理:在社保部门医保现金报销窗口刷卡绑定,刷被使用人的社保卡,并录入使用人的社保卡号。
在定点医院医疗保险办公室办理:在医院医保办,通过“网上医院”刷卡绑定,刷被使用人的卡,并录入使用人的社保卡号。
完成绑定后,家人在就医时就可以使用社保卡里的余额进行支付了。
需要注意的是,社保卡里的余额属于个人所有,给家人使用时需确保符合要求,不得进行违法违规操作。
另外,不同地区的社保卡使用可能有所不同,具体操作方法还需根据当地而定。
拉萨社保缴费比例是多少?公司和个人的社保缴费比例是不同的:养老保险:参加基本养老保险的个人,达到法定退休年龄时累计缴费满十五年的,按月领取基本养老金。
参加基本养老保险的个人,因病或者非因工死亡的,其遗属可以领取丧葬补助金和抚恤金;在未达到法定退休年龄时因病或者非因工致残完全丧失劳动能力的,可以领取病残津贴。
所需资金从基本养老保险基金中支付。
医疗保险:参加职工基本医疗保险的个人,达到法定退休年龄时累计缴费达到要求年限的,退休后不再缴纳基本医疗保险费,按照法规享受基本医疗保险待遇。
失业保险:单位缴费比例为8%-10%,个人缴费比例为2%。
同样以医疗保险缴费基数为基础,单位需缴纳的比例为8%-10%,个人则需缴纳2%。
生育保险缴费比例是指企业和职工按照一定比例缴纳生育保险费用的比例,按照相关要求,企业按照其缴费总基数的0.8%缴纳生育保险费,职工个人不缴纳生育保险费。
工伤保险缴费比例按行业确定,由单位缴纳,个人不缴费,现行的一至八类工伤保险基准费率分别为0.4%、0.5%、0.9%、1.0%、1.1%、1.6%、2.2%、3.0%。
住房公积金个人和单位缴纳的比例是1:1,缴存单位可在5%-12%范围内自主确定缴存比例。
缴存比例:公司和个人缴纳住房公积金的比例是相等的,即1:1。
单位可以根据自身情况,在5%至12%的范围内选择适合的缴存比例。
例如,如果单位选择的缴存比例是8%,那么个人和单位各自需要缴纳工资总额的8%作为住房公积金。
缴存基数:住房公积金管理中心会根据当地的职工平均工资来计算公积金的缴存基数。
这个基数通常最高不超过上一年职工月平均工资的3倍,同时也不得低于当地当年职工工资的最低标准。
缴存额度:在确定了缴存基数和缴存比例后,每个月可以缴存的公积金总额就是缴存基数的10%至24%(因为个人和单位各自缴纳5%至12%,所以总额度是这个范围的两倍)。
目前首批开通个人账户跨省家庭共济的地区(统筹区)有哪些?1、安徽省(淮南市)2、山东省(德州市)3、河北省(石家庄市、唐山市、秦皇岛市、邯郸市、邢台市、保定市、张家口市、承德市、沧州市、廊坊市、衡水市、辛集市、定州市、雄安新区、省本级)4、四川省(省本级、成都市、广安市)5、重庆市(云阳县)6、河南省(郑州市、信阳市)7、江苏省(苏州市)8、湖北省(襄阳市、黄冈市、咸宁市、随州市、恩施土家族苗族自治州、潜江市)9、甘肃省(临夏回族自治州)共31个地区(统筹区)已开通个人账户跨省共济使用。
西安如何查询个人参保信息、社保缴费记录、社保卡使用记录?
2、缓解经济压力:在面临失业、工伤或生育等特殊情况下,社保可以提供经济援助,减轻个人和家庭的经济负担。
3、促进社会稳定:通过建立社会保险网络,减少社会不稳定因素,维护社会和谐稳定。
4、支持劳动力再生产:社保保险有助于提高劳动者的生活质量,促进劳动力的健康和持续发展。
西安社保缴费明细查询方式有哪些?(1)您可以拨打社保查询12333热线,客服人员将热忱为您查询您的缴费信息;(2)您可以登录当地的人力资源和社保局网,进入个人网上服务大厅进行注册登记进行查询,或者找到“个人社保查询”、“社会保险缴费明细查询”等栏目,按要求输入身份证、密码等,即可!(3)您可以通过人社局微信进行查询;(4)各镇社保所和市民服务中心有社保一体机进行个人缴费信息查询。
需要提醒的是,前往社保局查询也不失一种很传统的查询方式,人们可以先了解社保局是在哪里,然后携带好身份证及社保卡就可以了,不仅可以查询到自己的社会保险的缴纳情况,还可以查询到使用情况,如果当地的社会保险有什么新的资讯也能及时了解。
以上就是关于社保的相关资讯,希望对您有帮助!更多精彩内容欢迎关注新社通APP最新资讯!