从零开始学习jQuery (十) jQueryUI常用功能实战分享

本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案, 即使你会使用jQuery也能在阅读中发现些许秘籍.


本系列文章将带您进入jQuery的精彩世界, 其中有很多作者具体的使用经验和解决方案, 即使你会使用jQuery也能在阅读中发现些许秘籍.

本文是实战篇. 使用jQueryUI完成制作网站的大部分常用功能.

二.前言

经过公司内部收集, 整理了一些经常使用javascript实现的功能. 实现这些功能的主角不是让人眼花缭乱的jQuery插件, 而是jQuery UI.

如果你还在为了一个小小的特效而去下载并安装插件, 发现Bug还没有人替你解决. 记住插件是我们没有办法的最后选择.

使用插件有太多的坏处:

1.不利于维护

2.增加页面大小

3.不利于成员间交流共享,具有学习成本.

4.不够健壮, 不能保证插件版本一直更新并修复所有问题.

下面就引入今天的主角:jQuery UI

jQuery UI 是 jQuery 的一部分, 是在jQuery之上的一套专门用于UI交互的类库. 使用jQuery UI可以实现底层交互, 各种高级特效, 动画, 并且可定制主题.

我们可以用它轻松的构建高度交互的Web应用程序.

官方首页:
https://jqueryui.org/

下载:
https://jqueryui.com/download

示例和文档:
https://jqueryui.com/demos/

皮肤:
https://jqueryui.com/themeroller/

jQuery UI 的在线网站十分强大. 首先就是在下载时可以组装自己想要的功能定制下载:

https://www.dotnetapi.com/JSLib/

此路径开通了目录浏览, 可以直接查找需要的文件. 目录组织结构按照本系列: (八) 插播:jQuery实施方案 中介绍的方案组织.

另外也可以从Google上引用文件, Google的CDN速度更快也更有保证, 参见: Google’s CDN

本文的实例的所有引用都使用 WebConfig.ResourceServer 这个属性:

public class WebConfig  {    public static string ResourceServer = @"https://www.dotnetapi.com/";
}

弹出框是最常用最实用的功能. 先来看一下艺龙网上的一些应用场景.

1. 艺龙网应用场景举例

(1) 静态提示类弹出层. 弹出层的内容是固定的.

Draggable), 可以改变大小(Resizable) .

示例完整代码如下:

<%@ Page Language="C#" %>    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "https://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">  <html xmlns="https://www.w3.org/1999/xhtml">  <head id="Head1" runat="server">    <title>jQuery UI - 弹出层应用实例 Dialog</title>      <!--black-tie,blitzer,blitzer,dot-luv,excite-bike,hot-sneaks,humanity,mint-choc,redmond,smoothness,south-street,start,swanky-purse,trontastic,ui-darkness,ui-lightness,vader-->    <link rel="stylesheet" type="text/css" href="<%=WebConfig.ResourceServer +"/JsLib/jquery/themes/redmond/style.css"%>" />     <script type="text/javascript" src="<% =WebConfig.ResourceServer %>/JsLib/jquery/jquery-min-lastest.js"></script>      <script src="<% =WebConfig.ResourceServer %>/JsLib/jquery/ui/jquery-ui-all-min-lastest.js"      type="text/javascript"></script>    <% if (false)      {%><script src="~/js/jquery-vsdoc-lastest.js" type="text/javascript"></script>    <% }%>    <script type="text/javascript">      /*========== 必须放在头部加载的语句块. 尽量避免使用 ==========*/    </script>    <style type="text/css">      </style>  </head>  <body>    <!-- Demo 静态提示类弹出层 -->    <div class="ui-widget ui-widget-content ui-corner-all" style="width: 700px; padding: 5px;">      <h3>Demo. 共享同一个静态弹出层, 弹出层内容固定: </h3>      <div>        <span id="spanShowTip1">显示提示</span>   <span id="spanShowTip2">显示提示</span>          <span id="spanShowTip3">显示提示</span>   <span id="spanShowTip4">显示提示</span>        </div>    </div>    <br />    <br />    <!-- Demo 动态提示类弹出层 -->    <div class="ui-widget ui-widget-content ui-corner-all" style="width: 700px; padding: 5px;">      <h3>Demo. 每个弹出层内容不同, 弹出层内容存储在事件源的元素属性中: </h3>      <div>        <span id="spanShowDataTip1" data="颜色是红色">红色</span>          <span id="spanShowDataTip2" data="颜色是绿色">绿色</span>        </div>    </div>    <br />    <br />    <!-- Demo 遮罩类弹出层 -->    <div class="ui-widget ui-widget-content ui-corner-all" style="width: 700px; padding: 5px;">      <h3>Demo. 弹出IFrame </h3>      <div>        <input type="button" id="btnShowIframe" name="btnShowIframe" value="显示弹出层"/>      </div>    </div>        <!-- 提示类弹出层 -->    <div id="divTip" title="自定义标题">      <p>弹出层</p>    </div>    <!-- 遮罩类弹出层 -->    <div id="divIframe" title="iFrame弹出层" style="text-align:center;">      <iframe src="https://www.elong.com" width="450px" height="230px"></iframe>    </div>    <script type="text/javascript">      /*==========用户自定义方法==========*/          /*==========事件绑定==========*/      $(function()      {        //静态提示类弹出层        $("span[id^=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");        });        //动态提出类弹出层        $("span[id^=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", "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).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,          draggable: true,                  resizable: false,          modal: true        });            });    </script>  </body>  </html>

效果如图:

静态提示类弹出层

https://jqueryui.com/demos/show/

当一个动画效果执行时, 如果用户在此对这个元素进行操作, 就会出现各种问题, 比如定位不准确等. 所以如果应用了动画, 我们在对其操作时需要使用stop()函数来停止动画, 通常是停止虽有元素的动画:

$("*").stop();

但是即使停止了动画再进行操作, 如果操作的太快也容易产生问题. 所以至于是否使用动画需要经过权衡决定.

(4) 动态提示类弹出层的数据传递

动态提示类弹出层的数据是不同的, 本文实例使用的是将数据存储在元素属性data上:

<span id="spanShowDataTip1" data="颜色是红色">红色</span>

这是一种简单直观的方式. 比较容易编程实现(尤其是在使用MVC编程模型的时候.)

还有一种常用方式是使用javascript变量存储数据.这两种方式在第5章时有过讲解:

https://www.cnblogs.com/zhangziqiu/archive/2009/05/06/jQuery-Learn-5.html

(5)更换主题

大家注意实例中的弹出层没有为其编辑任何样式, 但是显示出来后已经被美化过了. 这是因为我引用了jQuery UI的主题:

  <!--black-tie,blitzer,blitzer,dot-luv,excite-bike,hot-sneaks,humanity,mint-choc,redmond,smoothness,south-street,start,swanky-purse,trontastic,ui-darkness,ui-lightness,vader-->    <link rel="stylesheet" type="text/css" href="<%=WebConfig.ResourceServer +"/JsLib/jquery/themes/redmond/style.css"%>" /> 

注释中有很多的主题, 只需要将引用路径中的”redmond”改为其中任何一个, 弹出层的样式会立刻发生变化.

VS中有一个Bug, 就是针对link标签, href中的语句块编译有问题, 某些情况下<%%>不被编辑解析. 所以我使用上面代码中的方式构造href属性值.

可以在下面的地址查看各个主题的效果:

https://jqueryui.com/themeroller/#themeGallery

不刷新页面, 在页面中的不同标签间切换:

https://jqueryui.com/demos/tabs

使用jQuery UI的accordion组件可以实现手风琴菜单. 效果见下图.

accordion文档地址: https://jqueryui.com/demos/accordion/

1.实例效果

https://xiazai.phpstudy.net/201101/yuanma/Code-jQueryStudy-10.rar

—-想了解更多的linux相关异常处理怎么解决关注<计算机技术网(www.ctvol.com)!!>



本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/jquerytutorial/54563.html

(0)
上一篇 2020年4月12日
下一篇 2020年4月12日

精彩推荐