zoukankan      html  css  js  c++  java
  • :jQuery实例【DEMO】

    前言: 今天2月最后一天,写一篇jQuery的几个实例,算是之前前端知识的应用。写完这篇博客会做一个登陆界面+后台管理(i try...)

    一、菜单实例

    最开始的界面:

     点击菜单三后的界面:

     View Code

    二、表单实例

    效果图:

    优化后:

    实现功能:

    • 功能1:点击菜单A, 则下面的内容为菜单A对应的内容。
    • 功能2:点击菜单A,则菜单A会出现背景色,而未被点击的菜单没有。

    难点说明:

    一点击菜单一,菜单一的背景就"变色",背景颜色其实就是一种样式(以样式A为称)嘛,一点击菜单的div就会它加上样式A,同时给菜单二,菜单三(即菜单一的同级元素siblings)去除样式A。这个是不难实现的,如果有看我之前写的博客的话。

    问题来了,如何实现一点击菜单1,就显示菜单1的内容??其实菜单1对应的内容就是一块div嘛。只要找到这块div元素,去除隐藏的样式,同时给菜单2和3加上隐藏的样式。就OK啦~ 现在的问题是如何一点菜单一就找到菜单一对应内容的div元素?? 

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <div class="tab-box">
        <div class="box-menu">
            <!--所有菜单-->
            <a zcl="c1" onclick="ChangeTab(this);" class="current_menu">菜单一</a>
            <a zcl="c2" onclick="ChangeTab(this);">菜单二</a>
            <a zcl="c3" onclick="ChangeTab(this);">菜单三</a>
        </div>
        <div class="box-body">
            <!--所有内容-->
            <div id="c1">内容一</div>
            <div id="c2" class="hide">内容二</div>
            <div id="c3" class="hide">内容三</div>
        </div>
    </div>

    我给菜单(a标签)加上自定义属性zcl,该属性对应的值就是菜单对应内容的id。所以我只要一点击菜单,就去获取则菜单的zcl属性的值(即内容的id)。嗯,挺有意思的哈哈~~

     View Code

    三、复选框

    效果图:

    改进版:

     View Code

    四、返回顶部

    一点击"返回顶部",就调用下面的方法便可回到顶部:

    1
    2
    3
    function GoTop(){
        $(window).scrollTop(0);
    }

    优化版:

    看下面这个网站https://www.yonglibao.com/ ,会发现刚开始右下角是没有出现返回顶部的标记的,当滑轮向下滚动一定距离后才会出现返回顶部的标记!!

    如果想等到滑轮离顶部100时才出现返回顶部字样的话,可以给windows注册一个事件,当滑轮每移动一次就执行一次该事件,检测当前滑轮离顶部的距离,如果超过100,则去除div(返回顶部)的隐藏样式。

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    <script>
        //给windows注册一个事件,当滑轮每移动一次就执行一次该事件
        window.onscroll = function () {
            //console.log(123);  //一滚动就输出123
            //获取当前的scrollTop
            var current_top = $(window).scrollTop();
            if(current_top>100){
                $(".top").removeClass("hide");
            }else {
                $(".top").addClass("hide");
            }
        };
     
    </script>

    PS: 也可以给一个标签定义滑轮(overflow: auto)。

     View Code

    五、滚动菜单

    效果图:

    如果页面已经到底部了,但此时第3张的顶部还未到浏览器的顶部,所以是显示第2张,但按用户体验来说,左侧的菜单对第3张着色会更好.

    如何判定滑轮到了底部?? 可用:浏览器界面高度+滑轮滚动高度=HTML文档高度

    1
    $(window).height()+$(window).scrollTop()==$(document).height()
     View Code

    六、拖动面板

    效果图:

    鼠标放在黑色标题点击后便可拖动。

    JS代码讲解:

    复制代码
     1     <script>
     2         $(function () {
     3             //页面加载完成之后自动执行
     4             $("#title").mouseover(function () {  //给title绑定事件
     5                 $(this).css("cursor", "move");   //this代表title(标题标签)
     6             }).mousedown(function (e) {   //链式编程,在jQuery是很流行的;也是对title绑定事件
     7                 //绑定事件,e为封装了事件的对象,包含很多信息
     8                 var _event = e || window.event;  //有些浏览器不兼容没给出e,就用window.event
     9                 var old_x = _event.clientX; //原始鼠标横坐标
    10                 var old_y = _event.clientY;
    11                 //框左上角离浏览器界面左边界,顶部的距离
    12                 var parent_left = $(this).parent().offset().left;
    13                 var parent_top = $(this).parent().offset().top;
    14 
    15                 $(this).bind("mousemove", function (e) {  //this代表title;为谁绑定事件,$(this)便是谁
    16                     var _new_event = e || window.event;
    17                     var new_x = _new_event.clientX;  //新的鼠标坐标
    18                     var new_y = _new_event.clientY;
    19 
    20                     var x = parent_left + (new_x-old_x);  //移动的横坐标距离
    21                     var y = parent_top + (new_y-old_y);
    22 
    23                     $(this).parent().css("left", x+'px');  //this仍代表title
    24                     $(this).parent().css("top", y+'px');
    25                 })
    26             }).mouseup(function () {  //鼠标一放开(不点击),则取消绑定移动事件
    27                     $(this).unbind("mousemove");
    28                 })
    29         })
    30     </script>
    复制代码
     View Code

    七、跨域Ajax请求与电视节目实例

    Ajax概述

    对于WEB应用程序:用户浏览器发送请求,服务器接收并处理请求,然后返回结果,往往返回就是字符串(HTML),浏览器将字符串(HTML)渲染并显示浏览器上。页面不刷新便能提交数据。通过ajax请求,收到返回的数据。通过跨域ajax请求接收的数据是包装在服务端发往客户端的函数中的。

    1、传统的Web应用

    一个简单操作需要重新加载全局数据

    2、AJAX

    AJAX,Asynchronous JavaScript and XML (异步的JavaScript和XML),一种创建交互式网页应用的网页开发技术方案。

    • 异步的JavaScript:
      使用 【JavaScript语言】 以及 相关【浏览器提供类库】 的功能向服务端发送请求,当服务端处理完请求之后,【自动执行某个JavaScript的回调函数】。
      PS:以上请求和响应的整个过程是【偷偷】进行的,页面上无任何感知。
    • XML
      XML是一种标记语言,是Ajax在和后台交互时传输数据的格式之一

    利用AJAX可以做:
    1、注册时,输入用户名自动检测用户是否已经存在。
    2、登陆时,提示用户名密码错误
    3、删除数据行时,将行ID发送到后台,后台在数据库中删除,数据库删除成功后,在页面DOM中将数据行也删除。(博客园)

    目前我对ajax学习不怎么深入,具体可以参考http://www.cnblogs.com/wupeiqi/articles/5703697.html,下次有时间再整理写篇关于ajax的博客。

    效果图:

    通过江西电视台的接口http://www.jxntv.cn/data/jmd-jxtv2.html?callback=list&_=1454376870403获取数据

    代码分析:

    复制代码
     1 <!DOCTYPE html>
     2 <html lang="en">
     3 <head>
     4     <meta charset="UTF-8">
     5     <title></title>
     6 </head>
     7 <body>
     8 <input type="button" onclick="AjaxRequest()" value="跨域Ajax" />
     9 
    10 
    11 <div id="container"></div>
    12 
    13 <script src="jquery-3.1.1.min.js" type="text/javascript"></script>
    14     <script type="text/javascript">
    15         function AjaxRequest() {
    16             $.ajax({
    17                 url: 'http://www.jxntv.cn/data/jmd-jxtv2.html?callback=list&_=1454376870403',
    18                 type: 'GET',
    19                 dataType: 'jsonp',
    20                 jsonp: 'callback',
    21                 jsonpCallback: 'list',
    22 
    23                 success: function (arg) {
    24                     //当请求执行完成之后,自动调用,arg(参数):服务器返回的数据
    25                     //arg = {data: xxx}
    26                     //jsonpdic为字典,jsonpdic有两个元素,一个是week:xx;另一个是list列表,包含周几相关的信息
    27                     var jsonpdic = arg.data;
    28                     //k为列表(里面为星期X对应的内容),v为一个字典{week:xx}
    29                     $.each(jsonpdic, function (k, v) {
    30                         var week = v.week;  //获得星期几,并将其拼接成h1标签,并append到div标签
    31                         var temp = "<h1>" + week + "</h1>";
    32                         $('#container').append(temp);
    33                         //获得key为list所对应的value(包含相关信息);listArray为列表,里面元素为字典形式
    34                         var listArray = v.list;
    35                         $.each(listArray, function (kk,vv) {
    36                             var link = vv.link;
    37                             var name = vv.name;
    38                             //a标签是没有换行的,所以在后面加上<br/>
    39                             var tempNex = "<a href='" + link + "'>" + name + "</a><br/>"
    40                             $('#container').append(tempNex);
    41                         })
    42                     })
    43                 }
    44             });
    45         }
    46 
    47 </script>
    48 </body>
    49 </html>
    复制代码

    接收的数据是列表与字典的嵌套,结合着下图与上面代码看会好很多:

    今天在博客园看到一条段子:

  • 相关阅读:
    ExtJs之表格控件入门
    bootstrap错误警告信息提示
    android采用MVP漫画APP、适配刘海屏、小黄车主界面、录音波浪动画、综合APP等源码
    iOS仿QQ侧滑菜单、登录按钮动画、仿斗鱼直播APP、城市选择器、自动布局等源码
    iOS仿抖音节拍界面、Swift,MVVM架构完整项目、日历demo、滚动切换分类等源码
    接住! 安卓巴士开发者大会花絮第二弹来啦
    iOS漂亮的Toolbar动画、仿美团主页、简易笔记本、流失布局、标签分组等源码
    android仿今日头条App、多种漂亮加载效果、选择器汇总、记事本App、Kotlin开发等源码
    到场率高达96% 这才是高水准技术大会应该有的样子
    iOS动画效果集合、 通过摄像头获取心率、仿淘宝滑动样式、瀑布流、分类切换布局等源码
  • 原文地址:https://www.cnblogs.com/libin-1/p/6482737.html
Copyright © 2011-2022 走看看