jQuery特殊属性操作

val方法

val方法用于设置和获取表单元素的值,例如input、textarea的值
//设置值
$("#name").val(“张三”);
//获取值
$("#name").val();

html方法与text方法

html方法相当于innerHTML text方法相当于innerText
//设置内容
$(“div”).html(“<span>这是一段内容</span>”);
//获取内容
$(“div”).html()
​
//设置内容
$(“div”).text(“<span>这是一段内容</span>”);
//获取内容
$(“div”).text()

区别:html方法会识别html标签,text方法会将内容直接当成字符串,并不会识别html标签。

empty() 和 html() 方法都可以清空内容,但推荐使用empty方法清空元素里的内容
​
$(“div”).empty();//清空div的所有内容(推荐使用,会清除子元素上绑定的事件)
$(“div”).html("");//使用html方法来清空元素,不推荐使用,会造成内存泄漏,绑定的事件不会被清除。

width方法与height方法

设置或者获取高度
//带参数表示设置高度
$(“img”).height(200);
//不带参数获取高度
$(“img”).height();

获取网页的可视区宽高

//获取可视区宽度
$(window).width();
//获取可视区高度
$(window).height();

scrollTop与scrollLeft

设置或者获取垂直滚动条的位置
//获取页面被卷曲的高度
$(window).scrollTop();
//获取页面被卷曲的宽度
$(window).scrollLeft();

jQuery事件机制

JavaScript中已经学习过了事件,但是jQuery对JavaScript事件进行了封装,增加并扩展了事件处理机制。jQuery不仅提供了更加优雅的事件处理语法,而且极大的增强了事件的处理能力。

jQuery事件发展历程(了解)

简单事件绑定>>bind事件绑定>>delegate事件绑定>>on事件绑定(推荐)

简单事件注册
click(handler)          单击事件
mouseenter(handler)     鼠标进入事件
mouseleave(handler)     鼠标离开事件

缺点:不能同时注册多个事件

bind方式注册事件
//第一个参数:事件类型
//第二个参数:事件处理程序
$("p").bind("click mouseenter", function(){
    //事件响应方法
});

缺点:不支持动态事件绑定

delegate注册委托事件
// 第一个参数:selector,要绑定事件的元素
// 第二个参数:事件类型
// 第三个参数:事件处理函数
$(".parentBox").delegate("p", "click", function(){
    //为 .parentBox下面的所有的p标签绑定事件
});

缺点:只能注册委托事件,因此注册时间需要记得方法太多了

on注册事件

on注册事件(重点)

jQuery1.7之后,jQuery用on统一了所有事件的处理方法。

最现代的方式,强烈建议使用。

on注册简单事件

// 表示给$(selector)绑定事件,并且由自己触发,不支持动态绑定。
$(selector).on( "click", function() {});

on注册委托事件

// 表示给$(selector)绑定代理事件,当必须是它的内部元素span才能触发这个事件,支持动态绑定
$(selector).on( "click",“span”, function() {});

on注册事件的语法:

// 第一个参数:events,绑定事件的名称可以是由空格分隔的多个事件(标准事件或者自定义事件)
// 第二个参数:selector, 执行事件的后代元素(可选),如果没有后代元素,那么事件将有自己执行。
// 第三个参数:data,传递给处理函数的数据,事件触发的时候通过event.data来使用(不常使用)
// 第四个参数:handler,事件处理函数
$(selector).on(events[,selector][,data],handler);

事件解绑

unbind方式(不用)
$(selector).unbind(); //解绑所有的事件
$(selector).unbind("click"); //解绑指定的事件
undelegate方式(不用)
$( selector ).undelegate(); //解绑所有的delegate事件
$( selector).undelegate( “click” ); //解绑所有的click事件
off方式(推荐)
// 解绑匹配元素的所有事件
$(selector).off();
// 解绑匹配元素的所有click事件
$(selector).off("click");

触发事件

$(selector).click(); //触发 click事件
$(selector).trigger("click");

jQuery事件对象

jQuery事件对象其实就是js事件对象的一个封装,处理了兼容性。

//screenX和screenY   对应屏幕最左上角的值
//clientX和clientY   距离页面左上角的位置(忽视滚动条)
//pageX和pageY   距离页面最顶部的左上角的位置(会计算滚动条的距离)
​
//event.keyCode 按下的键盘代码
//event.data    存储绑定事件时传递的附加数据
​
//event.stopPropagation()   阻止事件冒泡行为
//event.preventDefault()    阻止浏览器默认行为
//return false 既能阻止事件冒泡,又能阻止浏览器默认行为。

隐式迭代

基本概念

隐式迭代:jQuery在设置属性时会自动的遍历,因此我们不需要再遍历
  1. jQuery在执行设置性操作时,会给所有的元素都设置上相同的值。
  2. jQuery在执行获取性操作时,只会返回第一个元素对应的值。
  3. 如果想要给每一个元素都设置不同的值,需要手动进行遍历jQuery对象。

each方法

遍历jQuery对象集合,为每个匹配的元素执行一个函数

语法:

// 参数一表示当前元素在所有匹配元素中的索引号(下标)
// 参数二表示当前元素, 在function中this也表示当前元素。当前正在遍历的元素。
$(selector).each(function(index,element){});

链式编程

链式编程的原理:设置性操作会返回一个jQuery对象,因此可以继续调用jQuery的方法。
  1. 设置操作的时候,可以使用链式编程。
  2. 对于设置性操作,会把当前的jq对象进行返回,所以可以在后面继续链式编程。
  3. 获取操作的时候,无法使用链式编程。
  4. 对于获取性操作,返回的是具体的值,(不是jq对象),无法使用链式编程。
  5. 链式编程不是无条件的
end(); // 上一次返回的jq对象
prevAll();//获取前面所有的兄弟元素
nextAll();//获取后面所有的兄弟元素
siblings();//获取所有的兄弟元素
prev();//获取前一个兄弟
next();//获取后一个兄弟。

jQuery插件

插件:jquery不可能包含所有的功能,我们可以通过插件扩展jquery的功能。

jQuery有着丰富的插件,使用这些插件能给jQuery提供一些额外的功能。

使用插件

1. 引入jQuery文件
2. 引入插件(如果有用到css的话,需要引入css)
3. 使用插件

常用插件的使用

jQuery框架封装

jq的基本架构

(function(window){
    var jQuery = function(){
        
    }
    
    // 把jQuery函数暴露到全局中
    window.jQuery = window.$ = jQuery;
})(window);

jq的选择器

(function(window){
    var jQuery = function(selector){
        // 根据选择器来获取元素
        var ele = document.querySelectorAll(selector);
        
        // 把获取到的元素遍历添加到jq实例对象上
        for(var i = 0; i < ele.length; i++){
            this[i] = ele[i];
        }
        // 手动维护length属性为获取元素的个数
        this.length = ele.length;
    }
    
    window.jQuery = window.$ = jQuery;
})(window);

原型添加方法

(function(window){
    var jQuery = function(selector){
        // ...
    }
    
    // 原型替换,给jq原型中添加成员
    jQuery.prototype = {
        constructor: jQuery,
        css: function(){
            // css 操作样式功能...
        },
        html: function(){
            // html 操作文本内容功能...
        },
        //...
    };
    
    window.jQuery = window.$ = jQuery;
})(window);

省去new的操作

使用工厂函数来省去new可以得到实例对象,方便得到实例对象不用自己手动new

改变构造函数init的原型

得到的实例对象访问不到jq原型中的成员,改变init构造函数的原型为jQuery的原型,使其init的实例对象可以访问的到jq原型中的成员。

jQuery.fn.init.prototype = jQuery.fn;
最后修改:2021 年 06 月 23 日 01 : 44 PM
本文作者:博主:    
文章标题:JQuery系列(三)
本文地址:https://www.iftiger.com/archives/150.html     
版权说明:若无注明,本文皆为“泰戈尔のBlog”原创,转载请保留文章出处。
如果觉得我的文章对你有用,可以对我进行您主观即不限定金额大小的打赏。