电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

原生js XMLhttprequest請求onreadystatechange執(zhí)行兩次的解決

瀏覽:25日期:2022-06-01 18:54:38
目錄
  • 原生js XMLhttprequest請求onreadychange執(zhí)行兩次
  • 關于readyState不同狀態(tài)總結
    • (0) 未初始化
    • (1) 載入
    • (2) 載入完成
    • (3) 交互
    • (4) 完成
  • 總結

    原生js XMLhttprequest請求onreadychange執(zhí)行兩次

    最近做到一個頁面需要兼容IE,然后就寫了一個原生 XMLhttprequest請求

    直接上錯誤代碼

    xmlHttp = new XMLHttpRequest();
    ? ? ? ? xmlHttp.open("post","https://baidu.com/mianxiang/baidu/biancheng");
    ? ? ? ? xmlHttp.setRequestHeader("Content-Type","application/json");
    ? ? ? ? xmlHttp.send(XXXXXXXXXX) ;
    ? ? ? ? xmlHttp.onreadystatechange = function () {
    ? ? ? ? ? ? if(this.status==200){
    ? ? ? ? ? ? ? ? console.log("responseText",this.responseText);
    ? ? ? ? ? ? }
    ? ? ? ? };

    在上面代碼中,當status == 200 的console.log內容每次請求,都會在控制臺打印兩次,也就是說里面的邏輯會被執(zhí)行兩次,百度了很多都沒有發(fā)現相似問題,和具體解決辦法。

    xmlHttp = new XMLHttpRequest();
    ? ? ? ? xmlHttp.open("post","https://baidu.com/mianxiang/baidu/biancheng");
    ? ? ? ? xmlHttp.setRequestHeader("Content-Type","application/json");
    ? ? ? ? xmlHttp.send(XXXXXXXXXX) ;
    ? ? ? ? xmlHttp.onreadystatechange = function () {
    ? ? ? ? ? ? if(xmlHttp.readyState == 4 && this.status==200){
    ? ? ? ? ? ? ? ? console.log("responseText",this.responseText);
    ? ? ? ? ? ? }
    ? ? ? ? };

    最后偶然發(fā)現了和正確代碼的差距,補上“ xmlHttp.readyState == 4 ”

    執(zhí)行一次,問題解決。

    分析,可能是因為在沒有添加判斷readyState時,當options預請求執(zhí)行時,也會有一次狀態(tài)碼200的,所以會被執(zhí)行兩次,但是疑惑點是預請求不會返回數據,但是在打印時,兩次打印都是有數據的。

    查資料+請教大佬 = get 知識

    知識:

    • 創(chuàng)建xmlhttprequest對象之后沒有調用open之前readystate值為0,調用open()之后就變?yōu)?了,并且此時onreadystatechange函數與open()幾乎是同時執(zhí)行的。
    • 在之后調用send方法之后,在startHttpRequest函數中readystate值仍為1,而調用send方法之后應該有2,3,4三個狀態(tài),而只有在startHttpRequest函數用alert語句才可以觀察到3個值!
    • 這是為什么呢?這是因為在startHttpRequest函數中當解析到send這一句時,并沒有真正開始執(zhí)行send執(zhí)行。
    • 只有send執(zhí)行,才可以在onreadystatechange函數觀察到狀態(tài)值的變化。
    • readystate不是發(fā)送的狀態(tài),它是準備發(fā)送的狀態(tài),要把它想像成“人間大炮一級準備、二級準備、放”這樣的口號,不是請求發(fā)送本身。
    • 同時xmlhttp也不是監(jiān)聽服務器信息,它是在send的時候獲取服務器返回的狀態(tài)信息而已,只有一次,監(jiān)聽則是一直在觀察狀態(tài)。

    關于readyState不同狀態(tài)總結

    (0) 未初始化

    此階段確認XMLHttpRequest對象是否創(chuàng)建,并為調用open()方法進行未初始化作好準備。

    值為0表示對象已經存在,否則瀏覽器會報錯--對象不存在。

    (1) 載入

    此階段對XMLHttpRequest對象進行初始化,即調用open()方法,根據參數(method,url,true)完成對象狀態(tài)的設置。

    并調用send()方法開始向服務端發(fā)送請求。值為1表示正在向服務端發(fā)送請求。

    (2) 載入完成

    此階段接收服務器端的響應數據。但獲得的還只是服務端響應的原始數據,并不能直接在客戶端使用。

    值為2表示已經接收完全部響應數據。并為下一階段對數據解析作好準備。

    (3) 交互

    此階段解析接收到的服務器端響應數據。

    即根據服務器端響應頭部返回的MIME類型把數據轉換成能通過responseBody、responseText或responseXML屬性存取的格式,為在客戶端調用作好準備。

    狀態(tài)3表示正在解析數據。

    (4) 完成

    此階段確認全部數據都已經解析為客戶端可用的格式,解析已經完成。

    值為4表示數據解析完畢,可以通過XMLHttpRequest對象的相應屬性取得數據。

    這個時候再回顧之前為何執(zhí)行兩次onreadystatechange, 因為當state每次變化的時候都會執(zhí)行到onreadystatechange,其實是readyState每次變化都會有執(zhí)行onreadystatechange,因為我判斷了this.status == 200 ,所以當服務器響應了之后返回了200的狀態(tài)碼,才會執(zhí)行console.log(),才有上面的執(zhí)行兩次的問題。

    至此問題解決!!!

    總結

    以上為個人經驗,希望能給大家一個參考,也希望大家多多支持。

    標簽: JavaScript
    主站蜘蛛池模板: 雷冲击高压发生器-水内冷直流高压发生器-串联谐振分压器-武汉特高压电力科技有限公司 | 浴室柜-浴室镜厂家-YINAISI · 意大利设计师品牌 | 咿耐斯 |-浙江台州市丰源卫浴有限公司 | 合肥升降机-合肥升降货梯-安徽升降平台「厂家直销」-安徽鼎升自动化科技有限公司 | 美国PARKER齿轮泵,美国PARKER柱塞泵,美国PARKER叶片泵,美国PARKER电磁阀,美国PARKER比例阀-上海维特锐实业发展有限公司二部 | 珠海白蚁防治_珠海灭鼠_珠海杀虫灭鼠_珠海灭蟑螂_珠海酒店消杀_珠海工厂杀虫灭鼠_立净虫控防治服务有限公司 | 皮带输送机-大倾角皮带输送机-皮带输送机厂家-河南坤威机械 | 净化板-洁净板-净化板价格-净化板生产厂家-山东鸿星新材料科技股份有限公司 | 执业药师报名时间,报考条件,考试时间-首页入口 | 风信子发稿-专注为企业提供全球新闻稿发布服务| 手术室净化装修-手术室净化工程公司-华锐手术室净化厂家 | 安徽千住锡膏_安徽阿尔法锡膏锡条_安徽唯特偶锡膏_卡夫特胶水-芜湖荣亮电子科技有限公司 | 别墅图纸超市|别墅设计图纸|农村房屋设计图|农村自建房|别墅设计图纸及效果图大全 | 首页_欧瑞传动官方网站--主营变频器、伺服系统、新能源、软起动器、PLC、HMI | 营养师网,营养师考试时间,报名入口—网站首页| 九州网址_专注于提供网址大全分享推广中文网站导航服务 | 合肥办公室装修 - 合肥工装公司 - 天思装饰 | 工业制氮机_psa制氮机厂家-宏骁智能装备科技江苏有限公司 | 北京律师事务所_房屋拆迁律师_24小时免费法律咨询_云合专业律师网 | 匀胶机旋涂仪-声扫显微镜-工业水浸超声-安赛斯(北京)科技有限公司 | 水性绝缘漆_凡立水_绝缘漆树脂_环保绝缘漆-深圳维特利环保材料有限公司 | 2025第九届世界无人机大会| 全自动包装机_灌装机生产厂家-迈驰包装设备有限公司 | 正压送风机-多叶送风口-板式排烟口-德州志诺通风设备 | 十字轴_十字轴万向节_十字轴总成-南京万传机械有限公司 | 氮化镓芯片-碳化硅二极管 - 华燊泰半导体 | 木材烘干机,木炭烘干机,纸管/佛香烘干设备-河南蓝天机械制造有限公司 | 东莞爱加真空科技有限公司-进口真空镀膜机|真空镀膜设备|Polycold维修厂家 | 餐饮加盟网_特色餐饮连锁加盟店-餐饮加盟官网 | 奇酷教育-Python培训|UI培训|WEB大前端培训|Unity3D培训|HTML5培训|人工智能培训|JAVA开发的教育品牌 | 衬四氟_衬氟储罐_四氟储罐-无锡市氟瑞特防腐科技有限公司 | 恒压供水控制柜|无负压|一体化泵站控制柜|PLC远程调试|MCGS触摸屏|自动控制方案-联致自控设备 | 江西自考网 | 中空玻璃生产线,玻璃加工设备,全自动封胶线,铝条折弯机,双组份打胶机,丁基胶/卧式/立式全自动涂布机,玻璃设备-山东昌盛数控设备有限公司 | 嘉兴恒升声级计-湖南衡仪声级计-杭州爱华多功能声级计-上海邦沃仪器设备有限公司 | 阀门智能定位器_电液动执行器_气动执行机构-赫尔法流体技术(北京)有限公司 | 合肥白癜风医院_合肥治疗白癜风医院_合肥看白癜风医院哪家好_合肥华研白癜风医院 | 特种阀门-调节阀门-高温熔盐阀-镍合金截止阀-钛阀门-高温阀门-高性能蝶阀-蒙乃尔合金阀门-福建捷斯特阀门制造有限公司 | 户外健身路径_小区健身器材_室外健身器材厂家_价格-浩然体育 | 儿童乐园|游乐场|淘气堡招商加盟|室内儿童游乐园配套设备|生产厂家|开心哈乐儿童乐园 | 顶空进样器-吹扫捕集仪-热脱附仪-二次热解吸仪-北京华盛谱信仪器 | 定制奶茶纸杯_定制豆浆杯_广东纸杯厂_[绿保佳]一家专业生产纸杯碗的厂家 |