<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Javascript的IE和Firefox兼容性匯編[轉]

    JavascriptIEFirefox兼容性匯編
    以下以 IE 代替 Internet Explorer,以 MF 代替 Mozzila Firefox
    1. document.form.item
    問題
    (1)
    現有問題:
    現有代碼中存在許多 document.formName.item("itemName") 這樣的語句,不能在 MF 下運行
    (2)
    解決方法:
    改用 document.formName.elements["elementName"]
    (3)
    其它
    參見 2
    2.
    集合類對象問題
    (1)
    現有問題:
    現有代碼中許多集合類對象取用時使用 ()IE 能接受,MF 不能。
    (2)
    解決方法:
    改用 [] 作為下標運算。如:document.forms("formName") 改為 document.forms["formName"]
    又如:document.getElementsByName("inputName")(1) 改為 document.getElementsByName("inputName")[1]
    (3)
    其它
    3. window.event
    (1)
    現有問題:
    使用 window.event 無法在 MF 上運行
    (2)
    解決方法:
    MF
    event 只能在事件發生的現場使用,此問題暫無法解決。可以這樣變通:
    原代碼(可在IE中運行)
    <input type="button" name="someButton" value="
    提交" onclick="javascript:gotoSubmit()"/>
    ...
    <script language="javascript">
    function gotoSubmit() {
    ...
    alert(window.event); // use window.event
    ...
    }
    </script>
    新代碼(可在IEMF中運行)
    <input type="button" name="someButton" value="
    提交" onclick="javascript:gotoSubmit(event)"/>
    ...
    <script language="javascript">
    function gotoSubmit(evt) {
    evt = evt ? evt : (window.event ? window.event : null);
    ...
    alert(evt); // use evt
    ...
    }
    </script>
    此外,如果新代碼中第一行不改,與老代碼一樣的話( gotoSubmit 調用沒有給參數),則仍然只能在IE中運行,但不會出錯。所以,這種方案 tpl 部分仍與老代碼兼容。
    4. HTML
    對象的 id 作為對象名的問題
    (1)
    現有問題
    IE 中,HTML 對象的 ID 可以作為 document 的下屬對象變量名直接使用。在 MF 中不能。
    (2)
    解決方法
    getElementById("idName") 代替 idName 作為對象變量使用。
    5.
    idName字符串取得對象的問題
    (1)
    現有問題
    IE中,利用 eval(idName) 可以取得 id idName HTML 對象,在MF 中不能。
    (2)
    解決方法
    getElementById(idName) 代替 eval(idName)
    6.
    變量名與某 HTML 對象 id 相同的問題
    (1)
    現有問題
    MF 中,因為對象 id 不作為 HTML 對象的名稱,所以可以使用與 HTML 對象 id 相同的變量名,IE 中不能。
    (2)
    解決方法
    在聲明變量時,一律加上 var ,以避免歧義,這樣在 IE 中亦可正常運行。
    此外,最好不要取與 HTML 對象 id 相同的變量名,以減少錯誤。
    (3)
    其它
    參見 問題4
    7. event.x
    event.y 問題
    (1)
    現有問題
    IE 中,event 對象有 x, y 屬性,MF中沒有。
    (2)
    解決方法
    MF中,與event.x 等效的是 event.pageX。但event.pageX IE中沒有。
    故采用 event.clientX 代替 event.x。在IE 中也有這個變量。
    event.clientX
    event.pageX 有微妙的差別(當整個頁面有滾動條的時候),不過大多數時候是等效的。
    如果要完全一樣,可以稍麻煩些:
    mX = event.x ? event.x : event.pageX;
    然后用 mX 代替 event.x
    (3)
    其它
    event.layerX
    IE MF 中都有,具體意義有無差別尚未試驗。

    8.
    關于frame
    (1)
    現有問題
    IE 可以用window.testFrame取得該framemf中不行
    (2)
    解決方法
    frame的使用方面mfie的最主要的區別是:
    如果在frame標簽中書寫了以下屬性:
    <frame src="xx.htm" id="frameId" name="frameName" />
    那么ie可以通過id或者name訪問這個frame對應的window對象
    mf只可以通過name來訪問這個frame對應的window對象
    例如如果上述frame標簽寫在最上層的window里面的htm里面,那么可以這樣訪問
    ie
    window.top.frameId或者window.top.frameName來訪問這個window對象
    mf
    只能這樣window.top.frameName來訪問這個window對象
    另外,在mfie中都可以使用window.top.document.getElementById("frameId")來訪問frame標簽
    并且可以通過window.top.document.getElementById("testFrame").src = 'xx.htm'來切換frame的內容
    也都可以通過window.top.frameName.location = 'xx.htm'來切換frame的內容
    關于framewindow的描述可以參見bbs的‘windowframe’文章
    以及/test/js/test_frame/目錄下面的測試
    ----adun 2004.12.09
    修改
    9.
    mf中,自己定義的屬性必須getAttribute()取得
    10.
    mf中沒有 parentElement parement.children 而用
    parentNode parentNode.childNodes
    childNodes
    的下標的含義在IEMF中不同,MF使用DOM規范,childNodes中會插入空白文本節點。
    一般可以通過node.getElementsByTagName()來回避這個問題。
    html中節點缺失時,IEMFparentNode的解釋不同,例如
    <form>
    <table>
    <input/>
    </table>
    </form>
    MF
    input.parentNode的值為form, IEinput.parentNode的值為空節點
    MF
    中節點沒有removeNode方法,必須使用如下方法 node.parentNode.removeChild(node)
    11.const
    問題
    (1)
    現有問題:
    IE 中不能使用 const 關鍵字。如 const constVar = 32; IE中這是語法錯誤。
    (2)
    解決方法:
    不使用 const ,以 var 代替。
    12. body
    對象
    MF
    bodybody標簽沒有被瀏覽器完全讀入之前就存在,而IE則必須在body完全被讀入之后才存在
    13. url encoding
    js中如果書寫url就直接寫&不要寫&例如var url = 'xx.jsp?objectName=xx&objectEvent=xxx';
    frm.action = url
    那么很有可能url不會被正常顯示以至于參數沒有正確的傳到服務器
    一般會服務器報錯參數沒有找到
    當然如果是在tpl中例外,因為tpl中符合xml規范,要求&書寫為&
    一般MF無法識別js中的&

    14. nodeName
    tagName 問題
    (1)
    現有問題:
    MF中,所有節點均有 nodeName 值,但 textNode 沒有 tagName 值。在 IE 中,nodeName 的使用好象
    有問題(具體情況沒有測試,但我的IE已經死了好幾次)。
    (2)
    解決方法:
    使用 tagName,但應檢測其是否為空。
    15.
    元素屬性
    IE
    input.type屬性為只讀,但是MF下可以修改

    16. document.getElementsByName()
    document.all[name] 的問題
    (1)
    現有問題:
    IE 中,getElementsByName()document.all[name] 均不能用來取得 div 元素(是否還有其它不能取的元素還不知道)。

    1. 對象問題
    1.1 Form
    對象
    現有問題:
    現有代碼這獲得form對象通過document.forms("formName"),這樣使用在IE 能接受,MF 不能。
    解決方法:
    改用 作為下標運算。改為document.forms["formName"]
    備注
    上述的改用 作為下標運算中的formNameidname

    1.2 HTML
    對象
    現有問題:
    IE 中,HTML 對象的 ID 可以作為 document 的下屬對象變量名直接使用。在 MF 中不能。
    document.all("itemName")
    或者document.all("itemId")
    解決方法:
    使用對象ID作為對象變量名
    document.getElementById("itemId")
    備注
    document.all
    IE自定義的方法,所以請大家盡量不使用。
    還有一種方式,在IEMF都可以使用
    var f = document.forms["formName "];
    var o = f. itemId;

    1.3 DIV
    對象
    現有問題:
    IE 中,DIV對象可以使用ID作為對象變量名直接使用。在 MF 中不能。
    DivId.style.display = "none"
    解決方法:
    document.getElementById("DivId").style.display = "none"
    備注
    獲得對象的方法不管是不是DIV對象,都使用getElementById方法。參見1.2


    1.4
    關于frame
    現有問題
    IE 可以用window.testFrame取得該framemf中不行
    解決方法
    frame的使用方面MFIE的最主要的區別是:
    如果在frame標簽中書寫了以下屬性:

    那么IE可以通過id或者name訪問這個frame對應的window對象
    mf只可以通過name來訪問這個frame對應的window對象
    例如如果上述frame標簽寫在最上層的window里面的htm里面,那么可以這樣訪問
    IE
    window.top.frameId或者window.top.frameName來訪問這個window對象
    MF
    :只能這樣window.top.frameName來訪問這個window對象
    另外,在mfie中都可以使用window.top.document.getElementById("frameId")來訪問frame標簽
    并且可以通過window.top.document.getElementById("testFrame").src = 'xx.htm'來切換frame的內容
    也都可以通過window.top.frameName.location = 'xx.htm'來切換frame的內容

    1.5
    窗口
    現有問題
    IE
    中可以通過showModalDialogshowModelessDialog打開模態和非模態窗口,但是MF不支持。
    解決辦法
    直接使用window.open(pageURL,name,parameters)方式打開新窗口。
    如果需要傳遞參數,可以使用frame或者iframe

    2.
    總結
    2.1
    JS中定義各種對象變量名時,盡量使用id,避免使用name
    IE 中,HTML 對象的 ID 可以作為 document 的下屬對象變量名直接使用。在 MF 中不能,所以在平常使用時請盡量使用id,避免只使用name,而不使用id

    2.2
    變量名與某 HTML 對象 id 相同的問題
    現有問題
    MF 中,因為對象 id 不作為 HTML 對象的名稱,所以可以使用與 HTML 對象 id 相同的變量名,IE 中不能。
    解決方法
    在聲明變量時,一律加上 var ,以避免歧義,這樣在 IE 中亦可正常運行。
    此外,最好不要取與 HTML 對象 id 相同的變量名,以減少錯誤。
    posted on 2006-03-03 09:47 隨風逝 閱讀(658) 評論(2)  編輯  收藏 所屬分類: javascript

    評論

    # re: Javascript的IE和Firefox兼容性匯編[轉] 2006-03-03 10:58 隨風逝  回復  更多評論   

    ff和ie還是很有區別滴。以后做東javascript要注意規范了啊,不然……

    # re: Javascript的IE和Firefox兼容性匯編[轉] 2006-08-23 16:44 q  回復  更多評論   

    說的很好!
    請教一個有關firefox傳遞event的問題,可否舉個例子?我用event.clientX老報錯呀!說event has no property,怎么回事?
    主站蜘蛛池模板: 我要看免费的毛片| 美女18毛片免费视频| 免费人成大片在线观看播放| 2021久久精品免费观看| 久久久久久亚洲精品成人| 中文字幕无码日韩专区免费 | 暖暖免费高清日本一区二区三区| 亚洲视频一区二区三区| 最近中文字幕免费完整| 中文字幕亚洲免费无线观看日本| 免费视频中文字幕| 欧美激情综合亚洲一二区| 最近最新的免费中文字幕| 国产免费伦精品一区二区三区 | 亚洲一区二区三区香蕉| 一个人看的在线免费视频| 亚洲精品麻豆av| 国产午夜精品理论片免费观看| 国产AⅤ无码专区亚洲AV| a级男女仿爱免费视频| 亚洲国产精品久久久久婷婷老年| 久久免费公开视频| 337p欧洲亚洲大胆艺术| 国产一级特黄高清免费大片| 九九免费久久这里有精品23| 亚洲一级免费毛片| 日韩在线免费电影| 在线成人爽a毛片免费软件| 免费一级毛片在线播放放视频| 亚洲啪啪免费视频| 国产99视频精品免费视频7| 全部免费毛片在线播放| 亚洲精品第一国产综合野| 成年人免费视频观看| 午夜老司机永久免费看片| 国产精品亚洲精品| 亚洲国产综合专区在线电影| 亚洲乱码日产精品a级毛片久久| 国产精品久久久久久久久久免费| 免费高清A级毛片在线播放| 亚洲w码欧洲s码免费|