前端常见问题及解决方式

CSS中常见案例

1、图片间隙
div中的图片间隙
bug:在块元素中插入图片时,有时图片会将块元素下方撑大三像素。
hack:给<img>添加声明:display:block
2、表单元素行高不一致(IE,MOZ,C,O,S)
bug:表单元素行高对齐方式不一致
hack:给表单元素添加声明:float:left;
3、按钮元素默认大小及样式不一致
hack1: 统一大小及样式(用a标记模拟)
hack2:如果这个按钮是一个图片,直接把图片作为按钮的背景图即可。
4、鼠标指针bug
描述:cursor属性的hand属性值只有IE8浏览器识别;
hack:如统一某元素鼠标指针形状为手型,应添加声明:cursor:pointer;
5、透明属性
IE浏览器写法:filter:alpha(opacity=数值);取值范围 1-100(IE8以下)
兼容其他浏览器写法:opacity:数值;(数值的取值范围0-1,0.1,0.2,0.3-----0.9)
6、父元素里有块元素,如果给子元素添加添加margin-top,父元素会“掉”下来(高度塌陷)
hack1:给父元素添加overflow:hidden;
hack2:给子元素添加float;
hack3:给父元素加边框;
或者用其他的方法达到我们想要的效果:如给父元素加padding-top
7、双倍浮向(双倍边距)
描述:当Ie6及更低版本浏览器在解析浮动元素时,会错误地把浮向边的边界加倍显示。
hack:给浮动元素添加声明:display:inline;
8、当li里的A加display:block或float:left时,出现行高不一致,有的会多出3像素
hack1:给a加display:inline-block;
hack2:给a加display:inline;
hack3:给li加float,再加宽度
9、万能清除浮动法

父元素选择符:after{content:"."; clear:both; display:block; height:0; overflow:hidden; visibility:hidden;}

10、行内块元素之间空白缝隙的问题
hack1:利用margin 负值,例如Margin-left:-8px;
hack2:把行内块写到一行上去
hack3:给父盒子加:font-size:0;

JS中常见案例

1、event事件
通用方式

document.onclick=function(e){
    var e = e || window.event;   //兼容写法
}

2、一些“方法”的兼容性写法
停止事件传播

if(evt.stopPropagation){
    return evt.stopPropagation();    //一定不能漏下evt  方法前一定要写明对象
}else{
    return evt.cancelbuble();
}

阻止默认事件

if (e.preventDefault) {
     e.preventDefault();   //W3C标准
}else{
     e.returnValue = 'false';    //IE
}

获取第一个子节点(next,last都类似)

if (obj.lastElementChild) {
     return obj.firstElementChild;   //非IE6/7/8支持
} else{
     return obj.firstChild;   //IE6/7/8支持
};

设置监听事件

//参数一:对象
//参数二:事件类型
//参数三:事件处理函数
function addEvent(obj, type, fn){
     if (obj.addEventListener) {
          obj.addEventListener(type, fn, false);  //非IE
     } else{
          obj.attachEvent('on' + type, fn);  //IE
     }
}

3、通过className获取DOM节点

function getClassName(xxx){
     var atag = document.all ? document.all : document.getElementsByTagName('*');
     var arr = [];
     for (var i = 0; i < atag.length; i++) {
         var reg = new RegExp('\\b' + xxx + '\\b', 'g');
         if (reg.test(atag[i].className)) {
             arr.push(atag[i]);
         }
     }
     return arr;  //返回的也是数组,包含传入的class所有元素;
}

4、event.srcElement问题
IE:event对象有srcElement属性,没有target属性;
Firefox:even对象有target属性,没有srcElement属性。

srcObj = event.srcElement ? event.srcElement : event.target;

5、firefox与IE的父元素(parentElement)的区别
IE:obj.parentElement
firefox:obj.parentNode
hack:都使用obj.parentNode
6、在文档开始引用包含dom操作的js文件时,操作无效
当代码有dom操作,对于dom的操作必须在相应的dom加载完才能操作要不然$(selecter)会出会是个空的对象;
hack:含有dom操作的代码可以放到文档末尾,或者使用jquery.ready函数

移动端常见案例

1、部分情况下对非可点击元素如(label,span)监听click事件时,ios下不会触发
hack:css中增加cursor:pointer
2、底部输入框被键盘遮挡问题

var oheight = $(document).height(); //浏览器当前的高度
$(window).resize(function(){
     if($(document).height() < oheight){
          $("#footer").css("position", "static");
     }else{
          $("#footer").css("position", "absolute");
     }
});

3、CSS动画页面闪白,动画卡顿

//使用综合属性
-webkit-transform: translate3d(0, 0, 0);
-moz-transform: translate3d(0, 0, 0);
-ms-transform: translate3d(0, 0, 0);
transform: translate3d(0, 0, 0);

4、阻止旋转屏幕时自动调整字体大小

html, body, form, fieldset, p, div, h1, h2, h3, h4, h5, h6 {-webkit-text-size-adjust:none;}

5、预加载、自动播放无效
自动播放的有效性受操作系统、浏览器(webview)、版本等的影响,苹果官方规定必须由用户手动触发才会载入音频,所以可以在用户依次输入后,让音频实现预加载:

document.addEventListener('touchstart', function () {
     document.getElementsByTagName('audio')[0].play();
     document.getElementsByTagName('audio')[0].pause();
});

6、ios safari时间显示问题
设置new Date日期格式的时候,在ios中的safari中发现显示效果与其他浏览器不一致。
只识别:new Date("year/month/day");
7、移动端300ms延迟。
hack1:一般在移动端用tap事件来取代click事件
hack2:fastclick可以解决在手机上点击事件的300ms延迟
8、手机上的flex布局时会有兼容性问题

.box{
    display: -webkit-box;  //老版本语法: Safari, iOS, Android browser, older WebKit browsers. 
    display: -moz-box;     //老版本语法: Firefox (buggy) 
    display: -ms-flexbox;  //混合版本语法: IE 10 
    display: -webkit-flex; //新版本语法: Chrome 21+ 
    display: flex;         //新版本语法: Opera 12.1, Firefox 22+ 
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,496评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,407评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,632评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,180评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,198评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,165评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,052评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,910评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,324评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,542评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,711评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,424评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,017评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,668评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,823评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,722评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,611评论 2 353

推荐阅读更多精彩内容