欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

測(cè)試IE瀏覽器對(duì)JavaScript的AngularJS的兼容性

 更新時(shí)間:2015年06月19日 11:17:36   投稿:goldensun  
這篇文章主要介紹了測(cè)試IE瀏覽器對(duì)JavaScript的AngularJS的兼容性的方法,盡管隨著Windows10的近期上市,IE瀏覽器即將成為歷史...需要的朋友可以參考下

短版本

為確保Angular應(yīng)用在IE上能夠工作請(qǐng)確認(rèn):

1. 在IE7或更早的版本上polyfill JSON.stringify。你可以使用JSON2或JSON3來(lái)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>

2. 在連接處將id="ng-app"添加到根元素,使用ng-app屬性
 

<!doctype html>
 <html xmlns:ng="http://angularjs.org" id="ng-app" ng-app="optionalModuleName">
  ...
 </html>

3. 你不能使用自定義的元素標(biāo)記,像<ng:view>(使用屬性版本<div ng-view>來(lái)代替),或

4. 如果你必需要用自定義元素標(biāo)記,然后你必須采取以下步驟以確保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>

5. 使用ng-style標(biāo)記來(lái)替代style="{{ someCss }}"。后續(xù)的版本能夠在Chrome和Firefox下工作但不能在IE版本<=11下工作(在撰寫本文時(shí)的最新版本)。


重要部分是:

  •     xmlns:ng- 命名空間- 你需要為每一個(gè)自定義標(biāo)簽指定一個(gè)命名空間。
  •     document.createElement(yourTagName)- 創(chuàng)建自定義標(biāo)簽名 - 因?yàn)檫@只是對(duì)舊版本IE的問(wèn)題,所以你需要指定加載條件。對(duì)于每一個(gè)沒(méi)有命名空間并且在HTML中沒(méi)有定義的標(biāo)簽,你需要提前聲明以使得IE識(shí)別。

版本信息

IE對(duì)非標(biāo)準(zhǔn)的標(biāo)簽元素有很多問(wèn)題。這些問(wèn)題可以歸為兩大類別,每一類別都有自己的解決辦法。

  •     如果標(biāo)簽名以my:開頭那么他會(huì)被當(dāng)做XML命名空間并且必須有對(duì)應(yīng)的命名空間聲明<html xmlns:my="ignored">
  •     如果標(biāo)簽沒(méi)有:符號(hào)但是不是標(biāo)準(zhǔn)HTML標(biāo)簽,那么必須提前使用document.createElement('my-tag')創(chuàng)建。
  •     如果你計(jì)劃用CSS選擇器改變自定義標(biāo)簽的樣式,那么不管有沒(méi)有命名空間你都得提前用document.createElement('my-tag')創(chuàng)建.


好消息

好消息是這些限制僅僅適用于元素標(biāo)記名稱并不適用于元素屬性名稱。因此,在IE中并不需要特別的處理:<div my-tag your:tag></div>
如果我不這樣做,會(huì)發(fā)生什么?

假如你使用HTML的未知標(biāo)記mytag(my:tag或者my-tag結(jié)果是相同的):

 
<html>
  <body>
   <mytag>some text</mytag>
  </body>
 </html>

 

應(yīng)該解析出如下的DOM:
 

#document
 +- HTML
   +- BODY
    +- mytag
      +- #text: some text

預(yù)期的行為是BODY元素有一個(gè)mytag子元素,它帶有一些文字。

但是在IE中不是這樣的(如果沒(méi)有包含上面的修訂)
 

#document
 +- HTML
   +- BODY
    +- mytag
    +- #text: some text
    +- /mytag

在IE中,BODY元素有三個(gè)子元素:

1,一個(gè)自關(guān)閉的mytag。例如自關(guān)閉標(biāo)簽<br/>。/是可選的,但是<br>標(biāo)簽是不允許有子元素的,瀏覽器將<br>some text</br>視為三個(gè)同輩的標(biāo)簽,而some text并不是<br>的子元素。

2,一個(gè)文本節(jié)點(diǎn)some text。在上面這應(yīng)該是mytag的子元素,而不是同輩標(biāo)簽

3.一個(gè)損壞的自關(guān)閉的/mytag。這是一個(gè)損壞的元素因?yàn)樵孛Q是不允許帶/字符的。另外,這種子關(guān)閉的元素并不是DOM的一部分,它僅僅是用于描述DOM的結(jié)構(gòu)。

CSS風(fēng)格的自定義標(biāo)記命名

為確保CSS選擇器能夠在自定義元素上工作,自定義元素的名稱必須預(yù)先使用document.createElement('my-tag')創(chuàng)建,不需顧慮XML的命名空間。
 

<html xmlns:ng="needed for ng: namespace">
  <head>
   <!--[if lte IE 8]>
    <script>
     // 需要確認(rèn)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>

相關(guān)文章

  • AngulaJS路由 ui-router 傳參實(shí)例

    AngulaJS路由 ui-router 傳參實(shí)例

    本篇文章主要介紹了AngulaJS路由 ui-router 傳參實(shí)例 ,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-04-04
  • Angular實(shí)現(xiàn)跨域(搜索框的下拉列表)

    Angular實(shí)現(xiàn)跨域(搜索框的下拉列表)

    angular.js 自帶jsonp,實(shí)現(xiàn)跨域,下面來(lái)實(shí)現(xiàn)搜索框的下拉列表功能,本文思路明確,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-02-02
  • AngularJS  $modal彈出框?qū)嵗a

    AngularJS $modal彈出框?qū)嵗a

    這篇文章主要介紹了AngularJS 彈出框 $modal,大家都知道open是$modal唯一方法,通過(guò)本文給大家列出了該方法的屬性。對(duì)angularjs彈出框知識(shí)感興趣的朋友一起看下吧
    2016-08-08
  • Angular5給組件本身的標(biāo)簽添加樣式class的方法

    Angular5給組件本身的標(biāo)簽添加樣式class的方法

    本篇文章主要介紹了Angular 5 給組件本身的標(biāo)簽添加樣式class的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • Angular outlet實(shí)現(xiàn)頁(yè)面布局示例詳解

    Angular outlet實(shí)現(xiàn)頁(yè)面布局示例詳解

    這篇文章主要為大家介紹了Angular outlet實(shí)現(xiàn)頁(yè)面布局示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • 基于angularJS的表單驗(yàn)證指令介紹

    基于angularJS的表單驗(yàn)證指令介紹

    下面小編就為大家?guī)?lái)一篇基于angularJS的表單驗(yàn)證指令介紹。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2016-10-10
  • 詳解基于Angular4+ server render(服務(wù)端渲染)開發(fā)教程

    詳解基于Angular4+ server render(服務(wù)端渲染)開發(fā)教程

    本篇文章主要介紹了詳解基于Angular4+ server render(服務(wù)端渲染)開發(fā)教程 ,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-08-08
  • Angular實(shí)現(xiàn)的日程表功能【可添加及隱藏顯示內(nèi)容】

    Angular實(shí)現(xiàn)的日程表功能【可添加及隱藏顯示內(nèi)容】

    這篇文章主要介紹了Angular實(shí)現(xiàn)的日程表功能,帶有向日程表中添加內(nèi)容及隱藏顯示內(nèi)容的功能,涉及AngularJS事件響應(yīng)及頁(yè)面元素動(dòng)態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2017-12-12
  • Angular 4.x中表單Reactive Forms詳解

    Angular 4.x中表單Reactive Forms詳解

    這篇文章主要介紹了Angular 4.x中表單Reactive Forms的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),相信對(duì)大家具有一定的參考價(jià)值,需要的朋友們下面來(lái)一起看看吧。
    2017-04-04
  • 詳解Angualr 組件間通信

    詳解Angualr 組件間通信

    本篇文章主要介紹了Angualr 組件間通信,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-01-01

最新評(píng)論