angular.js,IE7,8,9兼容性的处理

这段时间详细了解了谷歌新出的MVVM框架angular.js,并直接在本人所从事的项目中使用了。但是使用新东西都是有风险的,这不,采用了新框架的页面IE7,8各种显示不出来……心想着难道用以前的办法重来?不能允许!于是上网查阅了大量资料。终于跑通了,并且知道是怎么回事。

 

以下面这个IE7,8,9都跑得通的例子说明,重点是红字的部分:

<!DOCTYPE html>

<html>

<head>

<script src="app/js/json2.js"></script>

<script src="app/lib/angular/angular.js"></script>

<script src="demo.js"></script>

</head>

<body  ng-app id="ng-app" class="ng-cloak">

<div ng-controller="InvoiceCntl">

<b>Invoice:</b>

<br>

<br>

<table>

<tr><td>Quantity</td><td>Cost</td></tr>

<tr>

<td><input type="integer" min="0" ng-model="qty" required ></td>

<td><input type="number" ng-model="cost" required ></td>

</tr>

</table>

<hr>

<b>Total:</b> {{qty * cost | currency}}

</div>

</body>

</html>

 

要让IE7这个渣渣happy,你必须加上json2.js或者其他json文件(IE7没有原生的支持)。然后,你还需要在申明ng-app脚本的地方特意加上id="ng-app",这样IE7才能识别(因为IE7不支持自建元素)。如此IE7就能跑通了。IE7跑的通,IE8,IE9也没有问题。

 

官网上有一个教程例子:phonecat,想必各位想用angular.js的同志都看了。但是作为官网的例子,这货居然不能在IE7,8下转。用本人的方法稍微修改一下phonecat的index.html,就也能跑了:

 

<!DOCTYPE html>

 

<html lang="en" >

<head>

<meta charset="utf-8">

<!--[if lt IE 9]>

<script src="http://www.angularjs.cn/wp-content/themes/angularjs/js/html5.js" type="text/javascript"></script>

<![endif]-->

<title>Google Phone Gallery</title>

<link rel="stylesheet" href="css/app.css">

<link rel="stylesheet" href="css/bootstrap.css">

<script src="js/json2.js"></script>

<script src="lib/angular/angular.js"></script>

<script src="js/app.js"></script>

<script src="js/controllers.js"></script>

<script src="js/filters.js"></script>

<script src="js/services.js"></script>

<script src="lib/angular/angular-resource.js"></script>

</head>

<body ng-app="phonecat" id="ng-app">

<div ng-view></div>

</body>

</html>

 

此外,官网上提到两点:

1.如果我们需要使用老派风格的directive语法”ng:”,那么我们需要加入一个xml-namespace到html标签中以“取悦”IE。(这个是一个历史原因,我们也不推荐使用ng:)

<html xmlns:ng="http://angularjs.org">

对于采用标准写法的脚本(一切都是以ng-开始而不是ng:开始)就不需要这行内容了。

2.如果你按照angularjs的规则创建了很多自定义标签,那么每个自定义标签,对于IE7,8都必须自己写js 声明创建了这些标签。就像这样:

<!--[if lte IE 8]>

<script>

document.createElement('ng-include');

document.createElement('ng-pluralize');

document.createElement('ng-view');

</script>

<![endif]-->

 

总而言之,使用了angular.js,就仿佛看到了当初W3C标准化组织对web的远景规划:用XML替代html一样。各种操作声明、自定义标签将使DOM操作和应用逻辑解耦,它能大大改善代码的可调性。Angular信奉的是,当组建视图(UI)同时又要写软件逻辑时,声明式的代码会比命令式的代码好得多。