栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

基于jQuery的弹出警告对话框美化插件(警告,确认和提示)

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

基于jQuery的弹出警告对话框美化插件(警告,确认和提示)

前不久在官方网站是看见这个插件,所以今天趁有空就看了一下,随便给大家共享一下。也许你早已知道了

,如果是这样那请跳过,不要拍砖。

这个Jquery插件的目的是替代Javascript的标准函数alert(),/confirm/i(),和 prompt()。这个插件有

如下这些特点:

1:这个插件可以使你可以支持你自己的css制定。使你的网站看起来更专业。

2:允许你自定义对话框的标题。

3:在IE7中,可以使你避免使用Javascript 的prompt()函数带来的页面重新加载。

4:这些方法都模拟了Windows的模式对话框。在你改变改变浏览器窗口大小时候,它能够自适应用户

窗口的调整。

5:如果你引入了jQuery UI Draggable plugin插件,那这个插件也可以被自由拖动。

先在这里说插件的下载地址,以供有需之人下载:

http://labs.abeautifulsite.net/projects/js/jquery/alerts/jquery.alerts-1.1.zip

一:首先在导入JQuery,jquery.ui.draggable
和jquery.alerts的 css、js文件。








为了在iE中正确的使用alert插件,你还得在Page中加入何时DTD:


http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

二:使用
我们可以用下列方式来使用这个Jquery插件。

jalert(message, [title, callback])
jConfirm(message, [title, callback])
jprompt(message, [value, title, callback])
注:不同于Javascript标准函数,我们可以在message中使用HTML参数显示你的提示信息。

三:兼容性:
alert插件要求我们必须使用JQuery1.2.6或以上的jQuery包。

已经被测试能够在IE6、IE7、FF2、FF3、Safari 3 、Chrome 、Opera 9浏览器上很好的运行。

四:Demo:注:在Demo中么有引入dragonable插件所以不能拖拽
Test alert
复制代码 代码如下:
jalert('This is a custom alert box;

本示例来自破浪博客',
'alert Dialog');

Test Confirm
复制代码 代码如下:
jConfirm('Can you confirm this?

本示例来自破浪博客',
'Confirmation Dialog', function(r) {
jalert('/confirm/ied: ' + r, 'Confirmation Results');
});

Test prompt
复制代码 代码如下:
jprompt('Type something:<
a href="http://www.cnblogs.com/whitewolf/">
本示例来自破浪博客',
'WhiteWolf', 'prompt Dialog', function(r) {
if( r ) alert('You entered ' + r);
});

关于j/confirm/i回传的解决方案
我趁今天有空就考虑了下。我觉得lastwinter问这个问题应该是关于ASP.NET的回传问题,这主要是j/confirm/i这个为CallBack回调,
他是异步的,并非同步。
所以我尝试了下阻止事件的冒泡,并当选择为true是自动回传。用linkButton测试(Button不同于这个解决的方案在后面解释)
现贴出linkButton的CODE DEMO:
关于j/confirm/i回传DEMO
复制代码 代码如下:
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %>














linkButton1 Button Click CODE
复制代码 代码如下:
protected void Button1_Click(object sender, EventArgs e)
{
this.Label1.Text = DateTime.Now.ToString();
}

主要为先阻止事件的冒泡event.stopPropagation();event.preventDefault(); 在j/confirm/i的callback回调函数中判断是否需要回传,
<%= Page.Clientscript.GetPostBackClientHyperlink(linkButton1,"") %>;;
点击linkButton1是效果为:

点击Cancel时候就不会回传,当ok时候就会发生回传更新时间:

对于我们的linkButton的实现是在输出的客户端Html代码有脚本自动回传,而Button这是HTML元素submit,提交,
所以在这两个的区别下,linkButton就多了几处javascript 代码:
复制代码 代码如下:


和 input Hidden
复制代码 代码如下:



上面所说的意思就是如果要用Button实现同样的示例,我们必须保证我的输出客户端的代码有这些回传脚本注册,还有就是回传为
<%=Page.Clientscript.GetPostBackEventReference(Button1,"") %>。所以我觉得用linkButton更适合。
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/115837.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号