zoukankan      html  css  js  c++  java
  • Jquery记录

    jQuery中的事件
    1. 事件绑定
    1)on(events,[data],handler(eventObject),)
      融合了bind、live、delegate三种函数的特殊,是1.7版本之后新增的一个绑定事件函数,提供了一种统一绑定事件的方法(之前是前三种方法都在用,使用比较混乱)
    events -> 事件类型
      data -> 当一个事件被触发时,要传递给事件处理函数的event.data。
      handler(eventObject):事件被触发时,执行的函数。
      在选定的元素上绑定一个或多个事件处理函数。
      $("p").on("click", function(){
        alert( $(this).text() );
      });
    例如:
    jquery代码:
    //注意这里的代码和delegate函数的参数顺序是不一样的
      $("#dd").on({
        click:function(){
        console.log("click...");
      },
      mouseover:function(){
        console.log("mouseover...");
      },"button");
      $("button").after($("<button>新增按钮1</button>"));
      $("body").after($("<button>新增按钮2</button>"));
      $("#dd").after($("<button>新增按钮3</button>"));

      结果是和上面delegate的结果一样的。
      注意:on函数只有在指定了绑定事件的范围后,动态添加进来的元素才能也有事件的处理,否则on的效果和bind差不多。
    off( events )
      如果没有参数,删除所有绑定的事件,如果提供了事件类型,只删除该事件类型的绑定事件.(专门针对on绑定的事件)
    $("p").off();
    $("p").off("click");
      2)one( events [, data ], handler(eventObject) )
      给对象绑定一次数据处理,触发处理完之后就失效
      $( "#btn" ).one( "click", function( event ) {
        alert("hello");
      });

    2. 事件冒泡,事件会按照DOM的层次结构像水泡一样不断向上直至顶端
    举例说明:
    html代码:
    <div>
    <span>test</span>
    </div>

    jQuery代码:
    $("div").on("click",function(){
    alert("hello");
    });
    $("span").on("click",function(event){
    alert("world");
    });

    这个时候点击span的时候会触发span的onclick事件,同时也会触发div的onclick事件,因为span在div里面,这种现象就叫做事件冒泡


    可以调用事件对象的特定方法来组织事件冒泡: stopPropagation()
    $("element").bind("click",function(event){
     //event:事件对象,当点击“element”元素时,事件对象就被创建了,这个事件对象只有事件处理函数才能访问到,事件处理函数执行完毕后,事件对象就被销毁
      event.stopPropagation(); //停止事件冒泡
    })


    2.1 对象的默认行为
    默认行为:单击超链接会跳转,单击提交会提交表单
    例如:
    html代码:
    <a href="test.html">点击超链接</a>

    jquery代码:
    $("a").on("click",function(event){
      alert("大家好");
    });

    点击超链接后会触发onclick事件,然后执行绑定的函数,函数执行完接着就会进行超链接的跳转,因为这是点击超链接的默认行为。

    如果我们想处理完绑定事件,然后阻止这个对象的接下来的默认行为的话,那么需要调用事件对象的指定方法来实现:preventDefault()
    jquery代码:
    $("a").on("click",function(event){
      alert("大家好");
      event.preventDefault();
    });

    特别注意:如果想同时对事件对象停止冒泡和默认行为,可以在事件处理函数中返回false即可
    jquery代码:
    $("a").on("click",function(event){
      alert("大家好");
      return false;//同时阻止事件冒泡和默认行为
    });

    jQuery中的动画
    1,基础
    1)hide()
      隐藏匹配的元素。 style="display:none"
      hide( [duration ] [, complete ] )
      duration 三种预定速度之一的字符串("slow","normal", or "fast")或表示动画时长的毫秒数值(如:1000)
      complete 在动画完成时执行的函数。

    2)show()
    显示匹配的元素(和hide的参数作用一致)


    3)toggle( [duration ] [, complete ] )
    toggle()默认是切换元素的显示和隐藏效果
      $("#my_input").click(function(){
        $("#div2").toggle();
      });


    也可以自定义转换的俩个或者多个函数:
    //点击#my_input按钮后#div2就会在c1和c2俩个提前定义好的样式间转换
    $("#my_input").toggle(function(){
      $("#div2").attr("class","c1");
    },function(){
    $("#div2").attr("class","c2");
    });

    2,渐变
    1)fadeIn( [duration] ,[fn] )
      通过淡入的方式显示匹配隐藏元素。
      如果不写duration
      duration = ("slow","normal", or "fast")/5000毫秒
    2)fadeOut( duration ,[fn] )
      通过淡出的方式隐藏匹配显示元素。
      duration = ("slow","normal", or "fast")/5000毫秒
    3)fadeTo( duration, opacity ,[fn] )
      opacity:0和1之间的数字表示目标元素的不透明度。
    4)fadeToggle( [duration ] [, complete ] )
      切换渐变效果
      通过匹配的元素的不透明度动画,来显示或隐藏它们。
      当被可见元素调用时,元素不透明度一旦达到0,display样式属性设置为none ,所以元素不再影响页面的布局。
    3,滑动
    1)slideDown( [duration ] [, complete ] )
    将给匹配元素的高度的动画,这会导致页面的下面部分滑下去,弥补了显示的方式。
    2)slideUp( [duration ] [, complete ] )
    向上滑动
    3)slideToggle( [duration ] [, complete ] )
    切换滑动效果

  • 相关阅读:
    【资料整理】面向对象
    【资料整理】函数(方法)
    【资料整理】数组
    【资料整理】循环、判断、三元表达式
    【资料整理】类型转换、运算符
    【资料整理】c#基础
    线性表的链式表示和实现
    线性表
    PAT 乙级1062最简分数
    HDU 1027(全排列)
  • 原文地址:https://www.cnblogs.com/nyhhd/p/12525748.html
Copyright © 2011-2022 走看看