jQueryUI入门到精通-常用功能实战

上传人:仙*** 文档编号:161863792 上传时间:2022-10-15 格式:DOC 页数:22 大小:464KB
收藏 版权申诉 举报 下载
jQueryUI入门到精通-常用功能实战_第1页
第1页 / 共22页
jQueryUI入门到精通-常用功能实战_第2页
第2页 / 共22页
jQueryUI入门到精通-常用功能实战_第3页
第3页 / 共22页
资源描述:

《jQueryUI入门到精通-常用功能实战》由会员分享,可在线阅读,更多相关《jQueryUI入门到精通-常用功能实战(22页珍藏版)》请在装配图网上搜索。

1、一.摘要本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案, 即使你会使用jQuery也能在阅读中发现些许秘籍.本文是实战篇. 使用jQueryUI完成制作网站的大部分常用功能. 二.前言经过公司内部收集, 整理了一些经常使用javascript实现的功能. 实现这些功能的主角不是让人眼花缭乱的jQuery插件, 而是jQuery UI.如果你还在为了一个小小的特效而去下载并安装插件, 发现Bug还没有人替你解决. 记住插件是我们没有办法的最后选择. 使用插件有太多的坏处:1.不利于维护2.增加页面大小3.不利于成员间交流共享,具有学习成本.4.不够健壮, 不

2、能保证插件版本一直更新并修复所有问题.下面就引入今天的主角:jQuery UI三.jQuery UI jQuery UI 是 jQuery 的一部分, 是在jQuery之上的一套专门用于UI交互的类库. 使用jQuery UI可以实现底层交互, 各种高级特效, 动画, 并且可定制主题.我们可以用它轻松的构建高度交互的Web应用程序.官方首页: http:/jqueryui.org/下载: 示例和文档: 皮肤: jQuery UI 的在线网站十分强大. 首先就是在下载时可以组装自己想要的功能定制下载:并且针对各种控件不仅提供了详细的参数说明和实例, 还可以随时更换实例的皮肤:本文主要讲解实例,

3、大家可以通过实例代码快速上手jQuery UI. 使用jQuery UI我们可以再不借助其他插件的情况下完成大部分页面应用, 说其是一个官方的超级UI插件也不为过. 包含所有功能的jQuery UI类库文件为188K, 启用Gzip压缩后是45K. 虽然较大但是一次加载全网站获益.而且45K大小在当今的互谅网时代还算可以接受. ()目前还没有jQuery UI的中文教程. 因为本文是实战篇, 所以不会仔细讲解基础内容. 在后面的章节中我会加入jQuery UI的基础教程.争取成为中文jQuery UI第一教程.四. 准备工作我将所有相关的文件, 包括各种类库文件, Theme模板放置在如下路径

4、:此路径开通了目录浏览, 可以直接查找需要的文件. 目录组织结构按照本系列: (八) 插播:jQuery实施方案 中介绍的方案组织.另外也可以从Google上引用文件, Google的CDN速度更快也更有保证, 参见: Googles CDN本文的实例的所有引用都使用 WebConfig.ResourceServer 这个属性:public class WebConfig public static string ResourceServer = 五.弹出层对话框弹出框是最常用最实用的功能. 先来看一下艺龙网上的一些应用场景.1. 艺龙网应用场景举例(1) 静态提示类弹出层. 弹出层的内容是固

5、定的.(2) 动态提示类弹出层. 弹出层内容是根据事件源变化的. (3)遮罩类弹出层. 弹出时背景变灰并不可点击.2. 应用实例使用 jQuery UI 的 Dialog 组件. 我以轻松实现上面三种效果. Dialog组件的主要特点是可以拖动(Draggable), 可以改变大小(Resizable) .示例完整代码如下: jQuery UI - 弹出层应用实例 Dialog link rel=stylesheet type=text/css href= / script type=text/javascript src=/JsLib/jquery/jquery-min-lastest.js

6、 script src=/JsLib/jquery/ui/jquery-ui-all-min-lastest.js type=text/javascript /*= 必须放在头部加载的语句块. 尽量避免使用 =*/ Demo. 共享同一个静态弹出层, 弹出层内容固定: 显示提示   显示提示   显示提示   显示提示   Demo. 每个弹出层内容不同, 弹出层内容存储在事件源的元素属性中: 红色   绿色   Demo. 弹出IFrame 弹出层 /*=用户自定义方法=*

7、/ /*=事件绑定=*/ $(function() /静态提示类弹出层 $(spanid=spanShowTip).css(cursor, pointer).click(function(event) $(*).stop(); event.stopPropagation(); var top = $(event.target).offset().top + 20; var left = $(event.target).offset().left; $(#divTip).dialog(option, position, left, top); $(#divTip).dialog(open); )

8、; /动态提出类弹出层 $(spanid=spanShowDataTip).css(cursor, pointer).click(function(event) $(*).stop(); $(#divTip).dialog(close); event.stopPropagation(); var top = $(event.target).offset().top + 20; var left = $(event.target).offset().left; $(#divTip).html($(event.target).attr(data); $(#divTip).dialog(option

9、, position, left, top); $(#divTip).dialog(open); ); /遮罩类弹出层 $(#btnShowIframe).click(function(event) event.preventDefault(); event.stopPropagation(); $(#divIframe).dialog(open); ); /单击自身取消冒泡 $(#divTip, #divIframe).bind(click, function(event) event.stopPropagation(); ); /document对象单击隐藏所有弹出层 $(document

10、).bind(click, function(event) $(#divTip).dialog(close); $(#divIframe).dialog(close); ); ); /*=加载时执行的语句=*/ $(function() /初始化提示类弹出层 $(#divTip).dialog( show: null, bgiframe: false, autoOpen: false ); /初始化遮罩类弹出层 $(#divIframe).dialog( show: null, bgiframe: false, autoOpen: false, width: 500, height: 300,

11、 draggable: true, resizable: false, modal: true ); ); 效果如图:静态提示类弹出层动态提示类弹出层:遮罩类弹出层:3.关键点讲解(1)计算弹出层位置提示类弹出框最重要的是计算弹出框的位置. 通过事件对象获取到事件源, 使用offset()函数计算事件源相对于document的位置: var top = $(event.target).offset().top; var left = $(event.target).offset().left;因为是相对于document, 即页面左上角的位置, 所以需要将弹出层放在Body元素中的第一层. 即

12、父类就是body. 如果包含在其他元素中, 需要确定任何一个父类的position样式设置为了relative.计算出来的top和left是事件源的位置, 在此位置显示会将事件源对象遮盖住. 所以通常需要手工做一些偏移, 比如top+20.(2) 取消冒泡和浏览器默认行为如果我们为document对象绑定了单击后关闭弹出层的事件, 那么就一定要取消事件的冒泡. 使用event对象的stopPropagation()方法可以取消冒泡.event.stopPropagation();对于具有默认行为的元素,比如提交按钮的提交表单行为, 元素的超链接行为等, 我们如果在这些元素上应用事件, 还需要取

13、消它们的默认行为:event.preventDefault();(3) 设置动画效果与取消动画通过设置dialog的配置项的show属性, 可以设置显示dialog时候的动画效果:$(.selector).dialog( show: slide );show默认为null即无动画, 可以是使用下列值:blind, clip, drop, explode, fold, puff, slide, scale, size, pulsate.对于这些动画的效果, 可以在此页观看: 当一个动画效果执行时, 如果用户在此对这个元素进行操作, 就会出现各种问题, 比如定位不准确等. 所以如果应用了动画, 我

14、们在对其操作时需要使用stop()函数来停止动画, 通常是停止虽有元素的动画:$(*).stop();但是即使停止了动画再进行操作, 如果操作的太快也容易产生问题. 所以至于是否使用动画需要经过权衡决定.(4) 动态提示类弹出层的数据传递动态提示类弹出层的数据是不同的, 本文实例使用的是将数据存储在元素属性data上:红色这是一种简单直观的方式. 比较容易编程实现(尤其是在使用MVC编程模型的时候.)还有一种常用方式是使用javascript变量存储数据.这两种方式在第5章时有过讲解:(5)更换主题大家注意实例中的弹出层没有为其编辑任何样式, 但是显示出来后已经被美化过了. 这是因为我引用了j

15、Query UI的主题: link rel=stylesheet type=text/css href= / 注释中有很多的主题, 只需要将引用路径中的redmond改为其中任何一个, 弹出层的样式会立刻发生变化.VS中有一个Bug, 就是针对link标签, href中的语句块编译有问题, 某些情况下不被编辑解析. 所以我使用上面代码中的方式构造href属性值.( )可以在下面的地址查看各个主题的效果:六.Tab标签不刷新页面, 在页面中的不同标签间切换:本实例通过jQuery UI的Tabs组件实现. Tabs组件的使用与dialog一样十分简单, 默认的配置即可实现最简单的tab, 通过设

16、置更多的options可以实现更复杂的应用. 1.应用实例源代码: jQuery UI - 弹出层应用实例 Dialog link rel=stylesheet type=text/css href= / script type=text/javascript src=/JsLib/jquery/jquery-min-lastest.js script src=/JsLib/jquery/ui/jquery-ui-all-min-lastest.js type=text/javascript /*= 必须放在头部加载的语句块. 尽量避免使用 =*/ One Two Three Tab1内容 T

17、ab3内容 One Two Three Tab1内容 Tab2内容 Tab3内容 One Two Three Tab1内容 Tab2内容 Tab3内容 /*=用户自定义方法=*/ /*=事件绑定=*/ $(function() ); /*=加载时执行的语句=*/ $(function() /默认Tabs $(#tabs1).tabs(); /可折叠的Tabs $(#tabs2).tabs( collapsible: true ); /鼠标滑动即切换的Tabs $(#tabs3).tabs( event: mouseover ); ); 效果:1. 默认设置的Tabs, Two标签内容使用Aja

18、x获取2.再折叠tab3.鼠标滑动即切换的tab 2.要点讲解(1) 注意Tabs中的HTML结构. 使用ul构建标签. 内容div一定要和标签关联, 没有关联的div将不被处理直接显示.(2) 使用Ajax可以不指定内容容器, 但是也可以将Ajax内容放入指定容器中. . . (3) 活用事件tab有很多事件:select, load, show, add, remove, enable, disable使用这些事件可以完成很多复杂任务. 需要注意事件的签名:$(#example).bind(tabsselect, function(event, ui) / Objects availabl

19、e in the function context: ui.tab / anchor element of the selected (clicked) tab ui.panel / element, that contains the selected/clicked tab contents ui.index / zero-based index of the selected (clicked) tab);第一个是事件对象, 第二个ui对象是传递的额外参数, 我们可以获取tab对象, tab所在容器和tab的索引值.比如我们可以在事件中做验证:$(#example).tabs( sele

20、ct: function(event, ui) var isValid = . / form validation returning true or false return isValid; );或者当添加一个tab时立刻切换到选中状态:var $tabs = $(#example).tabs( add: function(event, ui) $tabs.tabs(select, # + ui.panel.id); );活学活用, 更多应用大家也可以参见tab组件的官方文档:七. 手风琴菜单使用jQuery UI的accordion组件可以实现手风琴菜单. 效果见下图.accordion

21、文档地址: 1.实例效果2.实例代码 jQuery UI - 手风琴菜单应用实例 Accordion link rel=stylesheet type=text/css href= / script type=text/javascript src=/JsLib/jquery/jquery-min-lastest.js script src=/JsLib/jquery/ui/jquery-ui-all-min-lastest.js type=text/javascript /*= 必须放在头部加载的语句块. 尽量避免使用 =*/ body font-size: 12px; 菜单1 菜单1的内容

22、 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单2 菜单2的内容 菜单3 菜单3的内容 菜单1 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单2 菜单2的内容 菜单3 菜单3的内容 菜单1 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单1的内容 菜单2 菜单2的内容 菜单3 菜单3的内容 /*=用户自定义方法=*/ /*=事件绑定=*/ $(function() ); /*=加载时执行的语句=*/ $(function() /默认配置的Accordion菜

23、单 $(#accordion1).accordion(); /取消自动高度, 可折叠 $(#accordion2).accordion( autoHeight:false, collapsible: true ); /鼠标滑动触发, 自定义图标 $(#accordion3).accordion( icons: header: ui-icon-circle-arrow-e, headerSelected: ui-icon-circle-arrow-s , event: mouseover ); ); 3. 关键点讲解(1) 注意高度设置过小问题当包含accordion控件的容器高度设计过小时,

24、在FireFox3中在此容器后面的内容会被accordion控件部分遮盖. 在IE中没有此问题. 经检查是因为容器高度小于菜单高度导致. 所以我们在应用时应当注意不要将容器高度设置过小.(2) 部分关键属性autoHeight: 设置是否自动将内容高度设置为容器高度. collapsible: 设置是否可折叠一般上面两个配合使用, 以为折叠后肯定会改变菜单高度, 会导致autoHeight设置为true无效.更多属性和事件使用请参阅官方文档.八.总结本章简单介绍了jQueryUI, 并且使用jQuery UI完成了弹出层,tabs,手风琴菜单的应用实例. 使用jQuery UI可以不需要额外寻找插件. 并且实现简单.但是有些功能是必须使用插件完成的. 下一张讲解两个插件实例: 自动完成插件AutoComplete 和 表单验证插件jQuery Validate.本章源代码下载:

展开阅读全文
温馨提示:
1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
2: 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
3.本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

copyright@ 2023-2025  zhuangpeitu.com 装配图网版权所有   联系电话:18123376007

备案号:ICP2024067431-1 川公网安备51140202000466号


本站为文档C2C交易模式,即用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。装配图网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知装配图网,我们立即给予删除!