能否用javascript实现confirm对话框中确认按钮按照数字倒计时选择

时间:2023-01-30 10:47:20
能否用javascript实现confirm对话框中确认按钮按照数字倒计时选择,也就是在确认按钮中加上(5),(4),(3),(2),(1),让用户有5秒的考虑时间,如果用户没有选择是或者是否,那就通过倒计时数字来选择默认的选择

5 个解决方案

#1


貌似不能
或者自己模拟一个吧

#2


不能吧
用层模拟

#3


confirm应该是不能,
用showModalDialog来实现吧。

#4


不能吧 
用层模拟

#5


给你一个效果好的, 用JS和CSS实现


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
 <style>  
html,body{font-size:12px;margin:0px;height:100%;}  
.mesWindow{border:#666 1px solid;background:#fff;}  
.mesWindowTop{border-bottom:#eee 1px solid;margin-left:4px;padding:3px;font-weight:bold;text-align:left;font-size:12px;}  
.mesWindowContent{margin:4px;font-size:12px;}  
.mesWindow .close{height:15px;width:28px;border:none;cursor:pointer;text-decoration:underline;background:#fff}  
</style>  
<script>  
var isIe=(document.all)?true:false;  
//设置select的可见状态  
function setSelectState(state)  
{  
 var objl=document.getElementsByTagName('select');  
 for(var i=0;i<objl.length;i++)  
 {  
 objl[i].style.visibility=state;  
 }  
}  
function mousePosition(ev)  
 {  
 if(ev.pageX || ev.pageY)  
 {  
 return {x:ev.pageX, y:ev.pageY};  
 }  
 return {  
 x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,y:ev.clientY + document.body.scrollTop - document.body.clientTop  
 };  
 }  
//弹出方法  
function showMessageBox(wTitle,content,pos,wWidth)  
{  
 closeWindow();  
 var bWidth=parseInt(document.documentElement.scrollWidth);  
 var bHeight=parseInt(document.documentElement.scrollHeight);  
 if(isIe){  
 setSelectState('hidden');}  
 var back=document.createElement("div");  
 back.id="back";  
 var styleStr="top:0px;left:0px;position:absolute;background:#666;width:"+bWidth+"px;height:"+bHeight+"px;";  
 styleStr+=(isIe)?"filter:alpha(opacity=40);":"opacity:0.40;";  
 back.style.cssText=styleStr;  
 document.body.appendChild(back);  
 var mesW=document.createElement("div");  
 mesW.id="mesWindow";  
 mesW.className="mesWindow";  
 mesW.innerHTML="<div class='mesWindowTop'><table width='100%' height='100%'><tr><td>"+wTitle+"</td><td style='width:1px;'></td></tr></table></div><div class='mesWindowContent' id='mesWindowContent'>"+content+"</div><div class='mesWindowBottom'></div>";  
  
 styleStr="left:"+(((pos.x-wWidth)>0)?(pos.x-wWidth):pos.x)+"px;top:"+(pos.y)+"px;position:absolute;width:"+wWidth+"px;";  
 mesW.style.cssText=styleStr;  
 document.body.appendChild(mesW);  
}  
 function showBackground(obj,endInt)  
{  
 obj.filters.alpha.opacity+=1;  
 if(obj.filters.alpha.opacity<endInt)  
 {  
 setTimeout(function(){showBackground(obj,endInt)},8);  
 }  
}  
//关闭窗口  
function closeWindow()  
{  
 if(document.getElementById('back')!=null)  
 {  
 document.getElementById('back').parentNode.removeChild(document.getElementById('back'));  
 }  
 if(document.getElementById('mesWindow')!=null)  
 {  
 document.getElementById('mesWindow').parentNode.removeChild(document.getElementById('mesWindow'));  
 }  
  
 if(isIe){  
 setSelectState('');}  
}  
//测试弹出  
function testMessageBox(ev)  
{  
 var objPos = mousePosition(ev);  
 messContent="<div style='padding:20px 0 20px 0;text-align:center'><span id='timeout'>10.000</span> 秒后 将自动关闭窗口<br><br><input type='button' onclick='closeW();' class='close'  title='确定' value='确定'>&nbsp;&nbsp;<input type='button' onclick='closeWindow();' title='取消' class='close' value='取消' /></div>";  
 showMessageBox('确定要关闭该页面?',messContent,objPos,350);  
 TimeOut();
}  


//设计倒计时
<!--
    var duration=9900;
    var endTime = new Date().getTime() + duration + 100;
    function interval()
    {
        var n=(endTime-new Date().getTime())/1000;
        if(n<0) return;
        document.getElementById("timeout").innerHTML = n.toFixed(3);
        setTimeout(interval, 10);
    }

    function TimeOut()
    {
        setTimeout("closeW();", duration);
        interval();
    }
function closeW()
{
window.opener=null;
window.close();
}
    //-->
</script>  
</head>

<body>
<a href="#none" onclick="testMessageBox(event);">关闭窗口</a>
</body>
</html>

#1


貌似不能
或者自己模拟一个吧

#2


不能吧
用层模拟

#3


confirm应该是不能,
用showModalDialog来实现吧。

#4


不能吧 
用层模拟

#5


给你一个效果好的, 用JS和CSS实现


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>无标题文档</title>
 <style>  
html,body{font-size:12px;margin:0px;height:100%;}  
.mesWindow{border:#666 1px solid;background:#fff;}  
.mesWindowTop{border-bottom:#eee 1px solid;margin-left:4px;padding:3px;font-weight:bold;text-align:left;font-size:12px;}  
.mesWindowContent{margin:4px;font-size:12px;}  
.mesWindow .close{height:15px;width:28px;border:none;cursor:pointer;text-decoration:underline;background:#fff}  
</style>  
<script>  
var isIe=(document.all)?true:false;  
//设置select的可见状态  
function setSelectState(state)  
{  
 var objl=document.getElementsByTagName('select');  
 for(var i=0;i<objl.length;i++)  
 {  
 objl[i].style.visibility=state;  
 }  
}  
function mousePosition(ev)  
 {  
 if(ev.pageX || ev.pageY)  
 {  
 return {x:ev.pageX, y:ev.pageY};  
 }  
 return {  
 x:ev.clientX + document.body.scrollLeft - document.body.clientLeft,y:ev.clientY + document.body.scrollTop - document.body.clientTop  
 };  
 }  
//弹出方法  
function showMessageBox(wTitle,content,pos,wWidth)  
{  
 closeWindow();  
 var bWidth=parseInt(document.documentElement.scrollWidth);  
 var bHeight=parseInt(document.documentElement.scrollHeight);  
 if(isIe){  
 setSelectState('hidden');}  
 var back=document.createElement("div");  
 back.id="back";  
 var styleStr="top:0px;left:0px;position:absolute;background:#666;width:"+bWidth+"px;height:"+bHeight+"px;";  
 styleStr+=(isIe)?"filter:alpha(opacity=40);":"opacity:0.40;";  
 back.style.cssText=styleStr;  
 document.body.appendChild(back);  
 var mesW=document.createElement("div");  
 mesW.id="mesWindow";  
 mesW.className="mesWindow";  
 mesW.innerHTML="<div class='mesWindowTop'><table width='100%' height='100%'><tr><td>"+wTitle+"</td><td style='width:1px;'></td></tr></table></div><div class='mesWindowContent' id='mesWindowContent'>"+content+"</div><div class='mesWindowBottom'></div>";  
  
 styleStr="left:"+(((pos.x-wWidth)>0)?(pos.x-wWidth):pos.x)+"px;top:"+(pos.y)+"px;position:absolute;width:"+wWidth+"px;";  
 mesW.style.cssText=styleStr;  
 document.body.appendChild(mesW);  
}  
 function showBackground(obj,endInt)  
{  
 obj.filters.alpha.opacity+=1;  
 if(obj.filters.alpha.opacity<endInt)  
 {  
 setTimeout(function(){showBackground(obj,endInt)},8);  
 }  
}  
//关闭窗口  
function closeWindow()  
{  
 if(document.getElementById('back')!=null)  
 {  
 document.getElementById('back').parentNode.removeChild(document.getElementById('back'));  
 }  
 if(document.getElementById('mesWindow')!=null)  
 {  
 document.getElementById('mesWindow').parentNode.removeChild(document.getElementById('mesWindow'));  
 }  
  
 if(isIe){  
 setSelectState('');}  
}  
//测试弹出  
function testMessageBox(ev)  
{  
 var objPos = mousePosition(ev);  
 messContent="<div style='padding:20px 0 20px 0;text-align:center'><span id='timeout'>10.000</span> 秒后 将自动关闭窗口<br><br><input type='button' onclick='closeW();' class='close'  title='确定' value='确定'>&nbsp;&nbsp;<input type='button' onclick='closeWindow();' title='取消' class='close' value='取消' /></div>";  
 showMessageBox('确定要关闭该页面?',messContent,objPos,350);  
 TimeOut();
}  


//设计倒计时
<!--
    var duration=9900;
    var endTime = new Date().getTime() + duration + 100;
    function interval()
    {
        var n=(endTime-new Date().getTime())/1000;
        if(n<0) return;
        document.getElementById("timeout").innerHTML = n.toFixed(3);
        setTimeout(interval, 10);
    }

    function TimeOut()
    {
        setTimeout("closeW();", duration);
        interval();
    }
function closeW()
{
window.opener=null;
window.close();
}
    //-->
</script>  
</head>

<body>
<a href="#none" onclick="testMessageBox(event);">关闭窗口</a>
</body>
</html>