jQuery 知识点大纲

一、jQuery的元素操作

1.1 jQuery获取元素的高和宽

  • height : $(selector).height(); //带参数设置,不带参数获取,参数是number类型
  • width : $(selector).width(200); //带参数设置,不带参数获取
  • innerHeight //只能获取:内边距+内容的高度
  • innerWidth //同上.........宽度
  • outerHeight
  • outerWidth //获取:左右内边距+内容+左右边框

1.2 jQuery元素坐标操作

  • offset() 获取或设置元素相对于文档位置的方法

    • 返回一个object,包含left和top属性,值是相对于document的位置。
    • 如果传入一个参数,则是对元素重新设置相对于document的位置。
      • 传入参数必须包括:left和top属性。比如: {left:100,top:150}

      例如:$(selector).offset({left:100, top: 150});

  • position() 获取相对于其最近的定位的父元素的位置。
    • 只能获取,不能设置。
    • 相对与其最近的定位元素
    • 返回一个object,包含left和top属性

    例如: $(selector).position();

  • 元素的滚动
    • scrollLeft() 获取或者设置元素水平方向滚动的位置
    • scrollTop() 获取或者设置窗口垂直方向的滚动的位置
    • 例如: 
      $(selector).scrollLeft(100);
    • scroll() 事件触发或者绑定滚动事件
      • scroll(hander) 绑定滚动事件
      • scroll() 触发滚动事件 $(selector).scroll(function(){ //当选择的元素发生滚动的时候触发 });

二、jQuery事件绑定机制

2.1 简单事件绑定方法

  • .click(hander) .click() //绑定事件 或者触发 click事件
  • .blur() //失去焦点事件,同上
  • .hover(mousein, mouseleave) //鼠标移入,移出
  • mouseout: 当鼠标离开元素及它的子元素的时都会触发。
  • mouseleave: 当鼠标离开自己时才会触发,子元素不触发。
  • .dbclick() 双击
  • change 改变,比如:文本框发送改变,下来列表发生改变等...
  • focus 获得焦点
  • keyup, keydown, keypress : 键盘 键被按下。
  • mousedown, mouseover
  • 其他参考:http://www.w3school.com.cn/jquery/jquery_ref_events.asp

2.2 绑定事件的方式 bind方式(不推荐,1.7以后的jQuery版本被on取代)

  • 语法格式:.bind( eventType [, eventData ], handler )
  • 参数说明
    • 第一个参数:事件类型
    • 第二个参数:传递给事件响应方法的数据对象,可以省略。
    • 事件响应方法中获取数据方式: e.data
    • 第三个参数:事件响应方法
  • 第二个参数可以省略。
    例如:
    $("p").bind("click", function(e){
        //事件响应方法
    });

2.3 delegate方式(推荐,性能高,支持动态创建的元素)

  • 语法格式:$(selector).delegate( selector, eventType, handler )
  • 语法说明:
    • 第一个参数:selector, 子选择器
    • 第二个参数:事件类型
    • 第三个参数:事件响应方法
    例如:
    $(".parentBox").delegate("p", "click", function(){
        //为 .parentBox下面的所有的p标签绑定事件
    });

优势:效率较高

2.4 on方式(最现代的方式,兼容zepto,强烈建议使用的方式)

  • jQuery1.7版本后,jQuery用on统一了所有的事件处理的方法
  • 语法格式:$(selector).on( events [, selector ] [, data ], handler )
  • 参数介绍:
    • 第一个参数:events,事件名
    • 第二个参数:selector,类似delegate
    • 第三个参数: 传递给事件响应方法的参数
    • 第四个参数:handler,事件处理方法
    例如:
    //绑定一个方法
    $( "#dataTable tbody tr" ).on( "click", function() {
      console.log( $( this ).text() );
    });

    //给子元素绑定事件
    $( "#dataTable tbody" ).on( "click", "tr", function() {
      console.log( $( this ).text() );
    });

    //绑定多个事件的方式
    $( "div.test" ).on({
      click: function() {
        $( this ).toggleClass( "active" );
      }, mouseenter: function() {
        $( this ).addClass( "inside" );
      }, mouseleave: function() {
        $( this ).removeClass( "inside" );
      }
    });

2.5 one绑定一次事件的方式

  • .one( events [, data ], handler )
    例如:
    $( "p" ).one( "click", function() {
      alert( $( this ).text() );
    });

2.6 解绑事件

  • unbind解绑 bind方式绑定的事件( 在jQuery1.7以上被 on和off代替)

    • $(selector).unbind(); //解绑所有的事件
    • $(selector).unbind("click"); //解绑指定的事件
  • undelegate解绑delegate事件
    • $( "p" ).undelegate(); //解绑所有的delegate事件
    • $( "p" ).undelegate( "click" ); //解绑所有的click事件
    例如:
    var foo = function () {
      // Code to handle some kind of event
    };

    // ... Now foo will be called when paragraphs are clicked ...
    $( "body" ).delegate( "p", "click", foo );

    // ... foo will no longer be called.
    $( "body" ).undelegate( "p", "click", foo );
  • off解绑on方式绑定的事件

    • $( "p" ).off();
    • $( "p" ).off( "click", "**" ); // 解绑所有的click事件,两个*表示所有
    • $( "body" ).off( "click", "p", foo );
    案例1:
    var foo = function() {
      // Code to handle some kind of event
    };

    // ... Now foo will be called when paragraphs are clicked ...
    $( "body" ).on( "click", "p", foo );

    // ... Foo will no longer be called.
    $( "body" ).off( "click", "p", foo );

    案例2:(了解)解绑命名空间的方式:
    var validate = function() {
      // Code to validate form entries
    };

    // Delegate events under the ".validator" namespace
    $( "form" ).on( "click.validator", "button", validate );

    $( "form" ).on( "keypress.validator", "input[type=‘text‘]", validate );

    // Remove event handlers in the ".validator" namespace
    $( "form" ).off( ".validator" );

2.7 触发事件

  • 简单事件触发

    • $(selector).click(); //触发 click事件
  • trigger方法触发事件
    • $( "#foo" ).trigger( "click" );
  • triggerHandler触发 事件响应方法,不触发浏览器行为
    • $( "input" ).triggerHandler( "focus" );

2.8 event对象的简介

  • event.data //传递的额外事件响应方法的额外参数
  • event.currentTarget //在事件响应方法中等同于this,当前Dom对象
  • event.target //事件触发源,不一定===this
  • event.pageX //The mouse position relative to the left edge of the document
  • event.pageY
  • event.stopPropagation()//阻止事件冒泡
  • e.preventDefault(); //阻止默认行为
  • event.type //事件类型:click,dbclick...
  • event.which //鼠标的按键类型:左1 中2 右3

jQuery其他补充

  • 链式编程: end()补充

    • 补充五角星 评论案例
    • 第一步:鼠标移入,当前五角星和前面的五角星变实体。后面的变空心五角星
    • 第二步:鼠标点击的时候,为当前元素添加clicked类,其他的移除clicked类
    • 第三步:当鼠标移开整个评分控件的时候,把clicked的之前的五角星显示实心
  • 隐式迭代
  • map函数
    • $.map(arry,function(object,index){}) 返回一个新的数组
    • $("li").map(function(index, element){}) 注意参数的顺序是反的
        var newArr = $.map($("li"), function(i, e) {
            return $(e).text() + i;//每一项返回的结果组成新数组
        });

        var newArr = $("li").map(function(elem, index){
            console.log("elem:" + elem);
            console.log("index:" + index);
            retrun index;
        });
  • each函数

    • $.each(array, function(index, object){})
    • $("li").each(index, element )
    • 参数的顺序是一致的。
    例如:
    $( "li" ).each(function() {
      $( this ).addClass( "foo" );
    });

    $( "li" ).each(function( index ) {
      console.log( index + ": " + $( this ).text() );
    });

    $( "div" ).each(function( index, element ) {});

+noConflict 全局对象污染冲突

时间: 2024-08-27 08:34:29

jQuery 知识点大纲的相关文章

jquery知识点梳理

jQuery知识点梳理 一.              jquery选择器 基本选择器 ID选择器 类选择器 标记选择器 分组选择器 通配符选择器 层次选择器 $(“ancestor descendent”):祖先后代选择器    空格 $(“parent > child”):父子选择器   大于 $(“prev + next”):相邻后兄弟元素选择器   加号 $(“prev ~ siblings”):所有后兄弟元素选择器  波浪线 过滤选择器:基本过滤选择器 :first.:last.:od

iOS知识点大纲

Xcode使用 1. 创建UI工程 基本控件 2. UILabel标签 3. UIButton按钮 项目: 计算器项目 4. UIImageView(UIImage)   项目: 人人界面 5. UIView 视图+触摸   项目: 人人界面 6. UITextField输入框/电子词典 7. iOS常用控件 8. 手势操作 视图控制器和多视图程序 9. UIViewController 10.UINavigationController 项目: 人人界面模拟 11. UITabBarContr

jQuery知识点总结(第一天)

整理笔记前的题外话: 我认为互联网的高速发展其中最为主要的一点就是——开源. 开源精神,使得无数的IT爱好者贡献所学,将自己的智慧结晶无偿奉献给大家.后辈的学习者在混沌的互联网世界里,追寻着前辈们留下的足迹,亦步亦趋的前往更高的层楼.开源精神,大大减少了后辈们在学习技术的难度,使得技术的升级和迭代日新月异.我希望成为一名思维开阔的人,成为对互联网有贡献的开源人. 我是后端PHP程序员,很少写前端页面.在做项目的过程中,被jQuery的便捷性所吸引.因此购买了<锋利的JQuery>一书,最近一边

jQuery知识点总结(第二天)

今天继续从我的笔记上面搬运.我们不产生知识,只是知识的搬运工. 内容过滤选择器: ○ 内容选择过滤器                                       $("div:contains('text')");   内容为'text'的那个div ○ 不包含子元素也不包含文本元素(一穷二白的选择器)   $("div:empty"); ○ 含有选择器所匹配元素的元素(真他妈绕口)              $("div:has(p)&q

jQuery知识点总结

一.元素的增删改查 1.增加 a.append() 和 appendTo()  区别 append():后边的加到前边的里边(后置插入) appendTo():前边的加到后边的里边 b.prepend()  和 prependTo() 区别 后边的加到前边的里边(前置插入) c.after()   和 before() 区别 后边的插入到前边的之后 后边的插入到前边的之前 2.删除 a.remove .empty 和 detach 方法的区别 Remove:移除 Empty:把元素内容清空 De

jQuery 知识点总结

[文章根据 尚硅谷 教学材料 总结] 发博备查. 1.        . class选择器    # id选择器    : 选取 2. $(function(){})相当于 window.onload 方法.    window.onload = function(){...}    3. 加载DOM的两种方式: jQuery 和 window.onload    $(document).ready(function(){...})    $(function(){...} 4. 选取butto

几个简单的jquery知识点练习

三.jquery对象和dom对象 <script type="text/javascript"> //页面的基本元素加载后 $(function () { var btnObjDom = document.getElementById('btn'); //dom对象变成jquery对象 alert($(btnObjDom).val());//如果val()该方法括号中什么都不写,表示的是获取值 //如果在括号中写内容了,表示的是设置该属性的值 //jquery对象变成dom

jQuery知识点积累

1.  jQuery对象与JavaScript对象转换 jQuery-->JavaScript 两种方法: $(selector).get(index) ;   $(selector)[index]; JavaScript-->jQuery 只需要将获取的JavaScript对象用$包装即可, 如: var obj = document.links;  $(obj).css("color","red");

jquery知识点复习

一. 基本概念 jQuery简介 jQuery是一个基于javascript的框架.它提供了丰富的选择器和大量的函数,可以方便的实现网页中各种动态的效果.迄今为止,已经有大量的jquery插件和基于jQuery的UI框架(miniui.easyui.ligerui). jQuery的宗旨是:write less,do more! 文档加载完毕函数 常规形式:$(document).ready(function(){- -}); 简写形式:$(function(){- -}); jquery对象和