jQuery UI目前的版本已经更新到了1.8.7。个人感觉和easyui相比起来,jQuery UI在界面的美观程度和可定制型更强一些。所以再次将一些jQuery UI组件的用法说明一下,方便日后查阅。也方面没接触jQuery UI的人能早日使用jQuery UI套件

(一)首先来说jQuery UI使用频率较高dialog组件:

dialog就是我们常说的弹出层,应用还是比较广泛的,比如:可以使用弹出层做登录、注册和消息提示等功能

下面来详细说说dialog的使用方法

在官方提供的官方文档和示例中有六种形式的dialog,但是前五种都是大同小异,包括在编写代码方面也仅仅是多设置两个属性而已,没什么太大的不同,先来看看使用jQuery UI组件的时候需要那些前期贮备工作。

首先将需要依赖的js文件导入到你的页面中。需要依赖的文件如下:

jquery-ui-1.8.7.custom.css这个是jQuery UI套件的CSS样式表,demos.css这个是jQuery UIdemo中用到的CSS样式,因为我用到了这些样式所以将它导入进来,如果大家不需要可以不导这个文件,jquery-1.4.4.min.js这个不用说了吧,jQuery的核心文件,没有它一切工作都无法开展。切记一点:一定要在引入其他的js文件之前引入jquery-1.4.4.min.js文件,别问为什么,懂点jQuery的人都能想的到。jquery-ui-1.8.7.custom.min.js这个是jQueryUI的核心js文件,也是必须的。有了上述的引用后就可以在你的页面中使用jQuery UI了。

先看一个超级简单的DEMO:

<div id="dialog" title="basic dialog"><p>这是一个采用默认样式的对话框</p></div>

在页面中加入上边的一行代码,然后加入一个script标签对,在脚本写如下代码:

$(function(){

$("#dialog").dialog();

});

打开你的页面看一下吧,如果没什么意外你会看到一个类似这样的对话框


简单吧,这就是一个弹出层,其中div的title被当作了dialog的title,右上角有关闭的xx,右下角则可以拖拽改变大小

这就是一个默认的dialog,虽然我们没有为它指定高度和宽度,但是它有默认的值,在我们没有设定情况下dialog默认会弹出在屏幕的中央,大小也是有默认值的,可以改变大小,显示关闭按钮,这都是默认的样式,那么如果我们想自己定制一下dialog,不想让他这样显示该如何做?下面介绍一些属性和方法来改变一下这个dialog,用到的属性如下:

autoOpen,modal,buttons,根据这些属性我们来定制一个不会自动打开(当点击按钮或者通过其他的事件来触发弹出dialog的事件),并且带有遮罩(模式窗体)和按钮的dialog

buttons属性是一个复合属性,使用形式如下:buttons{ok:function(){点击按钮执行的事件},cancel:function(){点击按钮执行的事件}}

其中ok是按钮显示的文本,而function是点击按钮后执行的事件。注意,在ok和function之间有冒号:,虽然按钮可以为中文,比如:确定:function(){}这种形式,但是切记,在按钮文本和function之间的冒号一定是英文字符下的冒号,不要写成中文的全角冒号,否则会有错误。

将刚才的js脚本替换为:

$("#dialog-form").dialog({

autoOpen:false,
        modal:true,

buttons:{

登录:function(){

alert("您点击了登录按钮");

}

}

})

//控制打开dialog的方法

function open_dialog(){

$("#dialog-form").dialog("open");

}

这里的dialog将带有一个登录按钮。并且为带遮罩的模式窗体。默认不显示。所以我们需要在页面添加一个按钮,通过点击按钮来控制打开dialog

<input type="button" value="打开" οnclick="open_dialog();"/>

这样当点击这个按钮时会打开这个dialog.打开后的dialog如下图:

可能有的人会说为什么这个显示的颜色和样式都第一个不一样呢?

因为jQueryUI组件的皮肤都是可定制的,而不是一尘不变。可以根据需要选择自己喜欢的皮肤样式来使用,在jQueryUI的官方网站上有UI皮肤下载的,可以先预览皮肤的效果再下载,下载后只需要将当前项目中的CSS文件即可实现切换皮肤

那么在dialog中显示的username:   password:     和两个文本框又是从何而来的?

这是自己写的一个表单,用于让用户登录的表单,还记得吗?dialog是通过在页面中指定一个div,然后得到该div对象.dialog()就可以生成dialog了,同样的道理,我们可以在这个div中加入自己想要的表单域。这个就是我自己定制的登录表单。样式采用了UI提供的样式,当然,如果你觉得这个样式不好同样是可以自己定制自己的CSS来使用。完整的表单代码如下:

<!-- 登录区域表单信息 -->

<div id="dialog-form" class="ui-widget ui-widget-content ui-corner-all" title="用户登录">

<p id="login_tip"></p>

<form id="login-form">

<fieldset>

username:<input type="text" name="name" id="name" class="text ui-widget-content ui-corner-all" />

password:<input type="password" name="password" id="password" value="" class="text ui-widget-content ui-corner-all" />

</fieldset>

</form>

</div>

大家可以看到每个input标签都有一个class属性,指定了3个class样式。这就是jQueryUI给我们提供的,不需要我们去写样式表文件。

更多的属性应用大家可以参考官方提供的文档,由于属性较多,不再一一介绍。都很简单,需要用到的时候查询一下即可

下面说说dialog中的事件调用。在上面的例子中dialog只有一个按钮,用于登录。如果我想添加另外一个按钮:关闭,当我点击关闭时关闭dialog该如何做呢?在jQueryUI中,多数组件的事件都使用如下的形式来调用:

$("#dialog").dialog("close");其中close就是事件的名称,这样当我点击这个按钮时就可以关闭该dialog了。如果要打开dialog也是同样的道理。$("#dialog").dialog("open");这个用于打开dialog。更多的方法请查阅文档,事件的功能不一样,但是用法基本一致:

都是$.dialog("事件名称");这种形式

下面我们以dialog为例,来实现一个实用dialog+form表单进行ajax注册的实例(只写前台实现,后台请根据自己所用的服务器端语言进行实现。)

首先看注册的dialog中都有什么内容。主页页面的dialog如下所示:

注册表单中有用户名、密码、email和用户的生日以及“提交”和“取消按钮”

功能描述:

当用户点击提交的时候首先进行客户端的验证,如果有不符合要求的则给与用户提示信息。提示信息会以醒目的方式显示在表单的最上方,不是alert()的方式。当验证通过后点击提交按钮发起ajax请求,将表单数据发送到后台处理,最终记录在数据库中,注册成功

先来看注册表单中div中的内容:

<div id="register-form" class="ui-widget ui-widget-content ui-corner-all" title="用户注册">

<p class="validateTips">所有的表单域都为必填项.</p>

<form id="reg-form">

<fieldset>

用户名:<input type="text" name="uname" id="uname" value="" class="text ui-widget-content ui-corner-all" />

密码:<input type="password" name="upass" id="upass" value="" class="text ui-widget-content ui-corner-all" />

email:<input type="text" name="email" id="email" value="" class="text ui-widget-content ui-corner-all" />

生日:<input type="text" readonly="readonly" name="birth" id="birth" value="" class="text ui-widget-content ui-corner-all" />

</fieldset>

</form>

</div>

上边的div中显示的就是注册表单的内容。一共四项,和大家看到的dialog中的是一致的

然后来看如何对这些数据进行验证,验证代码如下:

//注册表单相关函数和验证

//获取name,password,email和birth对象并将对象添加到一个空对象中备用

var uname = $("#uname"),

password = $("#upass"),

email = $("#email"),

birth = $("#birth"),

fields = $([]).add(uname).add(password).add(email),

tips = $(".validateTips");

$("#register-form").dialog({

//打开对话框的时候移除表单域的样式并设置错误信息显示文本为默认值

open:function(){

tips.removeClass().text("所有的表单域都为必填项.");

fields.removeClass("ui-state-error");

fields.val("");

},

modal:true,//弹出带有遮罩的模式窗体

autoOpen:false,//不自动打开

buttons:{

提交:function(){

//点击提交按钮时执行的事件

var chk = true;

//验证字段长度是否符合要求

chk = chk && checkLength(uname,"username",2,15);

chk = chk && checkLength(password,"password",6,20);

chk = chk && checkLength(email,"email",6,40);

chk = chk && checkLength(birth,"birthday",8,10);

//正则表达式验证用户名和email是否合法

chk = chk && checkReg(name,/^([\u4E00-\uFA29]|[\uE7C7-\uE7F3]|[a-zA-Z])|_\w*$/,"用户名必须以字母、下划线或者汉字开头,请修改后提交");

chk = chk && checkReg(email,/\w+([-+.']\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$/,"请输入正确的email格式,格式如下:admin@yahoo.com");

在上边的验证中使用到了checkLength()方法和checkReg方法,这两个方法分别都是自定义方法,分别是验证字段长度和通过正则表达式验证输入是否合法的方法,在jQueryUI官方提供的Demo里也有相应的方法,我在这里对方法做修改,因为官方的DEMO中当验证失败后,重新打开DIALOG时,验证失败的提示信息和错误样式都还保存着。而我写的方法已经做了修改。不会有这样的问题,下面是checkLength和checkReg方法,方法的注释我写的很清楚了,不再解释,我会说下关于添加错误CSS样式的东西。

//判断字段长度是否符合要求的方法,四个参数分别为:o被检测的对象,msg被检测对象显示名称

//min允许的最小长度,max允许的最大长度

function checkLength(o,msg,min,max){

if(o.val().length > max || o.val().length < min){

o.addClass("ui-state-error");//为当前的错误域添加CSS样式

updateTip(msg+"的长度必须在"+min+"到"+max+"之间");//更新提示区域的信息

return false;

}else{

//如果验证通过则移除当前对象的CSS错误样式

o.removeClass("ui-state-error");

return true;

}

}

//通过正则表达式验证内容的方法,o为表单域对象,reg为正则表达式,n为错误提示信息

function checkReg(o,reg,n){

if(!reg.test(o.val())){

o.addClass("ui-state-error");

updateTip(n);

return false;

}else{

o.removeClass("ui-state-error");

return true;

}

}

在这两个方法中都用到了一个updateTip方法,该方法的作用就是给那个<p>标签也就是错误消息显示的地方添加一个css样式,用来高亮提示用户的。方法如下:

//更新提示信息的方法,传递的参数t为显示的错误信息,然后为显示信息的标签添加高亮

function updateTip(t){

tips.text(t).addClass("ui-state-highlight");

}

验证的过程就是如上面显示的那样,方法都有比较详细的注释,大家可以自己看

当用户输入的都被我们验证,并通过后,应该像后台发起ajax请求了。具体代码如下:

此处用到了一个formSerialize()方法,是一个jquery.form.js的脚本文件,针对表单的一个jq插件,可以序列化表单,这样我们只需要把序列化后的值传递给后台就行,不用一个个获取再拼接了。如果需要用到请自行引入该脚本

if(chk){

//验证通过后移除提示处的样式和错误消息

tips.removeClass().text("");

//序列化表单

var user = $("#reg-form").formSerialize();

//发起ajax请求

$.ajax({

type:'post',

url: '${path}/UserAction?method=register',

data:user,

success:function(msg){

if(msg == "success"){

$("#register-form").dialog("close");

}else{

alert("服务器异常,请稍后再试");

}

},

error:function(){

alert("ajax请求失败");

}

});

}

整个的注册流程就是这样,当注册完成后会关闭dialog,下面的图片显示当验证出现错误时的样式

转载于:https://www.cnblogs.com/goloving/p/6951206.html

jQuery UI全教程之一(dialog的使用教程)相关推荐

  1. jQuery UI dialog插件出错信息:$(this).dialog is not a function

    使用jQuery UI 1.7.2 dialog插件,遇到这样的错误: [img]http://dl.iteye.com/upload/attachment/308166/97c428e4-2ce2- ...

  2. jQuery UI(三十八)

    jQuery UI 实例 - 对话框(Dialog) 在一个交互覆盖层中打开内容. 如需了解更多有关 dialog 部件的细节,请查看 API 文档 对话框部件(Dialog Widget). 默认功 ...

  3. w3cschool教程之jQuery UI 教程概述

    w3cschool教程之jQuery UI 教程概述 链接地址: http://www.w3cschool.cc/jqueryui/jqueryui-tutorial.html w3cschool教程 ...

  4. JQuery UI库 - Dialog

    在网站中我们经常会做一些好看的Popup Dialog,我们前面曾经讲过用JQuery的Importo插件 来做自定义的AlertBox. 其实,我们可以利用JQuery官方提供的UI库来做. 而且, ...

  5. 解决Select2控件不能在jQuery UI Dialog中不能搜索的bug

    本文使用博客园Markdown编辑器进行编辑 1.问题呈现 项目中使用了jQuery UI的Dialog控件,一般用来处理需要提示用户输入或操作的简单页面.逻辑是修改一个广告的图片和标题. 效果截图如 ...

  6. html 输入框自动缩短 一行内显示,JQuery UI组合框自动补全功能改进版(即时全部显示+input内容保存)...

    JQuery UI Autocomplete(自动补全)功能在input前端设计中非常有用,最近一个项目正好用到,仔细研究了下组合框(combobox)的自动补全部分,官方地址是:https://jq ...

  7. Jquery ui的dialog使用文档概述

    Jquery ui的dialog使用文档概述 一个浮动的窗口,包含标题和内容两部分.可以移动,调整大小,以及关闭图标'×'.如果内容长度超过了对话框内容区域的显示,则会自动出现滚动条.除此之外,还有一 ...

  8. jquery系列教程7-自定义jquery插件全解:对象函数、全局函数、选择器

    点击打开: jquery系列教程1-选择器全解 jquery系列教程2-style样式操作全解 jquery系列教程3-DOM操作全解 jquery系列教程4-事件操作全解 jquery系列教程5-动 ...

  9. jQuery UI dialog实现dialog弹框显示

    实现弹框,比较精美的jQuery.ui.*:来实现,弹框显示: jsp页面代码[jqueryuidialog.jsp]: <%@ page language="java" i ...

最新文章

  1. 使用C#格式化字符串
  2. 忙~~~~~~~~~~~~~~~~~
  3. 将您重定向的次数过多什么意思_电池循环次数是什么意思?怎么计算的?
  4. 今天的雪糕格外好吃!
  5. PHP密码问题陈婷代码_PHP实现登录注册
  6. 即时聊天IM之二 openfire 整合现有系统用户
  7. android自动布局优先级,自动布局AutoLayout
  8. 服务器内存超限问题_内存超限该怎么办?
  9. java怎么部署_java项目服务器如何部署?项目服务器的部署步骤
  10. ASA k8 升 k9
  11. 主成分分析在SPSS上的实现与结果分析——基于SPSS实验报告
  12. 基因测序技术发展历史以及一、二、三代测序技术原理及应用
  13. QQmlContext设置上下文
  14. 会议,如何从智能走向智慧?——四川有生发布智慧会议平台
  15. excel计算机一级打不开,【2人回答】Excel表格太大,电脑打不开如何解决?-3D溜溜网...
  16. jquery 入门(jquery是什么/与JavaScript的联系与区别/jquery版本/引包/入口函数)
  17. ABP框架心得系列-1.本土化和ABP核心
  18. python google 搜索结果爬取_python爬取百度谷歌搜索结果
  19. debian系统怎么连接服务器,zh_CN/SystemPrinting
  20. [Java8]_[语言特性]_[Lambda表达式说明]

热门文章

  1. tableau选择计算_干货 | 年薪40W, 掌握Tableau的留学生真的赚翻了
  2. 反射与泛型 java_Java的反射 和 泛型的一个问题
  3. python数码时钟代码_Python+Pyqt实现简单GUI电子时钟
  4. 剑指 Offer 40-----50
  5. WebRTC Google的 BBR拥塞控制算法解析
  6. 【WebRTC---进阶篇】(一)服务器基础编程
  7. C/C 代码规范注释有哪些讲究?
  8. n76e885_新唐N76E003,N76E616烧录,调试各种问题集【坑集】
  9. star-cd linux安装,linux 使用PXE方式,kickstar网络安装系统
  10. 东芝硬盘插入台式机后滴滴响