js模拟弹出系统对话框

好长时间不写笔记了,这段时间就是乱忙,忙看书,忙上课,还忙着玩。只是老师有任务才慢忽悠悠的查一些东西,真的堕落了吗……哎。进入正题……

今天淘到一段不错的代码,是用js模拟弹出系统对话框的。

出现的问题:为什么要模拟这个对话框,主要是因为做的系统是给老外用的,要求一切显示都是英语。在网上查到,其实js里面的conform弹出对话框中显示的“确定”和“取消”按钮,是根据电脑的系统来设置的,所以,这样的话,肯定有的地方显示成中文,有的地方显示英文,不合要求。

在网上查了好多,也有很多的组件,但是,仅仅这么一个小的功能,用一个组件有点浪费了。后来找到了一个好的。功能实现很齐全,根据自己的需要改了一下。其中的代码,我还是放上最初的吧。

下面的代码,我已经测试过了,直接放在一个html中可以运行的。

Code:
  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">      
  2. <html xmlns="http://www.w3.org/1999/xhtml">      
  3. <head>      
  4. <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />      
  5. <title>MessageBox演示</title>      
  6. <script language="javascript">      
  7. /*******************************************************************************************       
  8. *以下是原作者信息,其中稍微做了一点点修改    
  9.  * http://2lin.net    
  10.  * Email:caoailin@gmail.com     
  11.  * QQ:38062022     
  12.  * 下面的内容可以拷贝到一个JS文件里面    
  13. *********************************************************************************************/     
  14. // 控制按钮常量      
  15. var MB_OK = 0;      
  16. var MB_CANCEL = 1;      
  17. var MB_OKCANCEL = 2;      
  18. var MB_YES = 3;      
  19. var MB_NO = 4;      
  20. var MB_YESNO = 5;      
  21. var MB_YESNOCANCEL = 6;      
  22. // 控制按钮文本      
  23. var MB_OK_TEXT = "submit";      
  24. var MB_CANCEL_TEXT = "cancel";      
  25. var MB_YES_TEXT = " yes ";      
  26. var MB_NO_TEXT = "no ";      
  27. //提示图标      
  28. var MB_ICON = "http://2lin.net/image/information.gif";      
  29. //委托方法      
  30. var MB_OK_METHOD = null;      
  31. var MB_CANCEL_METHOD = null;      
  32. var MB_YES_METHOD = null;      
  33. var MB_NO_METHOD = null;      
  34. var MB_BACKCALL = null;      
  35. var MB_STR = '<style type="text/css"><!--' +      
  36.             'body{margin:0px;}' +      
  37.             '.msgbox_title{background-color: #B1CDF3;height:25px;position:relative;font-size:14px;line-height:25px;padding-left:10px;border-bottom:1px solid #000;}' +      
  38.             '.msgbox_control{text-align:center;clear:both;height:28px;}' +      
  39.             '.msgbox_button{background-color: #B1CDF3;border:1px solid #003366;font-size:12px;line-height:20px;height:21px;}' +      
  40.             '.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;}' +      
  41.             '.msgbox_mask{position:absolute;left:0px;top:0px;z-index:99999;background-color:#333333;width:100%;height:100%;}' +      
  42.             '.msgbox{background-color: #EFFAFE;position: absolute;height:auto;font-size:12px;top:50%;left:50%;border:1px solid #999999;}' +      
  43.             '--></style>' +      
  44.             '<div id="msgBoxMask" class="msgbox_mask" style="filter: alpha(opacity=0);display:none;"></div>' +      
  45.             '<div class="msgbox" style="display:none; z-index:100000;" id="msgBox">' +      
  46.             '<div class="msgbox_title" id="msgBoxTitle"></div>' +      
  47.             '<div class="msgbox_icon" id="msgBoxIcon"></div>' +      
  48.             '<div class="msgbox_content" id="msgBoxContent"></div>' +      
  49.             '<div class="msgbox_control" id="msgBoxControl"></div></div>';      
  50. var Timer = null;      
  51. document.write(MB_STR);      
  52. var icon = new Image();      
  53. icon.src = MB_ICON;      
  54. /* 提示对话框    
  55.  * 参数 1 : 提示内容    
  56.  * 参数 2 : 提示标题    
  57.  * 参数 3 : 图标路径    
  58.  * 参数 4 : 按钮类型    
  59. */     
  60. function MessageBox(){      
  61.    var _content = arguments[0] || "这是一个对话框!";      
  62.    var _title   = arguments[1] || "提示";      
  63.    var _icon    = arguments[2] || MB_ICON;      
  64.    var _button  = arguments[3] || MB_OK;      
  65.    MB_BACKCALL  = arguments[4];      
  66.          
  67.    var _iconStr = '<img src="{0}">';      
  68.    var _btnStr  = '<input name="{0}" id="{0}" type="button" class="msgbox_button" value="{1}" οnclick="MBMethod(this)" />';      
  69.          
  70.          
  71.    switch(_button)      
  72.    {            
  73.       case MB_CANCEL      : _btnStr = _btnStr.toFormatString("msgBoxBtnCancel", MB_CANCEL_TEXT); break;      
  74.            
  75.       case MB_YES         : _btnStr = _btnStr.toFormatString("msgBoxBtnYes", MB_YES_TEXT); break;      
  76.             
  77.       case MB_NO          : _btnStr = _btnStr.toFormatString("msgBoxBtnNo", MB_NO_TEXT); break;      
  78.             
  79.       case MB_OKCANCEL    :       
  80.            _btnStr = _btnStr.toFormatString("msgBoxBtnOk", MB_OK_TEXT) + "  " +      
  81.                      _btnStr.toFormatString("msgBoxBtnCancel", MB_CANCEL_TEXT);       
  82.            break;      
  83.                  
  84.       case MB_YESNO       :      
  85.             _btnStr = _btnStr.toFormatString("msgBoxBtnYes", MB_YES_TEXT) + "  " +      
  86.                       _btnStr.toFormatString("msgBoxBtnNo", MB_NO_TEXT);       
  87.             break;      
  88.                
  89.       case MB_YESNOCANCEL :      
  90.             _btnStr = _btnStr.toFormatString("msgBoxBtnYes", MB_YES_TEXT) + "  " +      
  91.                       _btnStr.toFormatString("msgBoxBtnNo", MB_NO_TEXT) + "  " +      
  92.                       _btnStr.toFormatString("msgBoxBtnCancel", MB_CANCEL_TEXT);       
  93.             break;      
  94.                
  95.       default :  _btnStr = _btnStr.toFormatString("msgBoxBtnOk", MB_OK_TEXT);  break;        
  96.             
  97.    }      
  98.    //解决 FF 下会复位      
  99.    ScrollTop = GetBrowserDocument().scrollTop;       
  100.    ScrollLeft = GetBrowserDocument().scrollLeft;       
  101.    GetBrowserDocument().style.overflow = "hidden";      
  102.    GetBrowserDocument().scrollTop = ScrollTop;         
  103.    GetBrowserDocument().scrollLeft = ScrollLeft;       
  104.             
  105.    $("msgBoxTitle").innerHTML = _title;      
  106.    $("msgBoxIcon").innerHTML = _iconStr.toFormatString(_icon);      
  107.    $("msgBoxContent").innerHTML = _content;       
  108.    $("msgBoxControl").innerHTML =  _btnStr;      
  109.          
  110.    OpacityValue = 0;      
  111.    $("msgBox").style.display = "";           
  112.    try{$("msgBoxMask").filters("alpha").opacity = 0;}catch(e){};      
  113.    $("msgBoxMask").style.opacity = 0;      
  114.    $("msgBoxMask").style.display = "";      
  115.    $("msgBoxMask").style.height = GetBrowserDocument().scrollHeight + "px";      
  116.    $("msgBoxMask").style.width = GetBrowserDocument().scrollWidth + "px";      
  117.          
  118.    Timer = setInterval("DoAlpha()",1);      
  119.    //设置位置         
  120.    $("msgBox").style.width = "100%";         
  121.    $("msgBox").style.width = ($("msgBoxIcon").offsetWidth + $("msgBoxContent").offsetWidth + 2) + "px";      
  122.          
  123.    $("msgBox").style.marginTop = (-$("msgBox").offsetHeight/2 + GetBrowserDocument().scrollTop) + "px";      
  124.    $("msgBox").style.marginLeft = (-$("msgBox").offsetWidth/2 + GetBrowserDocument().scrollLeft) + "px";         
  125.          
  126.    if(_button == MB_OK || _button == MB_OKCANCEL){      
  127.      $("msgBoxBtnOk").focus();      
  128.    }else if(_button == MB_YES || _button == MB_YESNO || _button == MB_YESNOCANCEL){      
  129.        $("msgBoxBtnYes").focus();      
  130.    }        
  131. }      
  132. var OpacityValue = 0;      
  133. var ScrollTop = 0;      
  134. var ScrollLeft = 0;      
  135. function GetBrowserDocument()      
  136. {      
  137.    var _dcw = document.documentElement.clientHeight;      
  138.    var _dow = document.documentElement.offsetHeight;      
  139.    var _bcw = document.body.clientHeight;      
  140.    var _bow = document.body.offsetHeight;      
  141.          
  142.    if(_dcw == 0) return document.body;      
  143.    if(_dcw == _dow) return document.documentElement;      
  144.          
  145.    if(_bcw == _bow && _dcw != 0)       
  146.      return document.documentElement;      
  147.    else     
  148.      return document.body;      
  149. }      
  150. function SetOpacity(obj,opacity){      
  151.         if(opacity >=1 ) opacity = opacity / 100;         
  152.                   
  153.         try{obj.style.opacity = opacity; }catch(e){}      
  154.               
  155.         try{       
  156.             if(obj.filters){      
  157.                 obj.filters("alpha").opacity = opacity * 100;      
  158.             }      
  159.                   
  160.         }catch(e){}      
  161. }      
  162.           
  163. function DoAlpha(){      
  164.     if (OpacityValue > 20){clearInterval(Timer);return 0;}      
  165.     OpacityValue += 5;        
  166.     SetOpacity($("msgBoxMask"),OpacityValue);      
  167. }      
  168. function MBMethod(obj)      
  169. {         
  170.    switch(obj.id)      
  171.    {      
  172.       case "msgBoxBtnOk" : if(MB_BACKCALL) {MB_BACKCALL(MB_OK);} else {if(MB_OK_METHOD) MB_OK_METHOD();} break;      
  173.       case "msgBoxBtnCancel" : if(MB_BACKCALL) {MB_BACKCALL(MB_CANCEL);} else {if(MB_CANCEL_METHOD) MB_CANCEL_METHOD();}       
  174.      
  175. break;      
  176.       case "msgBoxBtnYes" : if(MB_BACKCALL) {MB_BACKCALL(MB_YES);} else {if(MB_YES_METHOD) MB_YES_METHOD();} break;      
  177.       case "msgBoxBtnNo" : if(MB_BACKCALL) {MB_BACKCALL(MB_NO);} else {if(MB_NO_METHOD) MB_NO_METHOD();} break;      
  178.    }         
  179.          
  180.    MB_OK_METHOD = null;      
  181.    MB_CANCEL_METHOD = null;      
  182.    MB_YES_METHOD = null;      
  183.    MB_NO_METHOD = null;      
  184.    MB_BACKCALL = null;      
  185.          
  186.    MB_OK_TEXT = "确定";      
  187.    MB_CANCEL_TEXT = "取消";      
  188.    MB_YES_TEXT = " 是 ";      
  189.    MB_NO_TEXT = " 否";      
  190.          
  191.    $("msgBox").style.display = "none";        
  192.    $("msgBoxMask").style.display = "none";           
  193.    GetBrowserDocument().style.overflow = "";       
  194.    GetBrowserDocument().scrollTop = ScrollTop;      
  195.    GetBrowserDocument().scrollLeft = ScrollLeft;       
  196. }      
  197. String.prototype.toFormatString = function(){        
  198.    var _str = this;      
  199.    for(var i = 0; i < arguments.length; i++){          
  200.       _str = eval("_str.replace(///{"+ i +"//}/ig,'" + arguments[i] + "')");      
  201.    }      
  202.    return _str;      
  203. }      
  204. function $(obj){      
  205.    return document.getElementById(obj);      
  206. }      
  207. ///      
  208. </script>      
  209. <script language="javascript">      
  210. function test()      
  211. {      
  212.    var _msg = "<font color=red><b>演示:</b></font><br/>普通对话框!";      
  213.    MessageBox(_msg);      
  214. }      
  215. function test1()      
  216. {      
  217.   MB_OK_METHOD = function(){alert('你按了OK');}      
  218.   MB_YES_METHOD = function(){alert('你按了YES');}      
  219.   MB_NO_METHOD = function(){alert('你按了NO');}      
  220.   MB_CANCEL_METHOD = function(){alert('你按了CANCEL');}       
  221.         
  222.   var _msg = "<font color=red><b>演示:</b></font><br/>调用对话框。是、否、取消";      
  223.   MessageBox(_msg,"演示",null,MB_YESNOCANCEL);        
  224. }      
  225. function test2()      
  226. {       
  227.   var _msg = "<font color=red><b>演示:</b></font><br/>调用对话框。是、否、取消";      
  228.   MessageBox(_msg,"演示",MB_ICON,MB_YESNOCANCEL,callback);      
  229. }      
  230. function test4()      
  231. {       
  232.   var _msg = "<font color=red><b>演示:</b></font><br/>调用对话框。确定、取消";      
  233.   MessageBox(_msg,"演示",MB_ICON,MB_OKCANCEL,callback);      
  234. }      
  235. function callback(value)      
  236. {      
  237.   switch(value)      
  238.   {      
  239.      case MB_OK : alert('你按了OK'); break;//或者点击跳转到另一个页面:location.href="http://www.baidu.com";break;      
  240.      case MB_YES : alert('你按了YES'); break;      
  241.      case MB_NO : alert('你按了NO'); break;      
  242.      case MB_CANCEL : alert('你按了CANCEL'); break;      
  243.    }      
  244. }      
  245. function test3()      
  246. {       
  247.   MB_YES_TEXT = "演示一";      
  248.   MB_NO_TEXT = "演示二";      
  249.   MB_CANCEL_TEXT = "演示三";      
  250.   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>";      
  251.   MessageBox(_msg,"演示",MB_ICON,MB_YESNOCANCEL,callback);      
  252. }      
  253. </script>      
  254. </head>      
  255. <body>      
  256. <table width="1000" align="center" border="1" bordercolor="#000000">      
  257.   <tr>      
  258.     <td> </td>      
  259.     <td align="center"><a href="javascript:test()">普通演示</a></td>      
  260.     <td> </td>      
  261.   </tr>      
  262.   <tr>      
  263.     <td> </td>      
  264.     <td align="center"><a href="javascript:test1()">回调演示一</a>      
  265.     <label></label></td>      
  266.     <td> </td>      
  267.   </tr>      
  268.   <tr>      
  269.     <td> </td>      
  270.     <td align="center"><a href="javascript:test2()">回调演示二      
  271.             
  272.     </a></td>      
  273.     <td> </td>      
  274.   </tr>      
  275.   <tr>      
  276.     <td> </td>      
  277.     <td align="center"><a href="javascript:test4()">回调演示三</a><a href="javascript:test3()"></a></td>      
  278.     <td> </td>      
  279.   </tr>      
  280.   <tr>      
  281.     <td> </td>      
  282.     <td align="center"><a href="javascript:test3()">自定义演示      
  283.             
  284.     </a></td>      
  285.     <td> </td>      
  286.   </tr>      
  287. </table>      
  288. <div align="center"><input name="" value="自定义演示" type="button" οnclick="test3()" /></div>      
  289. </body>      
  290. </html>    

 

评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值