如何在jquery中实现蒙版的效果??

JavaScript023

如何在jquery中实现蒙版的效果??,第1张

用animate,animate是用来实现动画效果的,jquery下拉滑动有专门的方法

jQuery 拥有以下滑动方法:

slideDown() 向下滑动

slideUp() 向上滑动

slideToggle() 点一下向下滑动展开,再点一下还原!

你说的是不是常见的那种 弹出一个半透明遮罩层,同时不能操作页面相关对象,只能操作在遮罩层以上的内容?

实际这个效果很简单,半透明遮罩层(是不是半透明无所谓)是实现了和文档document同宽同高,但是css的z-index属性要大于普通内容的一个空白div,这个div做了半透明效果,隔离了所有事件,你鼠标在网页上面的点击,移动,拽托等操作只作用于这个div,因此原网页的所有事件均失效.

在遮罩层上一般还会有一个可操作域(div2),这个同理,这个div2的z-index要大于遮罩层的z-index,从而他会在遮罩层以上,而能实现其操作.

以上是原理,那么实现起来要分一些几个步骤:

1,遮罩层(可以事先就进行半透明处理和document等宽等高处理,这个需要通过js编写)和可操作域(div2) 的display属性设置为none.处于隐藏状态.

2,当网页需要激活遮罩事件的时候,js将遮罩层和可操作域的display设置为block.处于显示状态,当在可操作域关闭事件触发的时候,同时将遮罩和可操作域隐藏.

需要注意的是,遮罩层最好是在body的根目录下,并position设置为绝对定位,这样布局比较方便

var a = confirm( "OK?" )

执行了 confirm( "OK?" ) 弹出一个确认框后,javascript 就不再执行,等到点完按钮、返回一个值后,才能完成赋值语句的执行。

想要模拟这个功能,除非能弹出另外一个模态窗口,否则只用 普通的蒙版和 div 层是做不到阻塞 Javascript 的执行的。

修改方法改成:

function Confirm(msg,callback_OK,callback_CANCEL) {

btnok.onclick = function(){

if(callback_OK &&typeof callback_OK == "function")

callback_OK( true )

close()//你应该有这个功能吧?

}

btncancel.onclick = function(){

if(callback_CANCEL &&typeof callback_CANCEL== "function")

callback_CANCEL( false )

close()//你应该有这个功能吧?

}

}

这样的话,如果想执行类似这样的功能:

if(confirm( "OK?" )){

okHandlerCode()

}else{

cancelHandlerCode()

}

Confirm( "OK?" , okHandlerCode , cancelHandlerCode )

利用这种方式,就解决了确认对话框的返回值接收的问题: