ajax第四天笔记

本文记录了使用jQuery进行文件上传时的注意事项,包括添加contentType和processData配置,并介绍了axios请求的重点,如get和post请求的使用。同时,探讨了同源策略与跨域问题,包括jsonp和CORS解决方案。最后,讨论了防抖和节流的概念及其应用场景,以优化事件处理性能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.jquery 上传文件

 $.ajax({
                    method: 'POST',
                    url: 'http://www.liulongbin.top:3006/api/upload/avatar',
                    data: fd,
                    contentType: false,
                    processData: false,
                    success: function (res) {
                        console.log(res);
                    },
                });

注意:在$.ajax({})配置项里需要加contentType: false processData: false 两行代码

用$(document).ajaxStart()和$(document).ajaxStop() 可以监听ajax开始和结束事件

2.axios请求(重点)

 document
                .querySelector('#btn1')
                .addEventListener('click', function () {
                    var url = 'http://www.liulongbin.top:3006/api/get';
                    var data = { name: 'ls', age: 20 };
                    axios.get(url, data).then(function (res) {
                        console.log(res.data);
                    });
                });

在点击事件中,通过axios语法axios.get(url, data).then(function (res) { console.log(res)})发起axios请求;

1.axios get请求:axios.get('url', { params: { /参数/ } }).then(callback)

2.axios post请求:axios.post('url', { /参数/ }).then(callback)

3.直接使用axios发起请求:

发起get请求

 document
                .querySelector('#btn3')
                .addEventListener('click', function () {
                    axios({
                        method: 'GET',
                        url: 'http://www.liulongbin.top:3006/api/get',
                        data: {
                            name: 'zs',
                            age: 22,
                        },
                    }).then(function (res) {
                        console.log(res.data);
                    });
                });

发起post请求

document
                .querySelector('#btn4')
                .addEventListener('click', function () {
                    axios({
                        method: 'POST',
                        url: 'http://www.liulongbin.top:3006/api/post',
                        data: {
                            name: 'zs',
                            age: 2222,
                        },
                    }).then(function (res) {
                        console.log(res.data);
                    });
                });

3.同源与跨域

1.定义:协议,地址,端口都相同的即为同源,否则即是跨域

2.跨域:不同源的情况下ajax请求会被浏览器的同源策略所拦截,无法使用数据,所以要解决跨域的问题

3.跨域解决方法:

  • jsonp 临时想出的解决方法,只支持get请求,

  • CORS: 支持get和post两种请求方式,但存在兼容性问题

  • 后端可以添加白名单,我们之前的ajax请求其实也有跨域的问题,是通过后端添加白名单解决的

4.jsonp跨域原理:

script标签请求外部资源没有跨域问题,通过客户端定义函数的声明,服务端调用这个定义的函数,

利用src属性请求服务端JS文件

5.jquery发起jsonp请求:添加配置项: dataType: 'jsonp'

4.防抖与节流

1、防抖

概念:短时间内的多次事件触发是没必要的,通过定时器,让短时间内的一系列会触发多次的事件

最终只执行最后一次,在定时器所规定的时间内再次触发会重新计时

使用场景:搜索栏防抖 浏览器大小的调整

好处:节省了不必要的资源请求,减轻服务器等的压力

2.节流

概念:单位时间内多次触发的事件只执行一次,

使用场景:轮播图 懒加载

好处:降低计算频率,减轻cpu负荷

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值