AngularJS的IE相容性【已翻譯100%】
備註:AngularJS 1.3拋棄了對IE8的支援。可以在我們的部落格上了解更多內容。AngularJS 1.2將繼續支援IE8,但核心團隊已經不打算在解決IE8及之前版本的問題上花時間。
本文件介紹了網際網路瀏覽器(IE)在處理自定義HTML標籤及屬性時的特點。如果你正計劃在IE8或更早的瀏覽器上部署Angular應用請閱讀本文。
專案目前支援且將嘗試修復IE9以上的bug 。持續整合伺服器在IE9,IE10和IE11上執行所有的測試。詳細內容參加Travis CI及ci.angularjs.org。
我們不在IE8及之前的瀏覽器上執行測試。一些AngularJS的功能子集也許能夠在在這些瀏覽器上工作,但這將由你來測試並決定它在你的特定應用上是否工作。
短版本
為確保Angular應用在IE上能夠工作請確認:
- 在IE7或更早的版本上polyfill JSON.stringify。你可以使用JSON2或JSON3來polyfills。
<!doctype html>
<html xmlns:ng="http://angularjs.org">
<head>
<!--[if lte IE 7]>
<script src="/path/to/json2.js"></script>
<![endif]-->
</head>
<body>
...
</body>
</html>
- 在連線處將id=”ng-app”新增到根元素,使用ng-app屬性
<!doctype html>
<html xmlns:ng="http://angularjs.org" id="ng-app" ng-app="optionalModuleName">
...
</html>
- 你不能使用自定義的元素標記,像(使用屬性版本
來代替),或
- 如果你必需要用自定義元素標記,然後你必須採取以下步驟以確保IE8及之前版本都能用:
<!doctype html>
<html xmlns:ng="http://angularjs.org" id="ng-app" ng-app="optionalModuleName">
<head>
<!--[if lte IE 8]>
<script>
document.createElement(`ng-include`);
document.createElement(`ng-pluralize`);
document.createElement(`ng-view`);
// Optionally these for CSS
document.createElement(`ng:include`);
document.createElement(`ng:pluralize`);
document.createElement(`ng:view`);
</script>
<![endif]-->
</head>
<body>
...
</body>
</html>
- 使用ng-style標記來替代style=”{{ someCss }}”。後續的版本能夠在Chrome和Firefox下工作但不能在IE版本<=11下工作(在撰寫本文時的最新版本)。
重要部分是:
xmlns:ng- 名稱空間- 你需要為每一個自定義標籤指定一個名稱空間。
document.createElement(yourTagName)- 建立自定義標籤名 – 因為這只是對舊版本IE的問題,所以你需要指定載入條件。對於每一個沒有名稱空間並且在HTML中沒有定義的標籤,你需要提前宣告以使得IE識別。
版本資訊
IE對非標準的標籤元素有很多問題。這些問題可以歸為兩大類別,每一類別都有自己的解決辦法。
- 如果標籤名以my:開頭那麼他會被當做XML名稱空間並且必須有對應的名稱空間宣告 xmlns:my=”ignored”>
- 如果標籤沒有:符號但是不是標準HTML標籤,那麼必須提前使用document.createElement(`my-tag`)建立。
- I如果你計劃用CSS選擇器改變自定義標籤的樣式,那麼不管有沒有名稱空間你都得提前用document.createElement(`my-tag`)建立.
好訊息
好訊息是這些限制僅僅適用於元素標記名稱並不適用於元素屬性名稱。因此,在IE中並不需要特別的處理:
如果我不這樣做,會發生什麼?
假如你使用HTML的未知標記mytag(my:tag或者my-tag結果是相同的):
<html>
<body>
<mytag>some text</mytag>
</body>
</html>
應該解析出如下的DOM:
#document
+- HTML
+- BODY
+- mytag
+- #text: some text
預期的行為是BODY元素有一個mytag子元素,它帶有一些文字。
但是在IE中不是這樣的(如果沒有包含上面的修訂)
#document
+- HTML
+- BODY
+- mytag
+- #text: some text
+- /mytag
在IE中,BODY元素有三個子元素:
1,一個自關閉的mytag。例如自關閉標籤
。/是可選的,但是
標籤是不允許有子元素的,瀏覽器將
some text視為三個同輩的標籤,而some text並不是
的子元素。
2,一個文字節點some text。在上面這應該是mytag的子元素,而不是同輩標籤
3.一個損壞的自關閉的/mytag。這是一個損壞的元素因為元素名稱是不允許帶/字元的。另外,這種子關閉的元素並不是DOM的一部分,它僅僅是用於描述DOM的結構。
CSS風格的自定義標記命名
為確保CSS選擇器能夠在自定義元素上工作,自定義元素的名稱必須預先使用document.createElement(`my-tag`)建立,不需顧慮XML的名稱空間。
<html xmlns:ng="needed for ng: namespace">
<head>
<!--[if lte IE 8]>
<script>
// 需要確認ng-include被正常解析
document.createElement(`ng-include`);
// 需求啟用CSS引用
document.createElement(`ng:view`);
</script>
<![endif]-->
<style>
ng:view {
display: block;
border: 1px solid red;
}
ng-include {
display: block;
border: 1px solid blue;
}
</style>
</head>
<body>
<ng:view></ng:view>
<ng-include></ng-include>
...
</body>
</html>
相關文章
- Java:將100以內的數字翻譯成英文Java
- PHP最常用函式TOP100(翻譯)PHP函式
- 解決ie相容性問題
- [翻譯]Windows Exploit開發教程第十三章Part1.IE10-IE逆向工程WindowsIE10
- 掘金開源庫翻譯招募譯者啦(活動已結束)
- 騰訊互動翻譯的坑爹翻譯
- [翻譯]Windows Exploit開發教程第十四章Part1.IE11WindowsIE11
- [翻譯]Windows Exploit開發教程第十四章Part2.IE11WindowsIE11
- 翻譯
- Arctime怎麼翻譯字幕?Arctime批次翻譯字幕的技巧
- Symbol 的作用[翻譯]Symbol
- [翻譯]JavaScript的成本JavaScript
- [翻譯]Windows Exploit開發教程第十三章Part5.IE10 UAF漏洞WindowsIE10
- 蝴蝶書-task2: 文字推理、摘要、糾錯 transformers實現翻譯 OpenAI翻譯 PyDeepLX翻譯 DeepLpro翻譯ORMOpenAI
- 影象處理入門 100 題,有人把它翻譯成了中文版!
- Ubuntu安裝劃詞翻譯軟體Goldendict 單詞翻譯 句子翻譯UbuntuGo
- 如何完成中文翻譯日文線上翻譯
- 火爆 GitHub 的《機器學習 100 天》,有人把它翻譯成了中文版!Github機器學習
- [翻譯]Windows Exploit開發教程第十三章Part4.IE10 上帝模式(2)WindowsIE10模式
- [翻譯]Windows Exploit開發教程第十三章Part3.IE10 上帝模式(1)WindowsIE10模式
- 多翻譯引擎的程式
- Laravel 谷歌翻譯 /Bing 翻譯擴充套件包Laravel谷歌套件
- OpenCV翻譯專案總結二——Mat翻譯OpenCV
- 實用的Word文件翻譯方法分享,讓Word文件快速翻譯
- 人工翻譯的分類 安睿傑線上翻譯平臺
- 關於火狐和IE下href=”javascript:void(0)”相容性的問題JavaScript
- Angularjs——初識AngularJSAngularJS
- PendingIntent 是個啥?官方文件描述的很到位。我給翻譯翻譯Intent
- 翻譯英文軟體哪個好?中文翻譯英文最便捷的方法
- 告別生硬翻譯!AI谷歌翻譯:讓你的文字"說人話"AI谷歌
- 最佳 AI 翻譯工作流:全世界最信達雅的翻譯AI
- 使用google翻譯 api 翻譯中文成其他語言GoAPI
- 文件翻譯器怎麼用?如何翻譯Word文件?
- 有道雲詞典--翻譯/螢幕取詞翻譯
- TailWind文件翻譯說明以及每日翻譯進度AI
- [Web翻譯]JavaScript中的編譯與填充WebJavaScript編譯
- 跨越專業翻譯的語言之牆:百度翻譯的技術攀登
- 【譯】表單元件的屬性相容性表元件
- 翻譯介面整理