使用原生js实现页面蒙灰(mask)效果示例代码


Posted in Javascript onJune 20, 2014

对于web应用开发者,当用户进行界面浏览时如果后台程序处理程序时间较长,那么用户在网页的等待时间会较长,但是如果页面上没有一个比较友好的提示方式

(增加蒙灰效果),那么用户体验会不是特别良好,用户不知道现在是不是应该点击别的程序,用户并不知道是不是应该继续等待网页,还是可以点击别的页面。

现在就有一个比较良好的交互,就是增加蒙灰效果。像js的框架Extjs的mask()和unmask()功能提供了蒙灰效果,当然jquery也提供了这种蒙灰方法。在此作者希望自己也能够

使用原生的js实现自己的蒙灰效果。故自己做了尝试。实现了蒙灰效果。在此我只关注实现,页面美观程度我没有太多调整,所以页面不太美观。在此贴出实现代码。

在CODE上查看代码片派生到我的代码片

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> 
<HTML> 
<HEAD> 
<TITLE> New Document </TITLE> 
<META NAME="Generator" CONTENT="EditPlus"> 
<META NAME="Author" CONTENT=""> 
<META NAME="Keywords" CONTENT=""> 
<META NAME="Description" CONTENT=""> 
<style type="text/css"> 
.maskStyle { 
background-color:#B8B8B8; 
z-index:1; 
filter:alpha(opacity=50); 
opacity:0.8; 
position:absolute; 
text-align:center; 
color:blue; 
font:bold 1em "宋体",Arial,Times; 
height:25px; 
font-weight:bold; 
overflow:hidden; 

} 
</style> 
</HEAD> 
<script type="text/javascript"> 
function creatMaskLayer(effectItem,showText) { 
divItem = document.createElement("div"); 
divItem.className="maskStyle"; 
divItem.style.lineHeight=effectItem.offsetHeight+"px"; 
divItem.innerText=showText; 
divItem.style.width=effectItem.offsetWidth; 
divItem.style.height=effectItem.offsetHeight; 
divItem.style.top=effectItem.offsetTop; 
divItem.style.left=effectItem.offsetLeft; 
return divItem; 
} 
function setMask() { 
var effectItem = document.getElementById("test"); 
var existMaskItem = findMaskItem(effectItem); 
if(existMaskItem) { 
return; 
} 
var showText = "加载中..."; 
effectItem.appendChild(creatMaskLayer(effectItem,showText)); 
} 
function removeMask() { 
var effectItem = document.getElementById("test"); 
var maskItem = findMaskItem(effectItem); 
if(maskItem) { 
effectItem.removeChild(maskItem); 
} 
} 
function findMaskItem(item) { 
var children = item.children; 
for(var i=0;i<children.length;i++) { 
if("maskStyle"==(children[i].className)) { 
return children[i]; 
} 
} 
} 
</script> 
<BODY> 
<input type="button" value="蒙灰" onclick="setMask()"/> 
<input type="button" value="取消蒙灰" onclick="removeMask()"/> 
<br> 
<div id="test" style="border:1px solid;width:300px;height:300px"> 
蒙灰我吧 
<input type="button" value="测试是否还能点击" onclick="alert('OK!')"/> 
</div> 
</BODY> 
</HTML>

解释一下代码中比较重要的地方。

.maskStyle是蒙灰层的样式

其中
在CODE上查看代码片派生到我的代码片

filter:alpha(opacity=50); 
opacity:0.8;

是代表蒙灰层透明度,filter属性是为了兼容IE8浏览器

z-index 属性设置元素的堆叠顺序。拥有更高堆叠顺序的元素总是会处于堆叠顺序较低的元素的前面。

PS:蒙灰效果需要把要蒙灰到element放到div中才可以

Javascript 相关文章推荐
纯js实现的论坛常用的运行代码的效果
Jul 15 Javascript
用Javascript来生成ftp脚本的小例子
Jul 03 Javascript
jquery实现动静态条形统计图
Aug 17 Javascript
JavaScript几种数组去掉重复值的方法推荐
Apr 12 Javascript
Javascript中apply、call、bind的巧妙使用
Aug 18 Javascript
Web 开发中Ajax的Session 超时处理方法
Jan 19 Javascript
jQuery 全选 全不选 事件绑定的实现代码
Jan 23 Javascript
详解VUE中v-bind的基本用法
Jul 13 Javascript
AngularJs的UI组件ui-Bootstrap之Tooltip和Popover
Jul 13 Javascript
Vue模拟数据,实现路由进入商品详情页面的示例
Aug 31 Javascript
JavaScript接口实现方法实例分析
May 16 Javascript
nuxt 每个页面head标签内容设置方式
Nov 05 Javascript
js处理php输出时间戳对不上号的解决方法
Jun 20 #Javascript
Javascript 实现复制(Copy)动作方法大全
Jun 20 #Javascript
Blocksit插件实现瀑布流数据无限( 异步)加载
Jun 20 #Javascript
教你如何自定义百度分享插件以及bshare分享插件的分享按钮
Jun 20 #Javascript
jQuery.lazyload+masonry改良图片瀑布流代码
Jun 20 #Javascript
Node.js实现简单聊天服务器
Jun 20 #Javascript
SuperSlide2实现图片滚动特效
Jun 20 #Javascript
You might like
php 文件上传实例代码
2012/04/19 PHP
PHP高级编程实例:编写守护进程
2014/09/02 PHP
php封装好的人民币数值转中文大写类
2015/12/20 PHP
PHP文件上传操作实例详解
2016/09/27 PHP
PHP实现简易图形计算器
2020/08/28 PHP
jquery.tmpl JQuery模板插件
2011/10/10 Javascript
jquery的父子兄弟节点查找示例代码
2014/03/03 Javascript
Flexigrid在IE下不显示数据的有效处理方法
2014/09/04 Javascript
js获取微信版本号的方法
2015/05/12 Javascript
jq实现左侧显示图片右侧文字滑动切换效果
2015/08/04 Javascript
javascript事件处理模型实例说明
2016/05/31 Javascript
JavaScript使用forEach()与jQuery使用each遍历数组时return false 的区别
2016/08/26 Javascript
Angular2 组件间通过@Input @Output通讯示例
2017/08/24 Javascript
浅谈Redux中间件的实践
2018/07/27 Javascript
微信小程序基于picker实现级联菜单
2019/02/15 Javascript
vue实现登录页面的验证码以及验证过程解析(面向新手)
2019/08/02 Javascript
Python 稀疏矩阵-sparse 存储和转换
2017/05/27 Python
python中的break、continue、exit()、pass全面解析
2017/08/05 Python
PyQt5每天必学之滑块控件QSlider
2018/04/20 Python
Python实现随机创建电话号码的方法示例
2018/12/07 Python
利用python脚本如何简化jar操作命令
2019/02/24 Python
Django文件上传与下载(FileFlid)
2019/10/06 Python
python 已知三条边求三角形的角度案例
2020/04/12 Python
PyCharm 光标变成黑块的解决方式
2021/02/06 Python
css和css3弹性盒模型实现元素宽度(高度)自适应
2019/05/15 HTML / CSS
雅诗兰黛澳大利亚官网:Estée Lauder澳大利亚
2019/05/31 全球购物
电气专业应届生求职信
2013/11/01 职场文书
数控机械专业个人的自我评价
2014/01/02 职场文书
大学活动总结范文
2014/04/29 职场文书
企业安全生产月活动总结
2014/07/05 职场文书
办公室班子四风问题对照检查材料
2014/10/04 职场文书
第28个世界无烟日活动总结
2015/02/10 职场文书
预防艾滋病宣传活动总结
2015/05/09 职场文书
党员转正党支部意见
2015/06/02 职场文书
干货:如何写好观后感 !
2019/05/21 职场文书
Python绘制散点图之可视化神器pyecharts
2022/07/07 Python