JS可以设置任意请求header吗?
可以:用setRequestHeader
放在.open和.send之间
data:image/s3,"s3://crabby-images/ccb96/ccb96e6ef77f006128f2ae9b98797d1988bf7c29" alt=""
data:image/s3,"s3://crabby-images/987e2/987e263a1753f7e71f969e491211f4b93c28814c" alt=""
请求头显示出来了
那第4部分能不能设置?(要用POST请求)
搜 js set request body
.send()
data:image/s3,"s3://crabby-images/5931e/5931ee2f15951ad8ed9cbc8b7801cc52152a662f" alt=""
data:image/s3,"s3://crabby-images/1c503/1c503af12f630dfe37ef5ca76c50a4becdc1c4dd" alt=""
getAllResponseHeaders()
getResponseHeader
data:image/s3,"s3://crabby-images/6bde8/6bde8c17e4ee11752ecc3ff0e01aca3de4af4a57" alt=""
所有的响应的头——字符串
request.statusText就是获取OK啊什么的
requset.responseText
data:image/s3,"s3://crabby-images/fa1fc/fa1fc7a702349f364bb1fa060fdd049798e1d66d" alt=""
AJAX的请求和响应
服务端需要端口号
data:image/s3,"s3://crabby-images/2d558/2d5585d80a8823b5058b82f9451bf89fbae528ff" alt=""
jquery.ajax
window.jQuery.ajax的内存图
data:image/s3,"s3://crabby-images/806ae/806ae11c73f9e4c2ff01bbc33d72cfd6b97d895f" alt=""
写jquery.ajax的目的是把4行代码变成一行
data:image/s3,"s3://crabby-images/50a28/50a286b885f09c6aa0acb6e143fa41fc06d451f0" alt=""
data:image/s3,"s3://crabby-images/c5794/c579427799dd39a7b54e6996444d371b25a6e0e3" alt=""
问题:时间长了,无法确定下面的参数是什么意思
data:image/s3,"s3://crabby-images/c9510/c9510734b3ed2ed3b0821fc6c8ea7f72fd377874" alt=""
问题:当使用GET方法,第三个参数其实不需要的,那怎么办?只能写undefined或者null,代码看起来丑
比如某个API xxx(null,null,null,null,1)完全不知道每个参数的意思
办法:用有结构的参数
箭头函数是没有arguments的
data:image/s3,"s3://crabby-images/2d578/2d5786e327494fa6996dcbf9085e8fe9637c14f9" alt=""
使用方用到了successFn,而里面的参数x是被调用方的第一个参数request.responseText,即x <-request.responseText,这就叫做callback
如果请求失败了,有没有可能依然存在第4部分?
答案:是的
模拟下:
data:image/s3,"s3://crabby-images/7a55e/7a55e06f683acd720a763ede8d9f37c863b4cd43" alt=""
data:image/s3,"s3://crabby-images/9832e/9832efc4c511e4525a93284f9c472ecc49ab8367" alt=""
data:image/s3,"s3://crabby-images/0fadc/0fadce00b2a2c158f6632ef44db0914801e6d508" alt=""
data:image/s3,"s3://crabby-images/8937e/8937e66d69a9967eade593e03f18f0b30db7ccab" alt=""
data:image/s3,"s3://crabby-images/772e7/772e70c349be2d4bb1c4dabc307f7b80295b8d81" alt=""
一个函数如何接受两种形式的参数?
data:image/s3,"s3://crabby-images/bf074/bf0744828ae13e3573505426e6d403230be45d1e" alt=""
data:image/s3,"s3://crabby-images/a616b/a616b77a0e81ae24e86b9eecf10c3e36ce93f126" alt=""
data:image/s3,"s3://crabby-images/905b7/905b75bde535d097820f8f49277368900cc2e77f" alt=""
data:image/s3,"s3://crabby-images/e3c1f/e3c1fd4f8b022a88fcdc6c822b090c8b089f4eb8" alt=""
ES5和ES6
如果成功了,会打印出responsText和成功
data:image/s3,"s3://crabby-images/564a4/564a44093ee3eeaadb16d071f44c8c332f319510" alt=""
'成功'是作为第二个then的参数传进去的
第一个then里的return的值会传递给下一个then的输入参数
问题:为什么成功之后打印出来的结果是个对象?(responsText)
data:image/s3,"s3://crabby-images/9a518/9a518728fefaf71e3bdc24a42c6983389d098bb4" alt=""
因为jQuery发现你的返回值的content-type是text/json,json这4个字母,会自动把字符串转换成对象
data:image/s3,"s3://crabby-images/6df2d/6df2db29ff6a018f445b51ad48cfb39cd8b20717" alt=""
代码变更
window的promise是怎么的?
data:image/s3,"s3://crabby-images/339a3/339a3b3778603e34231c8abbbd7afc19fbb0f3b0" alt=""
要用promise,需要new一个,需要传入一个函数
data:image/s3,"s3://crabby-images/8cbd6/8cbd61ef95a43a718108d56169ecc699f3a1b673" alt=""
promise返回的对象带有then属性,所以可以调用then
then也返回一个promise对象,所以可以继续then
网友评论