jQuery
发送 ajax 请求
$.get('./ajax.php', { id: 10 }, function (res) { console.log(res) }, 'json')
$.post('./ajax.php', { id: 10 }, function (res) { console.log(res) }, 'json')
$.ajax({
url: './ajax',
type: 'GET',
data: {},
dataType: 'json',
async: true,
success () {},
error () {},
cache: true,
context: div,
status: {},
timeout: 1000,
})
$.ajax({
url: './jsonp.php',
dataType: 'jsonp',
data: { name: 'Jack', age: 18 },
success (res) {
console.log(res)
},
jsonp: 'cb',
jsonpCallback: 'fn'
})
全局 ajax 函数
- 全局的
ajax 函数我们也叫做 ajax 的钩子函数
- 也就是在一个
ajax 的整个过程中的某一个阶段执行的函数
- 而且每一个
ajax 请求都会触发
ajaxStart
$(window).ajaxStart(function () {
console.log('有一个请求开始了')
})
ajaxSend
- 任意一个请求在 准备 send 之前 会触发这个函数
$(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
- 那么,我们的
jQuery 就不能用了
- 那么这个时候,
jQuery 为我们提供了一个多库并存的方法
jQuery.noConflict()
console.log($)
console.log(jQuery)
jQuery.noConflict(true)
console.log($)
console.log(jQuery)
var aa = jQuery.noConflict(true)
aa('div').click(function () { console.log('我被点击了') })
JQuery 的插件扩展
jQuery 确实很好很强大
- 但是也有一些方法是他没有的,我们的业务需求中有的时候会遇到一些它里面没有的方法
- 那么我们就可以给他扩展一些方法
扩展给他自己本身
- 扩展给自己本身使用
jQuery.extend 这个方法
- 扩展完后的内容只能用
$ 或者 jQuery 来调用
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)
const min = $.min(4, 5, 3, 2, 6, 1)
console.log(min)
扩展给元素集
- 扩展完毕以后给元素的集合使用
- 也就是我们用
$('li') 这样的选择器获取到的元素集合来使用
- 使用
jQuery.fn.extend() 方法来扩展
jQuery.fn.extend({
checked: function () {
return this.each(function() { this.checked = true })
}
})
$('input[type=checkbox]').checked()
更多推荐