`

js模拟对话框

阅读更多
<!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>MessageBox演示</title>
<script language="javascript">

// 控制按钮常量
var MB_OK = 0;
var MB_CANCEL = 1;
var MB_OKCANCEL = 2;
var MB_YES = 3;
var MB_NO = 4;
var MB_YESNO = 5;
var MB_YESNOCANCEL = 6;
// 控制按钮文本
var MB_OK_TEXT = "确定";
var MB_CANCEL_TEXT = "取消";
var MB_YES_TEXT = " 是 ";
var MB_NO_TEXT = " 否 ";
//提示图标
var MB_ICON = "http://2lin.net/image/information.gif";
//委托方法
var MB_OK_METHOD = null;
var MB_CANCEL_METHOD = null;
var MB_YES_METHOD = null;
var MB_NO_METHOD = null;
var MB_BACKCALL = null;
var MB_STR = '<style type="text/css"><!--' +
'body{margin:0px;}' +
'.msgbox_title{background-color: #B1CDF3;height:25px;position:relative;font-size:14px;line-height:25px;padding-left:10px;border-bottom:1px solid #000;}' +
'.msgbox_control{text-align:center;clear:both;height:28px;}' +
'.msgbox_button{background-color: #B1CDF3;border:1px solid #003366;font-size:12px;line-height:20px;height:21px;}' +
'.msgbox_content{padding:10px;float:left;line-height: 20px;}' +
'.msgbox_icon{width: 50px;height: 50px;float: left;text-align: center;line-height:50px;padding-top:10px;}' +
'.msgbox_mask{position:absolute;left:0px;top:0px;z-index:99999;background-color:#333333;width:100%;height:100%;}' +
'.msgbox{background-color: #EFFAFE;position: absolute;height:auto;font-size:12px;top:50%;left:50%;border:1px solid #999999;}' +
'--></style>' +
'<div id="msgBoxMask" class="msgbox_mask" style="filter: alpha(opacity=0);display:none;"></div>' +
'<div class="msgbox" style="display:none; z-index:100000;" id="msgBox">' +
'<div class="msgbox_title" id="msgBoxTitle"></div>' +
'<div class="msgbox_icon" id="msgBoxIcon"></div>' +
'<div class="msgbox_content" id="msgBoxContent"></div>' +
'<div class="msgbox_control" id="msgBoxControl"></div></div>';
var Timer = null;
document.write(MB_STR);
var icon = new Image();
icon.src = MB_ICON;
/* 提示对话框
* 参数 1 : 提示内容
* 参数 2 : 提示标题
* 参数 3 : 图标路径
* 参数 4 : 按钮类型
*/
function MessageBox(){
   var _content = arguments[0] || "这是一个对话框!";
   var _title   = arguments[1] || "提示";
   var _icon    = arguments[2] || MB_ICON;
   var _button  = arguments[3] || MB_OK;
   MB_BACKCALL  = arguments[4];
  
   var _iconStr = '<img src="{0}">';
   var _btnStr  = '<input name="{0}" id="{0}" type="button" class="msgbox_button" value="{1}" onclick="MBMethod(this)" />';
  
  
   switch(_button)
   {     
  case MB_CANCEL      : _btnStr = _btnStr.toFormatString("msgBoxBtnCancel", MB_CANCEL_TEXT); break;

  case MB_YES         : _btnStr = _btnStr.toFormatString("msgBoxBtnYes", MB_YES_TEXT); break;
 
  case MB_NO          : _btnStr = _btnStr.toFormatString("msgBoxBtnNo", MB_NO_TEXT); break;
 
  case MB_OKCANCEL    :
       _btnStr = _btnStr.toFormatString("msgBoxBtnOk", MB_OK_TEXT) + "&nbsp;&nbsp;" +
             _btnStr.toFormatString("msgBoxBtnCancel", MB_CANCEL_TEXT);
   break;
  
  case MB_YESNO       :
        _btnStr = _btnStr.toFormatString("msgBoxBtnYes", MB_YES_TEXT) + "&nbsp;&nbsp;" +
              _btnStr.toFormatString("msgBoxBtnNo", MB_NO_TEXT);
    break;

  case MB_YESNOCANCEL :
        _btnStr = _btnStr.toFormatString("msgBoxBtnYes", MB_YES_TEXT) + "&nbsp;&nbsp;" +
              _btnStr.toFormatString("msgBoxBtnNo", MB_NO_TEXT) + "&nbsp;&nbsp;" +
  _btnStr.toFormatString("msgBoxBtnCancel", MB_CANCEL_TEXT);
    break;
    
  default :  _btnStr = _btnStr.toFormatString("msgBoxBtnOk", MB_OK_TEXT);  break; 
 
   }
   //解决 FF 下会复位
   ScrollTop = GetBrowserDocument().scrollTop;
   ScrollLeft = GetBrowserDocument().scrollLeft;
   GetBrowserDocument().style.overflow = "hidden";
   GetBrowserDocument().scrollTop = ScrollTop;  
   GetBrowserDocument().scrollLeft = ScrollLeft;
     
   $("msgBoxTitle").innerHTML = _title;
   $("msgBoxIcon").innerHTML = _iconStr.toFormatString(_icon);
   $("msgBoxContent").innerHTML = _content;
   $("msgBoxControl").innerHTML =  _btnStr;
  
   OpacityValue = 0;
   $("msgBox").style.display = "";   
   try{$("msgBoxMask").filters("alpha").opacity = 0;}catch(e){};
   $("msgBoxMask").style.opacity = 0;
   $("msgBoxMask").style.display = "";
   $("msgBoxMask").style.height = GetBrowserDocument().scrollHeight + "px";
   $("msgBoxMask").style.width = GetBrowserDocument().scrollWidth + "px";
  
   Timer = setInterval("DoAlpha()",1);
   //设置位置  
   $("msgBox").style.width = "100%";  
   $("msgBox").style.width = ($("msgBoxIcon").offsetWidth + $("msgBoxContent").offsetWidth + 2) + "px";
  
   $("msgBox").style.marginTop = (-$("msgBox").offsetHeight/2 + GetBrowserDocument().scrollTop) + "px";
   $("msgBox").style.marginLeft = (-$("msgBox").offsetWidth/2 + GetBrowserDocument().scrollLeft) + "px";  
  
   if(_button == MB_OK || _button == MB_OKCANCEL){
     $("msgBoxBtnOk").focus();
   }else if(_button == MB_YES || _button == MB_YESNO || _button == MB_YESNOCANCEL){
   $("msgBoxBtnYes").focus();
   } 
}
var OpacityValue = 0;
var ScrollTop = 0;
var ScrollLeft = 0;
function GetBrowserDocument()
{
   var _dcw = document.documentElement.clientHeight;
   var _dow = document.documentElement.offsetHeight;
   var _bcw = document.body.clientHeight;
   var _bow = document.body.offsetHeight;
  
   if(_dcw == 0) return document.body;
   if(_dcw == _dow) return document.documentElement;
  
   if(_bcw == _bow && _dcw != 0)
     return document.documentElement;
   else
     return document.body;
}
function SetOpacity(obj,opacity){
if(opacity >=1 ) opacity = opacity / 100;

try{obj.style.opacity = opacity; }catch(e){}

try{
if(obj.filters){
obj.filters("alpha").opacity = opacity * 100;
}

}catch(e){}
}

function DoAlpha(){
if (OpacityValue > 20){clearInterval(Timer);return 0;}
OpacityValue += 5;
SetOpacity($("msgBoxMask"),OpacityValue);
}
function MBMethod(obj)
{  
   switch(obj.id)
   {
      case "msgBoxBtnOk" : if(MB_BACKCALL) {MB_BACKCALL(MB_OK);} else {if(MB_OK_METHOD) MB_OK_METHOD();} break;
  case "msgBoxBtnCancel" : if(MB_BACKCALL) {MB_BACKCALL(MB_CANCEL);} else {if(MB_CANCEL_METHOD) MB_CANCEL_METHOD();} break;
  case "msgBoxBtnYes" : if(MB_BACKCALL) {MB_BACKCALL(MB_YES);} else {if(MB_YES_METHOD) MB_YES_METHOD();} break;
  case "msgBoxBtnNo" : if(MB_BACKCALL) {MB_BACKCALL(MB_NO);} else {if(MB_NO_METHOD) MB_NO_METHOD();} break;
   }  
  
   MB_OK_METHOD = null;
   MB_CANCEL_METHOD = null;
   MB_YES_METHOD = null;
   MB_NO_METHOD = null;
   MB_BACKCALL = null;
  
   MB_OK_TEXT = "确定";
   MB_CANCEL_TEXT = "取消";
   MB_YES_TEXT = " 是 ";
   MB_NO_TEXT = " 否 ";
  
   $("msgBox").style.display = "none"; 
   $("msgBoxMask").style.display = "none";    
   GetBrowserDocument().style.overflow = "";
   GetBrowserDocument().scrollTop = ScrollTop;
   GetBrowserDocument().scrollLeft = ScrollLeft;
}
String.prototype.toFormatString = function(){ 
   var _str = this;
   for(var i = 0; i < arguments.length; i++){   
      _str = eval("_str.replace(/\\{"+ i +"\\}/ig,'" + arguments[i] + "')");
   }
   return _str;
}
function $(obj){
   return document.getElementById(obj);
}
///////////////////////////////////////////////////////////////////////////////////////
</script>
<script language="javascript">
function test()
{
   var _msg = "<font color=red><b>演示:</b></font><br/>普通对话框!";
   MessageBox(_msg);
}
function test1()
{
  MB_OK_METHOD = function(){alert('你按了OK');}
  MB_YES_METHOD = function(){alert('你按了YES');}
  MB_NO_METHOD = function(){alert('你按了NO');}
  MB_CANCEL_METHOD = function(){alert('你按了CANCEL');}
 
  var _msg = "<font color=red><b>演示:</b></font><br/>调用对话框。是、否、取消";
  MessageBox(_msg,"演示",null,MB_YESNOCANCEL); 
}
function test2()
{
  var _msg = "<font color=red><b>演示:</b></font><br/>调用对话框。是、否、取消";
  MessageBox(_msg,"演示",MB_ICON,MB_YESNOCANCEL,callback);
}
function test4()
{
  var _msg = "<font color=red><b>演示:</b></font><br/>调用对话框。确定、取消";
  MessageBox(_msg,"演示",MB_ICON,MB_OKCANCEL,callback);
}
function callback(value)
{
  switch(value)
  {
     case MB_OK : alert('你按了OK'); break;
     case MB_YES : alert('你按了YES'); break;
     case MB_NO : alert('你按了NO'); break;
     case MB_CANCEL : alert('你按了CANCEL'); break;
   }
}
function test3()
{
  MB_YES_TEXT = "演示一";
  MB_NO_TEXT = "演示二";
  MB_CANCEL_TEXT = "演示三";
  var _msg = "<font color=red><b>演示:</b></font><br/>这是自定义的对话框<br/> <font color=green>MB_YES_TEXT  MB_NO_TEXT MB_CANCEL_TEXT MB_OK_TEXT</font>";
  MessageBox(_msg,"演示",MB_ICON,MB_YESNOCANCEL,callback);
}
</script>
</head>
<body>
<table width="1500" height="1000" border="1" bordercolor="#000000">
  <tr>
    <td> </td>
    <td align="center"><a href="javascript:test()">普通演示</a></td>
    <td> </td>
  </tr>
  <tr>
    <td>&nbsp;</td>
    <td align="center"><a href="javascript:test1()">回调演示一</a>
    <label></label></td>
    <td>&nbsp;</td>
  </tr>
  <tr>
    <td>&nbsp;</td>
    <td align="center"><a href="javascript:test2()">回调演示二
     
    </a></td>
    <td>&nbsp;</td>
  </tr>
  <tr>
    <td>&nbsp;</td>
    <td align="center"><a href="javascript:test4()">回调演示三</a><a href="javascript:test3()"></a></td>
    <td>&nbsp;</td>
  </tr>
  <tr>
    <td>&nbsp;</td>
    <td align="center"><a href="javascript:test3()">自定义演示
     
    </a></td>
    <td>&nbsp;</td>
  </tr>
</table>
</body>
</html>
分享到:
评论

相关推荐

    仿163信箱js模拟对话框代码

    总结起来,“仿163信箱js模拟对话框代码”是一个利用JavaScript和相关资源创建的自定义对话框,其设计风格参照了163邮箱,并强调了美观性和易用性。开发者可以通过学习和应用这样的代码,提升自己的网页交互设计能力...

    js模拟对话框,可拖动,QQ对话框风格

    总的来说,创建一个“js模拟对话框,可拖动,QQ对话框风格”的过程涵盖了JavaScript基础、DOM操作、CSS样式设计、事件监听、图片资源的使用等多个方面。通过这个项目,开发者可以深入理解前端开发中的交互设计和用户...

    Div模拟对话框 .

    总的来说,`Div模拟对话框`是Web开发中的一个重要技能,它结合了HTML、CSS和JavaScript的基本概念,提供了丰富的用户体验。通过合理布局`div`元素,定制CSS样式,以及编写JavaScript逻辑,开发者可以创造出各种各样...

    模拟网页对话框

    首先,我们可以通过HTML、CSS和JavaScript来构建一个基本的模拟对话框。`x.html`文件可能就是一个简单的实例,它可能包含了对话框的结构和样式。HTML用于构建对话框的结构,例如`&lt;div&gt;`元素可以作为对话框的基本容器...

    纯js(javascript)弹出层 对话框,div 模拟系统对话框

    本篇文章将详细讲解如何使用纯JavaScript(无依赖库如jQuery等)来创建自定义的弹出层对话框,以及如何模拟系统级别的Alert、Confirm和Prompt对话框。 首先,我们来理解“弹出层”。弹出层,通常是一个浮现在页面...

    模拟MSN弹出式对话框示例

    MSNP提供了消息传递、状态更新、文件传输等功能,这些功能是模拟对话框时需要复现的核心部分。 模拟弹出式对话框通常涉及到以下几个关键点: 1. **UI设计**:这包括对话框的外观和感觉,如边框、按钮、文字输入框...

    DIV模拟对话框

    为了提供更丰富的用户体验,开发者会使用自定义的模拟对话框(通常基于HTML、CSS和JavaScript)。本主题将详细讲解如何使用`DIV`元素来模拟`alert`和`confirm`对话框。 一、HTML基础 在`testDialog.html`文件中,...

    jQuery模拟JS警告、确认、提示弹出对话框

    在使用jQuery模拟对话框时,可以根据需求定制对话框的大小、颜色、字体等样式,以及添加更多的交互功能,如动画效果、回调函数等。这大大增强了对话框的灵活性和用户体验。 总结: jQuery模拟JS警告、确认、提示弹...

    javascript网页对话框.docx

    需要注意的是,由于弹出窗口可能被视为侵入性的用户体验,现代Web设计倾向于使用模态HTML元素(如`&lt;dialog&gt;`)或JavaScript库(如jQuery UI)来模拟对话框效果,以避免浏览器的弹出窗口阻止机制。同时,`...

    苹果IOS系统风格JS模态对话框特效

    而`js`目录则可能包含JavaScript代码,用于处理对话框的逻辑,如显示、隐藏对话框,以及与用户的交互。 具体实现上,JS可能会使用函数来控制对话框的生命周期,比如`showModal()`用于显示对话框,`hideModal()`用于...

    js实现div模拟模态对话框展现URL内容.pdf

    js实现div模拟模态对话框展现URL内容

    JavaScript应用实例-模拟更新下载对话框.js

    JavaScript应用实例-模拟更新下载对话框.js

    jQuery模拟JS警告、确认、提示弹出对话框效果.rar

    在本资源"jQuery模拟JS警告、确认、提示弹出对话框效果.rar"中,我们可以看到如何使用jQuery库来创建自定义的、具有类似原生JavaScript警告(alert)、确认(confirm)和提示(prompt)对话框的效果。 jQuery是一款...

    javascript模态对话框

    在JavaScript中,我们可以通过创建自定义的DOM元素和使用CSS来模拟这种效果,或者使用现成的库如jQuery UI或Bootstrap来快速实现。 实现一个基本的JavaScript模态对话框,我们需要以下几个步骤: 1. **创建HTML...

    artDialog 漂亮的javascript对话框(弹出层)组件

    漂亮的javascript对话框(弹出层)组件 javascript对话框(弹出层)组件artDialog artDialog是一个轻巧且高度兼容的javascript对话框组件,可让你的网页交互拥有桌面软件般的用户体验。 演示地址:...

    Javascript弹出对话框

    - 考虑使用模态框(modal)或自定义的HTML元素来模拟对话框效果,这样可以获得更多的定制能力和更好的响应式设计。 - 在处理用户输入时,务必进行验证和清理,防止XSS攻击和其他安全问题。 - 如果需要用户输入敏感...

    模拟163弹出对话框

    标题 "模拟163弹出对话框" 指向的是一个编程技术,它涉及到创建一个仿照网易163邮箱界面的对话框。在软件开发中,模拟特定平台或应用的用户界面元素是为了提供一致的用户体验或者进行自动化测试。在这个场景下,可能...

Global site tag (gtag.js) - Google Analytics