JavaScript系列教程

JavaScript学习笔记(三十三)-- jQuery(下)

2020-07-27  本文已影响0人  千锋HTML5学院

jQuery

发送 ajax 请求

// 直接使用 $.get 方法来发送一个请求
/*
 参数一: 请求地址
 参数二: 请求时携带的参数
 参数三: 请求成功的回调
 参数四: 返回的数据类型
*/
$.get('./ajax.php', { id: 10 }, function (res) { console.log(res) }, 'json')
// 直接使用 $.post 方法来发送一个请求
/*
 参数一: 请求地址
 参数二: 请求时携带的参数
 参数三: 请求成功的回调
 参数四: 返回的数据类型
*/
$.post('./ajax.php', { id: 10 }, function (res) { console.log(res) }, 'json')
// 使用 $.ajax 方法
// 只接受一个参数,是一个对象,这个对象对当前的请求进行所有的配置
$.ajax({
 url: './ajax',   // 必填,请求的地址
 type: 'GET',   // 选填,请求方式,默认是 GET(忽略大小写)
 data: {},   // 选填,发送请求是携带的参数
 dataType: 'json',   // 选填,期望返回值的数据类型,默认是 string
 async: true,   // 选填,是否异步,默认是 true
 success () {},   // 选填,成功的回调函数
 error () {},   // 选填,失败的回调函数
 cache: true,   // 选填,是否缓存,默认是 true
 context: div,   // 选填,回调函数中的 this 指向,默认是 ajax 对象
 status: {},   // 选填,根据对应的状态码进行函数执行
 timeout: 1000,   // 选填,超时事件
})
// 使用 $.ajax 方法也可以发送 jsonp 请求
// 只不过 dataType 要写成 jsonp
$.ajax({
 url: './jsonp.php',
 dataType: 'jsonp',
 data: { name: 'Jack', age: 18 },
 success (res) {
 console.log(res)
    },
 jsonp: 'cb',  // jsonp 请求的时候回调函数的 key
 jsonpCallback: 'fn' // jsonp 请求的时候回调函数的名称
})

全局 ajax 函数

ajaxStart

$(window).ajaxStart(function () {
 console.log('有一个请求开始了')
})

ajaxSend

$(window).ajaxSend(function () {
 console.log('有一个要发送出去了')
})

ajaxSuccess

$(window).ajaxSuccess(function () {
 console.log('有一个请求成功了')
})

ajaxError

$(window).ajaxError(function () {
 console.log('有一个请求失败了')
})

ajaxComplete

$(window).ajaxComplete(function () {
 console.log('有一个请求完成了')
})})

ajaxStop

$(window).ajaxStop(function () {
 console.log('有一个请求结束了')
})

jQuery 的多库共存

// 这个方法可以交还 jQuery 命名的控制权
jQuery.noConflict()
​
// 上面代码执行完毕以后 $ 这个变量就不能用了
// 但是 jQuery 可以使用
console.log($) // undefined
console.log(jQuery) // 可以使用
// 这个方法可以交并且传递一个 true 的时候,会完全交出控制权
jQuery.noConflict(true)
​
// 上面代码执行完毕以后 $ 这个变量就不能用了
// jQuery 这个变量也不能用了
console.log($) // undefined
console.log(jQuery) // undefined
// 可以用一个变量来接受返回值,这个变量就是新的控制权
var aa = jQuery.noConflict(true)
​
// 接下来就可以把 aa 当作 jQuery 向外暴露的接口使用了
aa('div').click(function () { console.log('我被点击了') })

JQuery 的插件扩展

扩展给他自己本身

// jQuery.extend 接受一个参数,是一个对象,对象里面是我们扩展的方法
jQuery.extend({
 max: function (...n) { return Math.max.apply(null, n) },
 min: function (...n) { return Math.min.apply(null, n) }
})
const max = $.max(4, 5, 3, 2, 6, 1)
console.log(max) // 6
const min = $.min(4, 5, 3, 2, 6, 1)
console.log(min) // 1

扩展给元素集

// jQuery.fn.extend() 接受一个参数,是一个对象,对象里面是我们扩展的方法
jQuery.fn.extend({
 checked: function () {
 // return 关键字是为了保证链式编程
 // 后面的代码才是业务逻辑
 return this.each(function() { this.checked = true })
    }
})
// 靠元素集合来调用
$('input[type=checkbox]').checked()
// 执行完毕之后,所有的 复选框 就都是选中状态了

上一篇 下一篇

猜你喜欢

热点阅读