jQuery学习备忘

jQuery对象转换成DOM对象

var #cr = $("#cr");  //jQuery对象
var cr = $cf[0];      //DOM对象
alert(cr.checked)    //检测这个checkbox是否被选中了

或者

var #cr = $("#cr");      //jQuery对象
var cr = $cf.get(0);     //DOM对象——通过jQuery本身的get(index)方法
alert(cr.checked)        //检测这个checkbox是否被选中了

DOM对象转换成jQuery对象

var cr = document.getElementById("cr");  //DOM对象
var $cr = $(cr);                          //jQuery对象

 

//是否被选中
$cr.is(":checked"));     //jQuery
cr.checked;              //javascript

 

var $t_a = $('.test :hidden');    //带空格的
//选取class为“test”的元素里面的隐藏元素。

var $t_a = $('.test:hidden');    //不带空格的
//选取隐藏的class为“test”的元素。

 


 

 

事件对象的属性:

  1、event.type  该方法的作用是可以获取到事件的类型;

  2、event.preventDefault()  该方法的作用是阻止默认的事件行为;

  3、event.stopPropagation()  该方法的作用是阻止事件的冒泡(jQuery对其重新封装,使IE也能支持);

  4、event.target  该方法的作用是获取到触发事件的元素;

  5、event.relatedTarget  W3C在mouseover和mouseout这两个触发的事件对象里添加了一个叫relatedTarget的属性,来表示与事件相关的DOM元素。mouseover中relatedTarget指向鼠标来自的元素,而mouseout中的relatedTarget指向的是鼠标去向的那个元素。jQuery中,reatedTarget与其作用相同,只用在mouseover和mouseout事件中,且relatedTarget是一个对象属性,不是一个函数(方法),不能调用。

  6、event.pageX和event.pageY  该方法的作用是获取到光标相对于页面的x坐标和y坐标;

  7、event.which  该方法的作用是在鼠标单击事件中获取到鼠标的左、中、右键,在键盘事件中获取键盘的按键;(1=左,2=中,3=右)

  8、event.metaKey  该方法的作用是为键盘事件中获取<ctrl>按键。

 


 

    在之前的jQuery版本中,都是使用attr()来访问对象的属性,比如取一个图片的alt属性,就可以这样做$('#img').attr('alt');但是在某些时候,比如访问input的disabled属性的时候,会有些问题。在有些浏览器里,只要写了disabled属性就可以,有些则要写:disabled="disabled"。所以,从1.6版开始,jQuery提供新的方法prop()来获取这些属性。使用prop()的时候,返回值是标准属性:true/false,比如$('#checkbos').prop('disabled'),不会返回“disabled”或者“”,只会返回true/false。当然赋值的时候也是如此。这样,便统一了所有操作,无论是从语法上还是语义上。

    那么,哪些属性应该用attr()访问,哪些应该用prop()访问呢?

    第一个原则:只添加属性名称该属性就会生效应该使用prop();

    第二个原则:只存在true/false的属性应该使用prop()。

   比如:如果是设置disabled和checked这些属性,应使用prop()方法,而不是使用attr()方法。


复制代码
$.ajaxPrefilter(function (options) {
    options.global = true;//Ajax不触发全局事件
});

//
$("#loading").ajaxStart(function () {
    $(this).show();
});
$("#loading").ajaxStop(function () {
    $(this).hide();
});
复制代码

 

 页面加载时,可多次触发的方法:

复制代码
function addLoadEvent(func) {
    var oldonload = window.onload;
    if (typeof window.onload != 'function') {
        window.onload = func;
    } else {
        window.onload = function () {
            oldonload();
            func();
        }
    }
}
复制代码

 在元素后添加

function insertAfter(newElement, targetElement) {
    var parentElement = targetElement.parentNode;
    if (parentElement.lastChild == targetElement) {
        parentElement.appendChild(newElement);
    } else {
        parentElement.insertBefore(newElement, targetElement.nextSibling);
    }
}

 

posted on   非零  阅读(252)  评论(0编辑  收藏  举报
编辑推荐:
· Linux glibc自带哈希表的用例及性能测试
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
阅读排行:
· 手把手教你在本地部署DeepSeek R1,搭建web-ui ,建议收藏!
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 数据库服务器 SQL Server 版本升级公告
· 程序员常用高效实用工具推荐,办公效率提升利器!
· C#/.NET/.NET Core技术前沿周刊 | 第 23 期(2025年1.20-1.26)
< 2025年1月 >
29 30 31 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31 1
2 3 4 5 6 7 8

点击右上角即可分享
微信分享提示