zoukankan      html  css  js  c++  java
  • 前端基础之jquery

    前端基础之jquery

    一 、jQuery是什么? 

    • jQuery由美国人John Resig创建,至今已吸引了来自世界各地的众多 javascript高手加入其team。

    •  jQuery是继prototype之后又一个优秀的Javascript框架。其宗旨是——WRITE LESS,DO MORE!

    • 它是轻量级的js库(压缩后只有21k) ,这是其它的js库所不及的,它兼容CSS3,还兼容各种浏览器

    • jQuery是一个快速的,简洁的javaScript库,使用户能更方便地处理HTMLdocuments、events、实现动画效果,并且方便地为网站提供AJAX交互。

    • jQuery还有一个比较大的优势是,它的文档说明很全,而且各种应用也说得很详细,同时还有许多成熟的插件可供选择。

    二 什么是jQuery对象?

       jQuery 对象就是通过jQuery包装DOM对象后产生的对象。jQuery 对象是 jQuery 独有的如果一个对象是 jQuery 对象那么它就可以使用 jQuery 里的方法: $(“#test”).html();

    jquery的基础语法:

      $(selector).action() 

    $("#test").html() 
       
             意思是指:获取ID为test的元素内的html代码。其中html()是jQuery里的方法 
    
             这段代码等同于用DOM实现代码: document.getElementById(" test ").innerHTML; 
    
             虽然jQuery对象是包装DOM对象后产生的,但是jQuery无法使用DOM对象的任何方法,同理DOM对象也不能使用jQuery里的方法.乱使用会报错
    
             约定:如果获取的是 jQuery 对象, 那么要在变量前面加上$. 
    
    var $variable = jQuery 对象
    var variable = DOM 对象
    
    $variable[0]:jquery对象转为dom对象      $("#msg").html(); $("#msg")[0].innerHTML    //打印标签下的文本及子标签
    $variable[0]:jquery对象转为dom对象      $("#msg").html(); $("#msg")[0].outerHTML   //打印标签

    三 寻找元素(选择器和筛选器) 

    3.1   选择器

    //3.1.1 基本选择器      
    $("*")  $("#id")   $(".class")  $("element")  $(".class,p,div")
    
    //3.1.2 层级选择器   
    $(".outer div")  $(".outer>div")   $(".outer+div")  $(".outer~div")
    
    //3.1.3 基本筛选器  
    $("li:first")  $("li:eq(2)")  $("li:even") $("li:gt(1)")
    
    //3.1.4 属性选择器
    $('[id="div1"]')   $('["alex="sb"][id]')
    
    //3.1.5 表单选择器      
    $("[type='text']")----->$(":text")         注意只适用于input标签  : $("input:checked")
    
    //3.1.6 表单属性选择器
        :enabled
        :disabled
        :checked
        :selected

    3.2 筛选器

    3.2.1  过滤筛选器  

    $("li").eq(2)  $("li").first()  $("ul li").hasclass("test")
    

    3.2.2  查找筛选器

     查找子标签:         $("div").children(".test")      $("div").find(".test")  
                                   
     向下查找兄弟标签:    $(".test").next()               $(".test").nextAll()     
                        $(".test").nextUntil() 
                               
     向上查找兄弟标签:    $("div").prev()                  $("div").prevAll()       
                        $("div").prevUntil()   
     查找所有兄弟标签:    $("div").siblings()  
                  
     查找父标签:         $(".test").parent()              $(".test").parents()     
                        $(".test").parentUntil()
    

    四 操作元素(属性,css,文档处理)

    4.1 事件

    页面载入

    ready(fn)  // 当DOM载入就绪可以查询及操纵时绑定一个要执行的函数。
    $(document).ready(function(){}) -----------> $(function(){})  
    

    事件绑定

    //语法:  标签对象.事件(函数)    
    eg: $("p").click(function(){})
    

    事件委派:

    $("").on(eve,[selector],[data],fn)  // 在选择元素上绑定一个或多个事件的事件处理函数。
    

      示例:

    <ul>
        <li>1</li>
        <li>2</li>
        <li>3</li>
    </ul>
    <hr>
    <button id="add_li">Add_li</button>
    <button id="off">off</button>
    
    <script src="jquery.min.js"></script>
    <script>
        $("ul li").click(function(){
            alert(123)
        });
    
        $("#add_li").click(function(){
            var $ele=$("<li>");
            $ele.text(Math.round(Math.random()*10));
            $("ul").append($ele)
    
        });
    
    
    //    $("ul").on("click","li",function(){
    //        alert(456)
    //    })
    
         $("#off").click(function(){
             $("ul li").off()
         })
        
    </script>

    事件切换

    hover事件:

    一个模仿悬停事件(鼠标移动到一个对象上面及移出这个对象)的方法。这是一个自定义的方法,它为频繁使用的任务提供了一种“保持在其中”的状态。

    over:鼠标移到元素上要触发的函数

    out:鼠标移出元素要触发的函数

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            *{
                margin: 0;
                padding: 0;
            }
            .test{
    
                 200px;
                height: 200px;
                background-color: wheat;
    
            }
        </style>
    </head>
    <body>
    
    
    <div class="test"></div>
    </body>
    <script src="jquery.min.js"></script>
    <script>
    //    function enter(){
    //        console.log("enter")
    //    }
    //    function out(){
    //        console.log("out")
    //    }
    // $(".test").hover(enter,out)
    
    
    $(".test").mouseenter(function(){
            console.log("enter")
    });
    
    $(".test").mouseleave(function(){
            console.log("leave")
        });
    
    </script>
    </html>
    示例

     

    4.2 属性操作

    --------------------------CSS类
    $("").addClass(class|fn)
    $("").removeClass([class|fn])
    
    --------------------------属性
    $("").attr();
    $("").removeAttr();
    $("").prop();                
    $("").removeProp();
    
    --------------------------HTML代码/文本/值
    $("").html([val|fn])
    $("").text([val|fn])
    $("").val([val|fn|arr])
    
    ---------------------------
    $("#c1").css({"color":"red","fontSize":"35px"})    

    注:prop()用于input标签,取checked、selected,属性值,返回值为true或false

    attr方法使用示例:

    <input id="chk1" type="checkbox" />是否可见
    <input id="chk2" type="checkbox" checked="checked" />是否可见
    
    
    
    <script>
    
    //对于HTML元素本身就带有的固有属性,在处理时,使用prop方法。
    //对于HTML元素我们自己自定义的DOM属性,在处理时,使用attr方法。
    //像checkbox,radio和select这样的元素,选中属性对应“checked”和“selected”,这些也属于固有属性,因此
    //需要使用prop方法去操作才能获得正确的结果。
    
    
    //    $("#chk1").attr("checked")
    //    undefined
    //    $("#chk1").prop("checked")
    //    false
    
    //  ---------手动选中的时候attr()获得到没有意义的undefined-----------
    //    $("#chk1").attr("checked")
    //    undefined
    //    $("#chk1").prop("checked")
    //    true
    
        console.log($("#chk1").prop("checked"));                  //false
        console.log($("#chk2").prop("checked"));                 //true
        console.log($("#chk1").attr("checked"));                 //undefined
        console.log($("#chk2").attr("checked"));                //checked
    </script>
    

      

    4.3 each循环

    each循环使用场景:

      $("p").css("color","red")

      是将css操作加到所有的标签上,内部维持一个循环;但如果对于选中标签进行不同处理,这时就需要对所有标签数组进行循环遍历啦

    jquery支持两种循环方式:

    方式一

    格式:$.each(obj,fn)

    li=[10,20,30,40];
    //dic={name:"yuan",sex:"male"};    >>name yuan           sex male
    $.each(li,function(i,x){
        console.log(i,x)
    });
    
    >>:0 11
          1 22
          2 33
          3 44

    方式二

    格式:$("").each(fn)

    $("tr").each(function(){
        console.log($(this).html())
    }) 

    each扩展(*)

    /*
            function f(){
    
                 for(var i=0;i<4;i++){
      
                    if (i==2){
                        return
                     }
                    console.log(i)
                 }
             }
        f();      // 结果:0  1  
    //-----------------------------------------------------------------------
    
    
        li=[11,22,33,44];
        $.each(li,function(i,v){
    
            if (v==33){
                    return ;   //  ===试一试 return false会怎样?
                }
                console.log(v)
        });
            // return:11  22   44
           //  return false:11 22
    
    //------------------------------------------
    
    
        // 大家再考虑: function里的return只是结束了当前的函数,并不会影响后面函数的执行
    
        //本来这样没问题,但因为我们的需求里有很多这样的情况:我们不管循环到第几个函数时,一旦return了,
        //希望后面的函数也不再执行了!基于此,jquery在$.each里又加了一步:
             for(var i in obj){
    
                 ret=func(i,obj[i]) ;
                 if(ret==false){
                     return ;
                 }
    
             }
        // 这样就很灵活了:
        // <1>如果你想return后下面循环函数继续执行,那么就直接写return或return true
        // <2>如果你不想return后下面循环函数继续执行,那么就直接写return false
    
    
    // ---------------------------------------------------------------------    
    each循环的坑

    总结:

    <1>如果你想return后下面循环函数继续执行,那么就直接写return或return true
    <2>如果你不想return后下面循环函数继续执行,那么就直接写return false

    4.4 文档节点处理

    //创建一个标签对象
        $("<p>")
    
    
    //内部插入
    
        $("").append(content|fn)      ----->$("p").append("<b>Hello</b>");
        $("").appendTo(content)       ----->$("p").appendTo("div");
        $("").prepend(content|fn)     ----->$("p").prepend("<b>Hello</b>");
        $("").prependTo(content)      ----->$("p").prependTo("#foo");
    
    //外部插入
    
        $("").after(content|fn)       ----->$("p").after("<b>Hello</b>");
        $("").before(content|fn)      ----->$("p").before("<b>Hello</b>");
        $("").insertAfter(content)    ----->$("p").insertAfter("#foo");
        $("").insertBefore(content)   ----->$("p").insertBefore("#foo");
    
    //替换
        $("").replaceWith(content|fn) ----->$("p").replaceWith("<b>Paragraph. </b>");
    
    //删除
    
        $("").empty()     //删除节点,删除后文档不存在
        $("").remove([expr])   //清空节点,执行后,节点还存在
    
    //复制
    
        $("").clone([Even[,deepEven]])
    

    4.5 动画效果

    显示隐藏

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="jquery-2.1.4.min.js"></script>
        <script>
    
    $(document).ready(function() {
        $("#hide").click(function () {
            $("p").hide(1000);
        });
        $("#show").click(function () {
            $("p").show(1000);
        });
    
    //用于切换被选元素的 hide() 与 show() 方法。
        $("#toggle").click(function () {
            $("p").toggle();
        });
    })
    
        </script>
        <link type="text/css" rel="stylesheet" href="style.css">
    </head>
    <body>
    
    
        <p>hello</p>
        <button id="hide">隐藏</button>
        <button id="show">显示</button>
        <button id="toggle">切换</button>
    
    </body>
    </html>
    hide与show

    滑动

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="jquery-2.1.4.min.js"></script>
        <script>
        $(document).ready(function(){
         $("#slideDown").click(function(){
             $("#content").slideDown(1000);
         });
          $("#slideUp").click(function(){
             $("#content").slideUp(1000);
         });
          $("#slideToggle").click(function(){
             $("#content").slideToggle(1000);
         })
      });
        </script>
        <style>
    
            #content{
                text-align: center;
                background-color: lightblue;
                border:solid 1px red;
                display: none;
                padding: 50px;
            }
        </style>
    </head>
    <body>
    
        <div id="slideDown">出现</div>
        <div id="slideUp">隐藏</div>
        <div id="slideToggle">toggle</div>
    
        <div id="content">helloworld</div>
    
    </body>
    </html>
    slideDown与slideUp

    淡入淡出

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="jquery-2.1.4.min.js"></script>
        <script>
        $(document).ready(function(){
       $("#in").click(function(){
           $("#id1").fadeIn(1000);
    
    
       });
        $("#out").click(function(){
           $("#id1").fadeOut(1000);
    
       });
        $("#toggle").click(function(){
           $("#id1").fadeToggle(1000);
    
    
       });
        $("#fadeto").click(function(){
           $("#id1").fadeTo(1000,0.4);
    
       });
    });
    
    
    
        </script>
    
    </head>
    <body>
          <button id="in">fadein</button>
          <button id="out">fadeout</button>
          <button id="toggle">fadetoggle</button>
          <button id="fadeto">fadeto</button>
    
          <div id="id1" style="display:none;  80px;height: 80px;background-color: blueviolet"></div>
    
    </body>
    </html>
    fadein与fadeout

    回调函数

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="jquery-2.1.4.min.js"></script>
    
    </head>
    <body>
      <button>hide</button>
      <p>helloworld helloworld helloworld</p>
    
    
    
     <script>
       $("button").click(function(){
           $("p").hide(1000,function(){
               alert($(this).html())
           })
    
       })
        </script>
    </body>
    </html>
    回调函数

    4.6 css操作

    css位置操作

    $("").offset([coordinates])      //位置距离,参照物为当前屏幕
            $("").position()     //位置距离,参照物为已定位的父级标签,若没有已定位的父级责已body为参照
            $("").scrollTop([val])     //页面滚动
            $("").scrollLeft([val])

    示例一:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>方框移动</title>
        <script src="../Day45_前端jquery/jquery-3.2.1.js"></script>
        <style>
            *{
                margin: 0;
                padding: 0;
            }
            .box{
                 300px;
                height: 300px;
                background-color: blue;
            }
        </style>
    </head>
    <body>
    <div class="box"></div>
    
    
    <script>
        var mouse_x=0;
        var mouse_y=0;
        $(".box").mouseover(function () {
            $(this).css("cursor","move")
        });
    
        $(".box").mousedown(function (e) {
    
            mouse_x=e.clientX;
            mouse_y=e.clientY;
            var $box_top=$(".box").offset().top;
            var $box_left=$(".box").offset().left;
            $(document).mousemove(function (e) {
                var new_mou_x=e.clientX;
                var new_mou_y=e.clientY;
                console.log(new_mou_x,new_mou_y);
                $(".box").offset({left:$box_left+new_mou_x-mouse_x,top:$box_top+new_mou_y-mouse_y})
            });
            $(document).mouseup(function () {
                $(document).off();
            })
        })
    </script>
    
    
    </body>
    </html>
    方框移动

    示例二:

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            * {
                margin: 0;
            }
    
            .box1 {
                 200px;
                height: 200px;
                background-color: rebeccapurple;
            }
    
            .box2 {
                 200px;
                height: 200px;
                background-color: darkcyan;
            }
    
            .parent_box {
                position: relative;
            }
        </style>
    </head>
    <body>
    
    
    <div class="box1"></div>
    <div class="parent_box">
        <div class="box2"></div>
    </div>
    <p></p>
    
    
    <script src="../Day45_前端jquery/jquery-3.2.1.js"></script>
    <script>
        var $position = $(".box2").position();
        var $left = $position.left;
        var $top = $position.top;
    
        $("p").text("TOP:" + $top+"LEFT" + $left)
    </script>
    </body>
    </html>
    position取位置数据示例

    示例三:返回顶部top功能

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="../Day45_前端jquery/jquery-3.2.1.js"></script>
        <style>
            *{
                margin: 0;
                padding: 0;
            }
            .box{
                 80%;
                height: 3000px;
                background-color: lightgray;
                margin-left: 10%;
            }
            .button{
                height: 35px;
                 60px;
                text-align: center;
                line-height: 35px;
                background-color: #4767b2;
                color: white;
                border-radius: 5px;
                position: fixed;
                right: 10%;
                bottom: 20px;
                display: none;
            }
        </style>
    </head>
    <body>
    
    <div class="box"></div>
    <div class="button">TOP</div>
    
    <script>
        $(window).scroll(function () {
            if($(window).scrollTop()>1000){
                $(".button").show(500)
            }
            else{
                $(".button").hide(500)
            }
        });
        $(".button").click(function () {
            $(window).scrollTop(0)
        })
    </script>
    
    
    
    </body>
    </html>
    top按钮

    尺寸操作

    $("").height()                   //内容部分的高度
    $("").width()                    //内容部分的宽度    
    
    $("").innerHeight()          //内容部分的高度+padding
    $("").innerWidth()
    
    $("").outerHeight()        //内容部分的高度+padding+border
    $("").outerWidth()        
    
    $("").outerHeight(true)   //内容部分的高度+padding+border+margin
    $("").outerWidth(true)  

    示例

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <style>
            * {
                margin: 0;
            }
    
            .box1 {
                 200px;
                height: 200px;
                background-color: wheat;
                padding: 50px;
                border: 50px solid rebeccapurple;
                margin: 50px;
            }
    
        </style>
    </head>
    <body>
    
    
    <div class="box1">
        DIVDIDVIDIV
    </div>
    
    
    <p></p>
    
    <script src="../Day45_前端jquery/jquery-3.2.1.js"></script>
    <script>
        var $height = $(".box1").height();
        var $innerHeight = $(".box1").innerHeight();
        var $outerHeight = $(".box1").outerHeight();
        var $margin = $(".box1").outerHeight(true);
    
        $("p").text($height + "---" + $innerHeight + "-----" + $outerHeight + "-------" + $margin)
    </script>
    </body>
    </html>
    尺寸操作
  • 相关阅读:
    NHibernate之映射文件配置说明
    JS jQuery json日期格式问题的办法
    Spring.net 配置说明
    NHibernate常见问题及解决方法
    Could not load type 'System.Web.Mvc.ViewPage<dynamic>' in asp.net mvc2 after publishing the website
    启用SQLite的Data Provider 运行WECOMPANYSITE时遇到ERROR CREATING CONTEXT 'SPRING.ROOT': ERROR THROWN BY A DEPENDENCY OF OBJECT 'SYSTEM.DATA.SQLITE'
    Nuget 命令 NuGet 管理项目库
    vs2013(vs2015) 打开vs2010 找不到此项目类型所基于的应用程序 MVC2 升级 MVC5 不能加载Web项目
    JsonResult作为Action返回值时的错误
    MVC 数据验证
  • 原文地址:https://www.cnblogs.com/hedeyong/p/7358321.html
Copyright © 2011-2022 走看看