IE6 迁移到 Firefox 的工作笔记

IE6 迁移到 Firefox 的工作笔记
jxc 最后更新于: 2010-07-09


☆ 前言
   
    △ 一些参考资料
        html5规范, firefox3已经支持
        http://www.w3.org/html/wg/html5/
       
        http://nexgenmedia.net/evang/iemozguide/        
        http://www.javascriptkit.com/domref/
       
        firefox对css的扩展
        http://developer.mozilla.org/en/docs/CSS_Reference:Mozilla_Extensions
       
        关于css3的信息,能在线测试当前浏览器对css3的支持情况
        http://www.css3.info
   
    △ 使IE5,IE6支持css2.0标准的 js 扩展库 (推荐)
        http://code.google.com/p/ie7-js/
        页面load后通过js来实现, 目前对运行时动态修改css的处理还不完善
        另外毕竟js模拟的效果,大量应用会有性能问题
   
   
    △ js调试工具推荐 firefox 的 firebug 插件
        能够给js设置断点执行
        能够运行时修改css样式
        查看dom模型等
    
    △ IE8 自带的developer bar也不错
        

☆ javascript 相关
    △ 这里也有部分总结
        http://www.cnitblog.com/joyboy/archive/2008/07/01/42429.html
       
    △  document.all("id")   -> document.getElementById("id")
        并且控件尽量用id,而不是name标识
        提示: form 内用于提交的元素必须定义name        
        提示: 如果控件只有name,没有id, 用getElementById时:
            IE:也可以找到对象
            FF:返回NULL
   
    △  获得form里某个元素的方法
        elForm.elements['name'];
   
    △  取集合元素时, ie支持  [],() 2种写法, 但是ff仅支持[],如:
        table.rows(5).cells(0)
        改为:
        table.rows[5].cells[0]
   
    △  判断对象是否是object的方法应该为
        if( typeof(obj) == "object")

   
    △  eval(对象名称)    ->  document.getElementById              
        FF支持eval函数
   

    △  在当前对象的前面插入其他对象
        obj.insertAdjacentElement("beforeBegin", elText); 
        改为用
        obj.parentNode.insertBefore(elText, obj);
   
   
    △  FF的createElement不支持HTML代码
        用document.write(esHTML);
   
        或者创建元素后再设置属性, 

        var el = createElement("input");
        el.type = "checkbox"; // 对input元素来说,需要先设置type再加入到dom里
        var obj2 = document.getElementById("id2");
        obj2.parentNode.insertBefore(el, obj2);
   
        如果是直接插入html代码,则可以考虑用
        createContextualFragment
   
   
    △  innerText -> textContent
        FF 没有innerText
        可以考虑用 innerHTML

       

        IE6/7/8 里 select 控件的 innerHTML 有 bug, 

        不过 elSelect.innerHTML = ''; 能够执行, 可用于快速删除select的内容
    
    △  对象名称中的 $ 不能识别, 建议改为 _ 或者 -
        name = "t1$spin"
        改为:
        name = "t1_spin"

        name = "t1-spin"
        
    △  FF里设置Attribute为某个对象,然后再取出来,这时候对象的属性都丢失了?
        el.setAttribute("obj", obj);
        alert(obj.id)   //正确        
        obj = el.getAttribute("obj");
        alert(obj.id) //null
       
        在IE下没有问题, FF 里 setAttribute 第2个参数都是字符串型
        解决的方法是直接赋值

        el.obj = obj;       
        obj = el.obj
   
   
    △  在html里定义的属性,必须用getAttribute才行
        <input type="text" id="t1" isOBJ="true">
        document.getElementById("t1").isOBJ 

        FF 里返回 undefined, IE下是可以的
       
        应该用:
        document.getElementById("t1").getAttribute("isOBJ")
        
            
    △  el.class -> el.className
        由于class是关键字, 所以需要用 className

        el.className = 'combobox-arrow';


        或者用 setAttribute
        setAttribute("class","css样式名称");
      
   
    △  FF里select控件不再是:总是在顶端显示
        需要设置控件的zIndex
        IE6 里select控件总在顶端显示, div不能盖住select
        覆盖select控件的方法是, 用 ifame 盖住 select, 再设置div元素的zIndex大于iframe的zIndex
   
    △  对于if ( vars == undefined ) 下面的值用于判断是等同的
        undefined
        null
        false
        0
   
   
    △  如果FF调用 el.focus(); 报错
        尝试改为:
        window.setTimeout( function(){ el.focus(); }, 20);
   
   
    △  FF 里 keyCode 是只读的, 那把回车转换为tab怎么办? 在录入时进行键值转换怎么办??
   
        解决方案:
        1. 回车跳转 -> 自己写跳转处理代码.
            遍历dom里所有的元素, 找到当前元素的下一个能够设置焦点的,当前可见的元素, 给其设置焦点
            如果该元素的父节点是不可见的, 则还是会报错, 所以设置焦点时, 需要try catch, 如果报错,则继续找下一个
       
        2. 录入时进行键值转换.
            利用selection, 选中光标后面的内容, 替换为新输入的内容
             
    △  <button> 会被firefox解释为提交form或者刷新页面???
        需要写上type

        <button type="button">按钮</button>
        或者 οnclick="原函数调用(); return false;"
   
   
    △  在firefox里, document.onfocus里获得不到实际获得焦点的控件?
        为什么document.keydown可以呢?
   
    △  children    -> childNodes      
   
    △  sytle.pixelHeight -> style.height
   
    △  判断函数或者变量是否存在, 没有则创建一个, 避免调用时 js 错误
        if (!("foo" in window)) var foo = function() { alert("请实现 foo 方法"); };
       
   
    △  获得客户区尺寸
        IE里与doctype有关
        <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" >
       
        如果html包含上面的语句,则应该用下面的方法获取
        document.documentElement.clientWidth
        否则用
        document.body.clientWidth
        
   

        
    △  window.createPopup
        FF不支持
   
    △  document.body.onresize
        FF 不支持
        用window.onresize        
        注意,页面打开时并不会触发onresize事件? 需要在onload里也调用一次才行
   
    △  box模型的问题
        IE下默认的是 content-box 为了统一, 可在页面第一行写: 

        <!DOCTYPE html>

 

        这样写即可, 不用写剩余的内容, google和taobao都这么用

    
    △  注册事件
        IE: el.attachEvent
        FF: el.addEventListener("blur", myBlur, false);
            第1个参数事件名称不需要带"on"
            第3个参数false代表事件传递从事件对象沿dom树往body方向传(与IE的方向一致)
                
    △  触发事件
        IE: el.fireEvent("onclick");
        FF:
          var e = document.createEvent("Events");  
          e.initEvent("click",   true,   false);  
          element.dispatchEvent(event)
   
    △  在自定义函数中获得对象句柄
        var oThis = this;
        obj.onfocus = function(evt){
            oThis.doOnFocus(evt);
        }
   
    △  统一事件处理框架代码
        function doOnFocus(evt){
            evt = evt || window.event;
            var el = evt.target || evt.srcElement;
           
            // 后续处理
        }
       
   
    △  FF不支持onpropertychange事件
        但是FF里可以定义属性的setter方法, 如下面的:
        HTMLElement.prototype.__defineSetter__("readOnly",
            function(readOnly){
                // 构造虚拟的event对象
                var evt = [];
                evt["target"] = this;
                evt["propertyName"] = "readOnly"
               
                //onpropertychange函数需要定义evt参数, 参考统一事件处理框架代码
                if ("onpropertychange" in this) this.onpropertychange(evt);
            }
        );

 

    △ document.activeElement
        用途: 在当前对象的 onblur 事件里, 可以通过 activeElement 获得下一个获得焦点的对象
        在做combobox等组件时很有用


        html5规范里加入, firefox3里已经支持, 但是要做一点儿技巧处理才能得到 activeElement


function text_blur(evt){
   evt = evt || window.event;
   var el = evt.target || evt.srcElement; 
   var btn = el.popup_button;
  

   // post 处理才行
   window.setTimeout(function(){text_blur_post(btn);},20);
}

 

function text_blur_post(btn){

   // 这时候才能获得到 activeElement
   var elActive = document.activeElement;
   if (elActive != btn) btn.style.display = "none";
}
        
   

 

☆ css 相关
   
    △  cursor:hand  ->  cursor:pointer
           

    △  FILTER  firefox不支持
        filter: Alpha(Opacity=50);
        替换为
        -moz-opacity: 0.5;
   
    △  text-overflow
        不支持
   
    △  transparent
        firefox下 obj.setAttribute("bgColor","#ffffff") 只支持颜色
        必须用

        obj.style.backgroundColor = "transparent" 才行
   
    △  FF下text控件高度与IE不同
        input[type=text] {
            height:20px;
        }
       
        注意 input 与 [ 之间不能有空格!
   
    △  font在IE里不能对body和td等起作用
        统一用 font-family

    

    △ 字体推荐用 Arial 字体

        虽然 FF 默认用宋体, 但是Arail字体的综合表现比较好


    △  expression  firefox不支持
        expression的确能够解决IE6对css2支持不足的问题,这样只需要定义css就可以兼容IE和FF了
        在IE下expression非常消耗CPU, 所以不建议在大量的element上应用!!

       
    △  IE6 仅支持 a:hover, 不支持其它对象的 :hover
       
        1. 加入下面的css
            .ie-hover {
                behavior: expression(
                    this.onmouseover = new Function("this.className = 'hover';"),
                    this.onmouseout = new Function("this.className = 'ie-hover';"),
                    this.style.behavior = null
                );
            }
           
            上面必须用 this.style.behavior = null , 否则某些情况会有严重的性能问题
           
           
        2. 在需要 :hover 的元素上增加 class
            <li class="ie-hover">
           
        3. 定义 :hover 样式同时定义 .hover 样式
            ul li:hover , ul li.hover {
                xxx
            }
           

    △  IE6里 <a> 必须定义href属性  a:hover 才有效
           

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值