document.onreadystatechange_js转json格式

document.onreadystatechange_js转json格式标准参考无。问题描述onreadystatechange事件通常用在基于XMLHttpRequest对象的AJAX应用中,当的该对象的loadstate改变时,会触发此事件。但在IE

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

标准参考

无。

问题描述

onreadystatechange 事件通常用在基于 XMLHttpRequest 对象的 AJAX 应用中,当的该对象的 load state 改变时,会触发此事件。

但在 IE 中 onreadystatechange 事件是其私有实现的,用于数据加载的 IMG、SCRIPT 和 LINK 标记,常常被误用 onreadystatechange 事件而导致在非 IE 浏览器中无法得到预期结果。

造成的影响

onreadystatechange 事件处理在各浏览器支持不一致,可能会导非预期结果。

受影响的浏览器

    

问题分析

onreadystatechange 事件是微软对 IE 浏览器的私有事件扩充,所有元素都存在 onreadystatechange 事件。

下列元素对象总可以触发此事件,因为他们均会加载数据:APPLET,DOCUMENT,FRAME,FRAMESET,IFRAME,IMG,LINK,OBJECT,SCRIPT 和 XML 元素。

其他元素对象仅当 DHTML Behavior 被追加后会触发 onreadystatechange 事件。

其具体信息可以参照 MSDN 说明:http://msdn.microsoft.com/en-us/library/ms536957(VS.85).aspx。

本文中将主要以 IMG、SCRIPT、LINK 这三个元素对象为例来检测浏览器对他们的 onreadystatechange 事件支持程度。

首先,分析以下代码,将 onreadystatechange 事件作为内联事件分别写于 IMG、SCRIPT 和 LINK 标记中:

<script> function OnStateChangeImage(image) {

document.getElementById (‘img-info’).innerHTML += ‘<br />readyState: ‘ + image.readyState;

}

function OnStateChangeScript(script) {

document.getElementById (‘script-info’).innerHTML += ‘<br />readyState: ‘ + script.readyState;

}

function OnStateChangeLink(link) {

document.getElementById (‘link-info’).innerHTML += ‘<br />readyState: ‘ + link.readyState;

} </script> <span id=”link-info” >The link is loading.</span><br /> <span id=”img-info” >The image is loading.</span><br /> <span id=”script-info”>The script is loading.</span><br /> <link rel=”stylesheet” type=”text/css” href=”http://www.cnblogs.com/http://www.cnblogs.com/http://www.cnblogs.com/css/article.css” onreadystatechange=”OnStateChangeLink(this)” /> <img src=”w3c.png” onreadystatechange=”OnStateChangeImage (this)” /> <script src=’http://code.jquery.com/jquery-1.4.js’ onreadystatechange=”OnStateChangeScript(this)”></script>

在各浏览器输出如下:

        

    The image is loading.

The image readyState: complete     The image is loading.

    The script is loading.

The script readyState: loading

The script readyState: loaded

The script readyState: complete     The scirpt is loading

    The link is loading.

The link readyState: complete     The link is loading

即:非 IE 浏览器均不支持触发 IMG、SCRIPT 和 LINK 标记的内联 onreadystatechange 事件。

让后,下面将分析动态创建的 IMG、SCRIPT 标记的在各浏览器中能否触发 onreadystatechange 事件:

function loadJS(url) { var domScript = document.createElement(‘script’); domScript.onreadystatechange = function() { var divElement = document.createElement(‘div’); divElement.appendChild(document.createTextNode(‘readyState:’+ domScript.readyState +’ 动态创建的 SCRIPT 标记可以触发 onreadystatechange 事件’)); document.body.appendChild(divElement); } domScript.src = url; document.getElementsByTagName(‘head’)[0].appendChild(domScript);} function loadIMG(url) { var domImage = document.createElement(‘img’); domImage.onreadystatechange = function() { var divElement = document.createElement(‘div’); divElement.appendChild(document.createTextNode(‘readyState:’+ domImage.readyState +’ 动态创建的 IMG 标记可以触发 onreadystatechange 事件’)); document.body.appendChild(divElement); } domImage.src = url; document.getElementsByTagName(‘head’)[0].appendChild(domImage);} function loadCSS(url) { var domLink = document.createElement(‘link’); domLink.onreadystatechange = function() { var divElement = document.createElement(‘div’); divElement.appendChild(document.createTextNode(‘readyState:’+ domLink.readyState +’ 动态创建的 LINK 标记可以触发 onreadystatechange 事件’)); document.body.appendChild(divElement); } domLink.rel = ‘stylesheet’; domLink.type = ‘text/css’; domLink.href = url; document.getElementsByTagName(‘head’)[0].appendChild(domLink);} window.onload=function (){ //执行动态加载外部 JS 文件 loadJS(‘http://code.jquery.com/jquery-1.4.js’); //执行动态加载图片文件 loadIMG(‘w3c.png’); //执行动态加载css文件 loadCSS(‘http://www.cnblogs.com/http://www.cnblogs.com/../css/article.css’);}

各浏览器输出如下:

            

    readyState:complete 动态创建的 IMG 标记可以触发 onreadystatechange 事件     readyState:undefined 动态创建的 IMG 标记可以触发 onreadystatechange 事件     无内容输出

    readyState:loading 动态创建的 SCRIPT 标记可以触发 onreadystatechange 事件

readyState:loaded 动态创建的 SCRIPT 标记可以触发 onreadystatechange 事件     readyState:loaded 动态创建的 Script 标记可以触发 onreadystatechange 事件     无内容输出

    readyState:complete 动态创建的 LINK 标记可以触发 onreadystatechange 事件     readyState:undefined 动态创建的 LINK 标记可以触发 onreadystatechange 事件     无内容输出

可见,此次测试中,除 IE 浏览器外,Opera 对于动态创建的 IMG、SCRIPT 和 LINK 标记也可以触发 onreadystatechange 事件,但他对不同元素加载过程中触发该事件的频率以及 readyState 状态值的支持细节又不同于 IE。

【注】:对于 MSDN 中其他标记或对象在非 IE 浏览器中支持 onreadystatechange 事件的情况,本文将不再一一验证,读者如有兴趣可以自行测试。

解决方案

在现行 W3C 标准规范中仅有 XmlHttpRequest 对象中存在 onreadystatechange 事件 ( 请参考 XMLHttpRequest 规范 )。

对于其他元素或对象请慎用 onreadystatechange 事件,因为他只有 IE 浏览器支持,而 Opera 浏览器则只是部分支持。

如果使用 onreadystatechange 是为了处理脚本加载(回调)的问题,请参考 BX9013: 动态引入的外部 JS 文件在各浏览器中的加载顺序不一致 一文“解决方案”中的内容。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/167569.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • listagg within group函数的作用_oracletochar函数

    listagg within group函数的作用_oracletochar函数前言:最近在写一些比较复杂的SQL,是一些统计分析类的,动不动就三四百行,也是首次写那么长的SQL,有用到一些奇形怪状的SQL函数,在这里结合网上的例子做一些笔记,以后用到不记得用法可以翻出来看!1.基础用法:LISTAGG(XXX,XXX)WITHINGROUP(ORDERBYXXX),就像聚合函数一样,通过Groupby语句,把每个Group的一个字段,拼接起来…

    2022年9月7日
    5
  • zencart模板如何设计「建议收藏」

    zencart模板如何设计「建议收藏」ZenCart的模板设计比较复杂,需要一定的时间来熟悉。一旦你了解了它的结构,就会慢慢习惯了。  首先要阅读常见问答部分的:如何添加、制作新模板。ZenCart的设计没有什么特别,与以前设计HTML页面是一样的。只是整个页面分成了好几个部分,并加入了PHP代码。  通常,页面分为页眉(header),页脚(footer),边框(sideboxes)。所以设计页面的时候

    2022年7月27日
    4
  • win10更新失败0x80240fff_win10系统更新出现错误代码

    win10更新失败0x80240fff_win10系统更新出现错误代码Windows无法更新,无法启用功能,0x8000FFFF错误,系统存在损坏文件,用管理员打开命令行(或powershell)运行sfc/scannow检查并修复。

    2022年9月25日
    2
  • windows cuda安装_虚拟机 cuda

    windows cuda安装_虚拟机 cuda1.cuda的安装到 https://developer.nvidia.com/cuda-downloads(旧:URL )去下载。在安装的时候一定要自定义安装,否则将会安装

    2022年8月6日
    4
  • 送你一张图,教你如何docker卸载redis,请收好「建议收藏」

    送你一张图,教你如何docker卸载redis,请收好「建议收藏」一张图,告诉你怎么操作。嘿嘿❤如果文章对您有所帮助,就在文章的右上角或者文章的末尾点个赞吧!(づ ̄3 ̄)づ❤如果喜欢大白兔分享的文章,就给大白兔点个关注吧!(๑′ᴗ‵๑)づ╭❤~❤对文章有任何问题欢迎小伙伴们下方留言或者入群探讨【群号:708072830】❤鉴于个人经验有限,所有观点及技术研点,如有异议,请直接回复讨论(请勿发表攻击言)…

    2022年9月7日
    2
  • 头文件cstring、string、string.h的区别「建议收藏」

    头文件cstring、string、string.h的区别「建议收藏」头文件cstring、string、string.h的区别<string>是C++标准库头文件,使用stirng类型必须首先包含string头文件,用于字符串操作,string类型可以进行+、=、+=、>等运算。std::string类实际上是STL模板类std::basic_string的具体化。#include<string>usingnamespacestd;strings;<cstring>是C标准库头文件<strin

    2025年9月3日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号