ie浏览器: Trident内核 也称为ie内核
chrome浏览器: webkit内核,现在是blink内核
firefox浏览器: gecko内核
safari浏览器: webkit内核
oprea浏览器: presto内核,后来变成了webkit,现在成了blink内核
360浏览器: IE+chrome
百度: IE的内核
猎豹: IE+chrome
qq浏览器: IE兼容性模式 + chrome 高速模式
1、不同浏览器的标签默认的外补丁( margin )和内补丁(padding)不同
解决方案: css 里增加通配符 * { margin: 0; padding: 0; }
2、当标签的高度设置小于10px,在IE6、IE7中会超出自己设置的高度
解决方案:超出高度的标签设置overflow:hidden,或者设置line-height的值小于你的设置高度
3、cursor:hand 显示手型在safari 上不支持
解决方案:统一使用 cursor:pointer
4、图片默认有间距
解决方案:使用float 为img 布局
5、IE9一下浏览器不能使用opacity
解决方案:
opacity: 0.5;filter: alpha(opacity = 50);filter: progid:DXImageTransform.Microsoft.Alpha(style = 0, opacity = 50);
6、边距重叠问题;当相邻两个元素都设置了margin 边距时,margin 将取最大值,舍弃最小值;
解决方案:为了不让边重叠,可以给子元素增加一个父级元素,并设置父级元素为overflow:hidden
7、谷歌浏览器不支持12px以下的字体,最小为12px;
我们可以使用到 css3里的一个属性:transform:scale()
8.js----event事件问题
document.οnclick=function(ev){//谷歌火狐的写法,IE9以上支持,往下不支持;
var e=ev;
console.log(e);
}
document.οnclick=function(ev){//兼容写法;
var e=ev||window.event;
var mouseX=e.clientX;//鼠标X轴的坐标
var mouseY=e.clientY;//鼠标Y轴的坐标
}
阻止事件传播:
//js阻止事件传播,这里使用click事件为例
document.οnclick=function(e){
var e=e||window.event;
if (e.stopPropagation) {
e.stopPropagation();//W3C标准
}else{
e.cancelBubble=true;//IE…
}
}
阻止默认事件:
//js阻止默认事件
document.οnclick=function(e){
var e=e||window.event;
if (e.preventDefault) {
e.preventDefault();//W3C标准
}else{
e.returnValue=‘false’;//IE…
}
}
关于event事件中的target
document.οnmοuseοver=function(e){
var e=e||window.event;
var Target=e.target||e.srcElement;//获取target的兼容写法,后面的为IE
var from=e.relatedTarget||e.formElement;//鼠标来的地方,同样后面的为IE…
var to=e.relatedTarget||e.toElement;//鼠标去的地方
}
鼠标滚轮滚动事件:
//火狐中的滚轮事件
document.addEventListener(“DOMMouseScroll”,function(event){
alert(event.detail);//若前滚的话为 -3,后滚的话为 3
},false)
//非火狐中的滚轮事件
document.onmousewheel=function(event){
alert(event.detail);//前滚:120,后滚:-120
}
节点加载:
//火狐下特有的节点加载事件,就是节点加载完才执行,和onload不同
//感觉用到的不多,直接把js代码放在页面结构后面一样能实现。。
document.addEventListener(‘DOMContentLoaded’,function ( ){},false);//DOM加载完成。好像除IE6-8都可以.
input标签:
placeholder属性是HTML5 中为input添加的。在input上提供一个占位符,文字形式展示输入字段预期值的提示信息(hint),该字段会在输入为空时显示。
(方式一)使用input的value作为显示文本,模拟灰色样式,focus让
(
"
[
p
l
a
c
e
h
o
l
d
e
r
]
"
)
.
v
a
l
(
)
=
=
"
"
,
b
l
u
r
时
("[placeholder]").val()=="",blur时
("[placeholder]").val()=="",blur时("[placeholder]").val(this.defaultValue);
(方式二)不使用value,添加一个额外的标签(span)到body里然后绝对定位覆盖到input上面。
浏览器内核兼容性
最新推荐文章于 2022-01-12 10:32:00 发布