知问前端——对话框UI(二)
dialog()方法的事件
除了属性设置外,dialog()方法也提供了大量的事件,这些事件可以给各种不同状态时的对话框提供回调函数,这些回调函数中的this值等于对话框内容的div对象,不是整个对话框的div。
dialog事件选项
| 事件名 | 说明 |
| focus | 当对话框被激活时(首次显示以及每次在上面点击)会调用focus方法,该方法有两个参数(event, ui)。此事件中的ui参数为空。 |
| create | 当对话框被创建时会调用create方法,该方法有两个参数(event, ui)。此事件中的ui参数为空。 |
| open | 当对话框被显示时(首次显示或调用dialog('open')方法)会调用open方法,该方法有两个参数(event, ui)。此事件中的ui参数为空。 |
| beforeClose | 当对话框将要关闭时(当单击关闭按钮或调用dialog('close')方法),会调用beforeClose方法。如果该函数返回false,对话框将不会被关闭。关闭的对话框可以用dialog('open')重新打开。该方法有两个参数(event, ui)。此事件中的ui参数为空。 |
| close | 当对话框关闭后(当单击关闭按钮或调用dialog('close')方法),会调用close方法。关闭的对话框可以用dialog('open')重新打开。该方法有两个参数(event,ui)。此事件中的ui参数为空。 |
| drag | 当对话框移动时,每次移动一点均会调用drag方法。该方法有两个参数。该方法有两个参数(event, ui)。此事件中的ui有两个属性对象: 1.position,得到当前移动的坐标,有两个子属性:top和left。 2.offset, 得到当前移动的坐标, 有两个子属性: top和left。 |
| dragStart | 当开始移动对话框时,会调用dragStart方法。该方法有两个参数(event, ui)。此事件中的ui有两个属性对象: 1.position,得到当前移动的坐标,有两个子属性:top和left。 2.offset, 得到当前移动的坐标, 有两个子属性: top和left。 |
| dragStop | 当结束移动对话框时,会调用dragStop方法。该方法有两个参数(event, ui)。此事件中的ui有两个属性对象: 1.position,得到当前移动的坐标,有两个子属性:top和left。 2.offset,得到当前移动的坐标, 有两个子属性: top和left。 |
| resize | 当对话框拉升大小的时候,每一次拖拉都会调用resize方法。该方法有两个参数(event, ui)。此事件中的ui有四个属性对象: 1.size,得到对话框的大小,有两个子属性:width和height。 2.position,得到对话框的坐标,有两个子属性:top和left。 3.originalSize,得到对话框原始的大小,有两个子属性:width和height。 4.originalPosition,得到对话框原始的坐标,有两个子属性:top和left。 |
| resizeStart | 当开始拖拉对话框时,会调用resizeStart方法。该方法有两个参数(event, ui)。此事件中的ui有四个属性对象: 1.size,得到对话框的大小,有两个子属性:width和height。 2.position,得到对话框的坐标,有两个子属性:top和left。 3.originalSize,得到对话框原始的大小,有两个子属性:width和height。 4.originalPosition,得到对话框原始的坐标,有两个子属性:top和left。 |
| resizeStop | 当结束拖拉对话框时,会调用resizeStop方法。该方法有两个参数(event, ui)。此事件中的ui有四个属性对象: 1.size,得到对话框的大小,有两个子属性:width和height。 2.position,得到对话框的坐标,有两个子属性:top和left。 3.originalSize,得到对话框原始的大小,有两个子属性:width和height。 4.originalPosition,得到对话框原始的坐标,有两个子属性:top和left。 |
jQuery代码:
index.html:
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>知问前端</title>
<script type="text/javascript" src="jquery-1.12.3.js"></script>
<script type="text/javascript" src="jquery-ui.js"></script>
<script type="text/javascript" src="index.js"></script>
<link rel="shortcut icon" type="image/x-icon" href="img/favicon.ico" />
<link rel="stylesheet" type="text/css" href="jquery-ui.css" />
<link rel="stylesheet" type="text/css" href="style.css" />
</head>
<body>
<div id="header">
<div class="header_main">
<h1>知问</h1>
<div class="header_search">
<input type="text" name="search" class="search" />
</div>
<div class="header_button">
<input type="button" value="查询" id="search_button" />
</div>
<div class="header_member">
<a href="###" id="reg_a">注册</a> | <a href="###" id="login_a">登录</a>
</div>
</div>
</div> <div id="reg" title="会员注册">
表单区--会员注册
</div> <div id="login" title="会员登录">
表单区--会员登录
</div> </body>
</html>
focus——当对话框获得焦点后,【当对话框被激活时(首次显示以及每次在上面点击)会调用focus方法】:
$("#reg").dialog({
focus:function(e,ui) {
alert("注册!");
}
});
$("#login").dialog({
focus:function(e,ui) {
alert("登录!");
}
});
当点击会员注册对话框,会调用其对应的focus();当点击会员登录对话框,会调用其对应的focus()。
create——当创建对话框时:
$('#reg').dialog({
create : function(e, ui) {
alert('创建对话框');
}
});
open——①当首次显示对话框时:
$('#reg').dialog({
open:function() {
alert("首次打开对话时触发!");
}
});
②当调用dialog('open')方法显示对话框时:
$('#reg').dialog({
autoOpen:false,
open:function() {
alert("调用dialog('open')方法打开对话时触发!");
}
});
$("#reg_a").click(function() {
$("#reg").dialog("open");
});
close——①当单击关闭按钮关闭对话框时:
$('#reg').dialog({
close:function() {
alert("单击关闭按钮关闭对话框!");
}
});
②调用dialog('close')方法关闭对话框时:
$('#reg').dialog({
autoOpen:false,
close:function() {
alert("调用dialog('close')方法关闭对话框!");
}
});
//点击div(id="reg")元素关闭
$("#reg").click(function() {
$("#reg").dialog("close");
});
beforeClose——同close,只是对话框将要关闭时(我觉得应该是在关闭之前)(当单击关闭按钮或调用dialog('close')方法),会调用beforeClose方法。如:
$('#reg').dialog({
beforeClose:function() {
alert("对话框将要关闭,关闭前做的事!");
}
});
如果该函数返回false,对话框将不会被关闭:
$('#reg').dialog({
//这个事件可以做一些关闭确认的工作
beforeClose:function() {
alert("对话框将要关闭,关闭前做的事!");
return false;
}
});
drag——当对话框移动时,每次移动一点均会调用drag方法,每次移动一点这让人很烦!
$('#reg').dialog({
drag:function() {
alert("每次移动都执行!");
}
});
此事件中的ui有两个属性对象,我们只测试position属性对象:position,得到当前移动的坐标,有两个子属性:top和left。
$('#reg').dialog({
drag:function(e,ui) {
alert("top:" + ui.position.top + "\n"
+"left:" + ui.position.left);
}
});
dragStart——当开始移动对话框时,会调用dragStart方法,同上。
$('#reg').dialog({
dragStart:function(e,ui) {
alert("top:" + ui.position.top + "\n"
+"left:" + ui.position.left);
}
});
dragStop——当结束移动对话框时,会调用dragStop方法,同上。
$('#reg').dialog({
dragStop:function(e,ui) {
alert("top:" + ui.position.top + "\n"
+"left:" + ui.position.left);
}
});
resize——当对话框拉升大小的时候,每一次拖拉都会调用resize方法,同样,这一点也让人很烦!
$('#reg').dialog({
resize:function() {
alert("每次调整大小都执行!");
}
});
此事件中的ui有四个属性对象,我们只测试size属性对象:size,得到对话框的大小,有两个子属性:width和height。
$('#reg').dialog({
resize:function(e,ui) {
alert("width:" + ui.size.width + "\n" +
"height:" + ui.size.height);
}
});
resizeStart——当开始拖拉对话框时,会调用 resizeStart方法,同上。
$('#reg').dialog({
resizeStart:function(e,ui) {
alert("width:" + ui.size.width + "\n" +
"height:" + ui.size.height);
}
});
resizeStop——当结束拖拉对话框时,会调用resizeStop方法,同上。
$('#reg').dialog({
resizeStop:function(e,ui) {
alert("width:" + ui.size.width + "\n" +
"height:" + ui.size.height);
}
});
dialog('action',param)方法
| 方法 | 返回值 | 说明 |
| dialog('open') | jQuery对象 | 打开对话框 |
| dialog('close') | jQuery对象 | 关闭对话框 |
| dialog('destroy') | jQuery对象 | 删除对话框,直接阻断了dialog |
| dialog('isOpen') | 布尔值 | 判断对话框是否打开状态 |
| dialog('widget') | jQuery对象 | 获取对话框的jQuery对象 |
| dialog('option',param) | 一般值 | 获取options属性的值 |
| dialog('option',param,value) | jQuery对象 | 设置options属性的值 |
注意:dialog('close')和dialog('destroy')的区别,dialog('close')是将对话框隐藏起来,即display: none;而dialog('destroy')是将对话框销毁掉。
初始隐藏对话框:
$('#reg').dialog({
autoOpen : false
});
打开对话框:
$('#reg_a').click(function () {
$('#reg').dialog('open');
});
点击div(id="reg")元素关闭或销毁对话框:
$("#reg").click(function() {
$("#reg").dialog("close"); //dialog('close')是将对话框隐藏起来,即display: none
$("#reg").dialog("destroy"); //dialog('destroy')是将对话框直接销毁掉
});
判断对话框打开或关闭状态:
alert($("#reg").dialog("isOpen")); //若对话框属性autoOpen:false,则返回false,反之,则返回true
现在来讨论dialog('open')和dialog('widget')的返回值!
dialog('open'):
$('#reg').dialog({
autoOpen : false
});
alert($("#reg").dialog("open")); //[object Object],返回jQuery对象,即对话框内容的div(id="reg")对象
所以可以连缀使用常用方法:
$("#reg").dialog("open").css("font-size", "50px");
dialog('widget'):
$("#reg").dialog("open");
alert($("#reg").dialog("widget")); //返回整个对话框div对象
当然可以连缀使用了。
$("#reg").dialog("widget").css("font-size", "50px");
获取某个options的param选项的值:
alert($("#reg").dialog("option","title"));
alert($("#reg").dialog("option","autoOpen")); //若对话框属性autoOpen:false,则返回false,反之,则返回true,同alert($("#reg").dialog("isOpen"));
设置某个options的param选项的值:
$("#reg").dialog("option","title","我爱李阿昀");
dialog中使用on()
在dialog的事件中,提供了使用on()方法处理的事件方法。
on()方法触发的对话框事件
| 特效名称 | 说明 |
| dialogfocus | 得到焦点时触发 |
| dialogopen | 显示时触发 |
| dialogbeforeclose | 将要关闭时触发 |
| dialogclose | 关闭时触发 |
| dialogdrag | 每一次移动时触发 |
| dialogdragstart | 开始移动时触发 |
| dialogdragstop | 移动结束后触发 |
| dialogresize | 每次调整大小时触发 |
| dialogresizestart | 开始调整大小时触发 |
| dialogresizestop | 结束调整大小时触发 |
on()方法的使用同上,现只讨论dialogclose事件:
$("#reg").on("dialogclose",function() {
alert("关闭!");
});
注意:还必须点击关闭按钮才能关闭对话框。
知问前端——对话框UI(二)的更多相关文章
- 第一百七十八节,jQuery-UI,知问前端--对话框 UI
jQuery-UI,知问前端--对话框 UI 学习要点: 1.开启多个 dialog 2.修改 dialog 样式 3.dialog()方法的属性 4.dialog()方法的事件 5.dialog 中 ...
- 知问前端——日历UI(二)
datapicker外观选项 属性 默认值/类型 说明 disabled false/布尔值 禁用日历 numberOfMonths 1/数值 日历中同时显示的月份个数.默认为1,如果设置3就同时显示 ...
- 知问前端——对话框UI(一)
对话框(dialog),是jQuery UI非常重要的一个功能.它彻底的代替了JavaScript的alert().prompt()等方法,也避免了新窗口或页面的繁杂冗余. 开启多个dialog 我们 ...
- 第一百八十二节,jQuery-UI,知问前端--日历 UI
jQuery-UI,知问前端--日历 UI 学习要点: 1.调用 datepicker()方法 2.修改 datepicker()样式 3.datepicker()方法的属性 4.datepicker ...
- 知问前端——日历UI(一)
日历(datepicker)UI,可以让用户更加直观的.更加方便的输入日期,并且还考虑不同国家的语言限制,包括汉语. 调用datepicker()方法 $('#date').datepicker(); ...
- 知问前端——日历UI(三)
datepicker日期选择选项 属性 默认值/类型 说明 minDate 无/对象.字符串或数值 日历中可以选择的最小日期 maxDate 无/对象.字符串或数值 日历中可以选择的最大日期 defa ...
- 知问前端——工具提示UI
工具提示(tooltip),是一个非常实用的UI.它彻底扩展了HTML中的title属性,让提示更加丰富,更加可控制,全面提升了用户体验. 调用tooltip()方法 在调用tooltip()方法之前 ...
- 知问前端——按钮UI
按钮(button),可以给生硬的原生按钮或者文本提供更多丰富多彩的外观.它不单单可以设置按钮或文本,还可以设置单选按钮和多选按钮. 使用button按钮 使用button按钮UI的时候,不一定必须是 ...
- 第一百七十九节,jQuery-UI,知问前端--按钮 UI-图标
jQuery-UI,知问前端--按钮 UI 学习要点: 1.使用 button 按钮 2.修改 button 样式 3.button()方法的属性 4.button('action', param) ...
随机推荐
- php-5.6.26源代码 - 扩展模块的种类,扩展模块的执行埋点
模块种类(两种) 类型一:zend的模块:(类似zend_extension=test.so) 识别方法: php.ini中以zend_extension开头的配置,如zend_extension=t ...
- linux下,把屏幕竖起来
xrandr -o left 向左旋转90度 xrandr -o right 向右旋转90度 xrandr -o inverted 上下翻转 xrandr -o normal 回到正常角度
- 解决win10子系统Ubuntu新装的mysql 不能root登陆方法
步骤一:打开终端 $sudo /etc/init.d/mysql stop $sudo mkdir -p /var/run/mysqld $sudo chown mysql:mysql /var/ru ...
- 希尔排序算法Java实现
希尔排序(Shell Sort)是插入排序的一种,它是针对直接插入排序算法的改进.该方法又称缩小增量排序,因DL.Shell于1959年提出而得名. 希尔排序实质上是一种分组插入方法.它的基本思想是: ...
- C语言实例解析精粹学习笔记——28
实例28:从键盘读入实数 题目要求: 编制一个从键盘读入实数的函数readreal(double *rp).函数将读入的实数字符列转换成实数后,利用指针参数rp,将实数存于指针所指向的变量*rp. 思 ...
- Wannafly挑战赛4. B
Wannafly挑战赛4. B 题意:求子区间异或和,要求区间长度在l到r之间,并且为偶数 题解:对于每一位算贡献,可以分奇偶来记录,计算的时候只加上奇偶性相同的就保证了为偶数,从大于l的点开始每次+ ...
- Clion 不能杀死进程
描述 自己使用时发现点了结束按钮后,打开任务管理器,发现刚才运行的程序还在,并没有被杀死. 有时如果一个程序写了死循环,就会出现疯狂占用内存,最后不得不关机重启. 解决方案 这是他的社区有人也有这样的 ...
- 【文件处理】xml 文件 SAX解析
SAX的全称是Simple APIs for XML,也即XML简单应用程序接口. 与DOM不同,SAX提供的访问模式是一种顺序模式,这是一种快速读写XML数据的方式. 当使用SAX分析器对XML文档 ...
- 初见spark-04(高级算子)
今天,这个是spark的高级算子的讲解的最后一个章节,今天我们来介绍几个简单的算子, countByKey val rdd1 = sc.parallelize(List(("a", ...
- Mysql 表转换成 Sqlite表
目前的转换仅仅支持对没有外键的Mysql数据表 准备: 下载安装 Sqlite Expert 软件 一 获取Mysql中的.sql文件,获取过程省略可以直接导出sql文件 二 在Sqlite Expe ...