html\css\js-dom在不同主流浏览器的兼容问题

1、html

主要是解决html5在主流浏览器上的兼容性。特别是在IE浏览器上的兼容性。

//方法 一:使用google的html5shiv包,将它引入放在<head></head>内部

<!--[if IE]>

<script src='http://html5shiv.googlecode.com/svn/trunk/html5.js'></script>

<![endif]-->

//原理就是使html5标签成块状

//方法二:直接写js代码

<!--[if lt IE9]>   

<script>   

  (function() { 

    if (!   

    /*@cc_on!@*/ 

    0) return; 

    var e = "abbr, article, aside, audio, canvas, datalist, details, dialog, eventsource, figure, footer, header, hgroup, mark, menu, meter, nav, output, progress, section, time, video".split(', '); 

    var i= e.length; 

    while (i--){ 

        document.createElement(e[i]) 

    }   

})()   

</script> 

<![endif]-->

注:@cc_on!@可以被ie识别并作为程序执行,同时启用ie的条件编译

//方法三:如果ie6/7/8 禁用脚本的用户,那么可以参照facebook的做法,引导用户进入带有noscript标识的页面,用html4标签代替HTML5标签。当用户点击’查看这里’时,引导用户进入html4标签设计的网页

<!--[if lte IE 8]>   

<noscript> 

    <style>.html5-wrappers{display:none!important;}</style> 

    <div class="ie-noscript-warning">您的浏览器禁用了脚本,请<a href="">查看这里</a>来启用脚本!或者<a href="/?noscript=1">继续访问</a>. 

    </div> 

</noscript> 

<![endif]-->

css

css3不兼容IE9以下浏览器的解决方案:

//对于css3新增的属性,大多数解决方式是属性名前加不同浏览器内核前缀

-ms-border-radius

-moz-border-radius

-o-border-radius

-webkit-radius

也可以使用google提供的一个包

<!--[if lte IE 9]>

    <script src="JS/selectivizr.js"></script>

    <![endif]-->

    但是,需要注意几点:

    (1)与selectivizr.js同文件夹下需要放入PIE.htc,PIE_IE9.js,PIE_IE678.js,prefixfree.min.js文件;

    (2)样式不能是行内样式;

    (3)如果需要用到伪类的选择器,请在页面引用JQ、 MooTools文件等,不同的文件对选择器的支持程度不同。

其他,css在不同浏览器的差异解决

(1)cursor:hand; 和 cursor:pointer

firfox不支持hand,IE支持pointer

所以统一使用pointer

(3)css透明问题

firfox:opacity:0.5;

IE:filter(alpha=50);zoom:1;

(4)css中的width和padding

在IE7和FF中width宽度不包括padding,在IE6中包括padding

(5)IE中盒子大小不包括border;Firfox中包括

解决方案:使用!important

div{margin:30px !important;margin:28px;}

因为在IE中不之别!important,在别的浏览器识别它。

(6)margin加倍问题

在IE中,给float的div设置margin值会加倍,这是IE6都存在的问题

解决方案:给div加 display:inline;

(7)IE不识别min-

在IE 中把正常的width和height当有min-的情况。所以可以同时设置width和min-width

div{width:auto;height:auto;min-width:80px;}

js-DOM

(1)注册事件和移出事件

IE : attachEvent(on+eventName,callback) callback中的this指向window ; detachEvent(on+eventName)

火狐和谷歌:addEventListener(eventName,callback,false) callback中this指向当前事件对象 ; removeEventListener(eventName)

(2)取消事件冒泡

IE: window.event.cancelBubble = true

火狐: e.stopPropagation()

谷歌二者都可以

(3)取消浏览器默认行为

通用的return false;

event.preventDefault() //低版本IE不支持

低版本IE: window.event.returnValue = false

(4)innerText和textContent

IE中有innerText属性,firfox中有textContent

解决方案:

function setInnerText(ele,content){

    if(typeof ele.textContent==='undefined'){

    ele.innerText = content

}else{

    ele.textContent=content

}

}

(5)input的type属性

IE: input的type属性是只读的

Firfox: input的type属性是可写的

(6)重定向到新页面

IE\火狐2.0 : window.location 或者 window.location.href

Firfox1.5 : window.location

(7)获取事件的真正触发者

IE : window.event.srcElement

火狐: event.target

(8)获取样式float关键字

IE : element.style.styleFloat

非IE : element.style.cssFloat

(9)获得计算后的样式

IE: element.currentStyle

非IE: window.getComputedStyle(element,null)

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,980评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,178评论 2 380
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,868评论 0 336
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,498评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,492评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,521评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,910评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,569评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,793评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,559评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,639评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,342评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,931评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,904评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,144评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,833评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,350评论 2 342

推荐阅读更多精彩内容