文章引用地址:http://www.iefans.net/shanchu-ie9-wenjianjia/ 作者:iefans
---------------------------------------------------------------------------------------
以前一直用json2.js来做客户端的JSON的parse和stringify,最近在看一篇文章介绍了IE8支持原生的JSON对象,而且IE8浏览器自带了JSON.parse与JSON.stringify两个方法。不过有时候我们在代码JSON测试的时候,页面却报告说JSON未定义。既然微软官网上有提到过IE8已经支持了JSON对象,那怎么还不能使用呢?
我们先来看看这段HTML代码
<html>
<body>
<script.type="text/javascript">
alert(typeofJSON);
</script>
</body>
</html>
原来,在IE8中使用原生JSON对象是有条件的。微软在介绍JSON对象时也有下面的一段注释:
Starting with JScript. 5.8, by default, the JScript. scripting engine supports the language feature set as it existed in version 5.7. This is to maintain compatibility with the earlier versions of the engine. To use the complete language feature set of version 5.8, the Windows Script. interface host has to invoke IActiveScriptProperty::SetProperty.
Internet Explorer 8 opts into the JScript. 5.8 language features when the document mode for Internet Explorer 8 is "Internet Explorer 8 Standards" mode. For other document modes, Internet Explorer uses the version 5.7 feature set.
JScript. 5.8 includes native JavaScript. Object Notation (JSON) support and the accessor methods for Document Object Model (DOM) prototypes.
由于JSON对象是在JScript. 5.8及其以后的版本引入的,所以,默认情况下,IE8使用的是JScript. 5.7版本,所以,原生JSON对象是无法使用的。那么,如何使用IE8的原生对象呢?
IE8为了最大限度地保证浏览器的向后兼容性,使原先创建的网页能够正常显示,默认采用的是IE7的渲染引擎,同时,IE8支持多种文档兼容性模式。具体来说有:
•“模仿IE8”模式将告诉 Internet Explorer 使用 <!DOCTYPE> 指令来确定如何呈现内容。 标准模式指令将以 Internet Explorer 8 标准模式显示,而 Quirks 模式指令将以IE5模式显示。 与IE8模式不同,“模仿IE8”模式遵循 <!DOCTYPE> 指令。
•“模仿IE7”模式将告诉 Internet Explorer 使用 <!DOCTYPE> 指令来确定如何呈现内容。 标准模式指令以 Internet Explorer 7 标准模式显示,而 Quirks 模式指令以IE5模式显示。 与IE7式不同,“模仿IE7模式”遵循 <!DOCTYPE> 指令。 对于很多网站来说,这是首选的兼容性模式。
•IE5模式呈现内容的方式如同使用了 Internet Explorer 7 的 Quirks 模式来显示内容,这与 Internet Explorer 5 显示内容的方式非常相似。
•IE7模式:无论页面是否包含 <!DOCTYPE> 指令,IE7模式呈现内容的方式均如同使用了 Internet Explorer 7 的标准模式来显示内容。
•IE8模式可最大程度地支持行业标准(包括 W3C 级联样式表级别 2.1 规范 和 W3C 选择器 API),并提供对 W3C 级联样式表级别 3 规范(工作草案) 的有限支持。
•Edge模式将告诉 Internet Explorer 以可用的最高级别模式显示内容。 对于 Internet Explorer 8,这等同于IE8模式。 假设 Internet Explorer 的将来版本支持更高级别的兼容性模式,那么,设置为 Edge 模式的页面将以该版本支持的最高级别的模式显示。 当使用 Internet Explorer 8 查看时,这些相同的页面仍会以IE8模式显示。
详细介绍可以参见MSDN文档:定义文档兼容性(http://msdn.microsoft.com/zh-cn/library/cc288325(VS.85).aspx)。
注意:X-UA-compatible 标头不区分大小写;不过,它必须显示在网页中除 title 元素和其他 meta. 元素以外的所有其他元素之前的标头中。
所以,要使用IE8的原生JSON对象,可以采取下面几种方法:
方法1:定义<!DOCTYPE>
XML/XHTML 代码
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<title>ieFans.Net:JSON测试</title>
</head>
<body>
<script.type="text/javascript">
alert(typeof JSON);
</script>
</body>
</html>
方法2:设置X-UA-compatible 标头
XML/XHTML 代码
<html>
<head>
<meta.http-equiv="X-UA-Compatible" content="IE=edge">
<title>ieFans.Net:JSON测试</title>
</head>
<body>
<script.type="text/javascript">
alert(typeof JSON);
</script>
</body>
</html>
或者
<html>
<head>
<meta.http-equiv="X-UA-Compatible" content="IE=8">
<title>ieFans.Net:JSON测试</title>
</head>
<body>
<script.type="text/javascript">
alert(typeof JSON);
</script>
</body>
</html>
在实际编程程序的时候,最好的办法是进行判断,如果不支持原生的JSON,那么就是要json2.js提供的对象即可。
还有一个问题对我造成了困扰,就是当需要stringify的对象中包含中文时,ie8的方法会将中文转为unicode编码格式,比如下面:
JScript code
var json = '{"PermID":"30","PermName":"普通员工级","Remark":"最基层员工使用的权限。"}';
var o = JSON.parse(json);
document.write(JSON.stringify(o));
会输出如下结果:
{"PermID":"30","PermName":"\u666e\u901a\u5458\u5de5\u7ea7","Remark":"\u6700\u57fa\u5c42\u5458\u5de5\u4f7f\u7528\u7684\u6743\u9650\u3002"}
这样的结果如果用XHR直接POST到服务器上中文会是乱码,现在我只好不用IE8的原生对象。
不知道哪位大侠有什么更好的办法既能用IE8原生的对象,又能避免乱码。
有网友提供办法说,IE8肯定不成熟要继续打补丁的,有可能就是BUG。总不能因为客户端浏览器的不同来影响服务器端的代码,其实就是判断一下XHR的数据里是否含有十六进制\u字符,有就转换,没有就不转换。
相关推荐
标题中的“原生JSON对象及兼容问题的解决”主要涵盖了两个关键点:原生JSON对象的理解和在不同环境中处理JSON的兼容性问题。JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它基于JavaScript的一个...
总的来说,json2.js是解决JSON处理兼容性问题的一个工具,它提供了一种安全且标准化的方式来在JavaScript中进行JSON字符串与对象之间的转换,尤其对于那些不支持原生JSON操作的老版本浏览器而言。
尽管`eval`通常不推荐使用,因为它可能存在安全风险,但在没有原生JSON支持的老版本浏览器中,这是常见的解决办法。 需要注意的是,使用`eval`解析JSON字符串时,确保输入是可信的,因为`eval`可以执行任何...
这是因为JSON(JavaScript Object Notation)是ECMAScript 5引入的一个内置对象,而在IE8及以下版本中并未原生支持JSON。这篇博文()很可能详细解释了如何在不支持JSON的IE浏览器中处理这个问题。 首先,我们需要...
json2.js是由Douglas Crockford编写的JavaScript库,用于在不支持原生JSON的旧版浏览器中提供JSON解析和序列化功能。如果你的用户可能使用这些浏览器,可以引入这个库确保所有浏览器都能处理JSON。例如: ```html ...
IE8中的原生JSON支持也确保了与ECMAScript 3.1提案草案中所描述的JSON支持的兼容性。这意味着开发者可以依赖于这一标准,以确保他们的Web应用在使用JSON时,无论是在IE8还是其他支持JSON的现代浏览器上,都能保持...
然而,旧版本的IE(尤其是IE6、IE7和部分IE8)并不原生支持JSON对象,这给开发者带来了困扰,因为JSON在现代Web应用中被广泛用于数据传输。 描述中提到的"用来解决iejson不兼容的js"很可能就是指`json2.js`这个文件...
总结来说,"JSON2解决JSON未定义"意味着在不支持JSON的旧版IE浏览器中,可以通过引入JSON2.js这个库来提供JSON解析和序列化的能力,使得JSON数据能在这些浏览器中正常工作。这个知识点对于编写兼容性良好的Web应用至...
JSON2.js是由Douglas Crockford开发的一个JavaScript库,专门用于处理JSON数据,尤其在老版本的浏览器中,这些浏览器可能不支持原生的JSON解析和序列化功能。 在JavaScript中,JSON主要用于对象与字符串之间的转换...
总的来说,这段代码提供了一种在不支持原生JSON对象的浏览器中实现JSON序列化和解析的方法。尽管`eval`存在潜在的安全问题,但在这个特定的上下文中,由于我们控制着生成的JSON字符串,风险相对较低。在实际开发中,...
在JavaScript中,JSON对象是原生支持的,但在一些老版本的浏览器(如IE7及以下)中并不具备JSON处理能力。`json2.js`就是为了解决这个问题而诞生的,它引入了`JSON.parse()`和`JSON.stringify()`这两个方法,使得在...
而在服务器端,如果你的项目是基于Java的,`json.jar`中的类库可以帮助你方便地将Java对象转换为JSON字符串,或者将接收到的JSON数据解析为Java对象。 关于JSON的使用,有以下关键点: 1. **JSON格式**:JSON数据...
json2.js是Douglas Crockford编写的JavaScript库,用于在那些不支持原生JSON的旧版浏览器中提供JSON解析和序列化功能。在JavaScript中,JSON对象在ECMAScript 5及更高版本中是内置的,但较早的版本如IE6和IE7并不...
这个版本可能包含了更多的兼容性和性能优化,例如处理旧版IE浏览器的问题,这些浏览器默认不支持原生的JSON对象。 两个版本的对比可能涉及到以下方面: 1. **API一致性**:`json2.js`可能更加接近ECMAScript 5及...
这些浏览器在原生不支持JSON对象,而`json2.js`则提供了`parse`和`stringify`这两个关键方法,使得在这些浏览器中可以进行JSON的解析和序列化。 **json2.js的使用步骤:** 1. **引入库**:首先,你需要将`json2.js...
JSON在JavaScript中是原生支持的,但早期的JavaScript版本(IE8以下)不支持JSON的一些功能,因此需要引入如json2.js这样的库来提供完整的JSON支持。这个文件通常用于在前端解析和生成JSON字符串,与后端进行数据...
在JavaScript中,JSON对象是原生支持的,但在一些较老的浏览器或环境中,如IE6和IE7,它们并不支持JSON的一些关键功能,如`JSON.parse()`和`JSON.stringify()`。这就是JSON2.js的作用所在。JSON2.js库提供了一个兼容...
总之,JSON2.js是一个针对老版本浏览器的JSON解析和序列化库,它弥补了这些浏览器缺乏原生JSON支持的不足。了解并熟练使用JSON2.js可以帮助开发者确保在各种环境下都能正确地处理JSON数据,提升应用程序的兼容性和...
这样,即使是在不支持原生JSON的浏览器中,开发者也能享受到JSON带来的便利。 在使用AngularJS进行前端开发时,由于AngularJS大量依赖JSON进行数据绑定和交互,因此在遇到旧版IE浏览器时,`json2.js`就显得尤为重要...
2. **JSON 支持**:IE8 不原生支持 JSON 对象,需要引入第三方库如 `json2.js` 进行JSON解析和序列化。 3. **CSS3 和 HTML5 支持**:ECharts 使用了一些CSS3选择器和HTML5的新特性,这些在IE8中可能需要使用条件...