笔试6

前端面试CSS 相关问题

  • Q:描述下 “reset” CSS 文件的作用和使用它的好处。

    A:

    • 作用以及好处:因为各个浏览器默认对CSS的渲染有差异,"reset" CSS 通过重新定义标签样式,对浏览器进行默认样式“清零”重置,样式保持一致。
    • 不足:
      • css文件大小增加;
      • 许多样式本身就需要重置,多此一举;
      • 增加浏览器对CSS 的渲染。

    可以阅读以下文章增强了解:

  • Q: 解释下浮动和它的工作原理。

    A: 浮动出现的最开始出现的意义是用来让文字环绕图片而已。float可以自动包裹元素。float会导致高度塌陷。float为什么会导致高度塌陷:元素含有浮动属性 –> 破坏inline box –> 破坏line box高度 –> 没有高度 –> 塌陷。什么时候会塌陷:当标签里面的元素只要样子没有实际高度时会塌陷。浮动会脱离文档流。产生自己的块级格式化上下文。

    可以阅读以下文章增加理解:

  • 列举不同的清除浮动的技巧,并指出它们各自适用的使用场景。

    • 直接把<div style="clear:both;"></div>放到当作最后一个子标签放到父标签那儿,此方法兼容性强,使用方便,但是浪费了一个标签,而且只能使用一次,而且有时候如果不注意中间多了个空格会产生一段空白高度。

      • 优点:通俗易懂,容易掌握;
      • 缺点:可以想象通过此方法,会添加多少无意义的空标签,有违结构与表现的分离,在后期维护中将是噩梦。
    • 如下:

      .clearfix{overflow:hidden; zoom:1;}
      

      此方法优点在于代码简洁,涵盖所有浏览器,可是对于overflow:hidden;要是里面的元素要是想来个margin负值定位或是负的绝对定位,岂不是直接被裁掉了,所以此方法是有不小的局限性的。

      • 优点:不存在结构和语义化问题,代码量极少;
      • 缺点:内容增多时候容易造成不会自动换行导致内容被隐藏掉,无法显示需要溢出的元素。
    • 如下:

      .fix{zoom:1;}
      .fix:after{
          display:block;
          content:'.';
          clear:both;
          line-height:0;
          visibility:hidden;}
      

      line-height:0写成height:0也是可以的。不会影响任何其他样式,通用性强,覆盖面广,我很推荐哦。

    • 父元素也浮动:

      • 优点:不存在结构和语义化问题,代码量极少
      • 缺点:使得与父元素相邻的元素的布局会受到影响,不可能一直浮动到body,不推荐使用

    总结:

    • 其一,通过在浮动元素的末尾添加一个空元素,设置 clear:both属性,after伪元素其实也是通过 content 在元素的后面生成了内容为一个点的块级元素;
    • 其二,通过设置父元素 overflow 或者display:table 属性来闭合浮动,这里的原理涉及到BFC,不再赘述。

    同样请参考上一题给出的参考文章进行阅读加以理解。

  • Q: 解释下 CSS sprites,以及你要如何在页面或网站中使用它。

    A: CSS Sprites就是把网页中一些小图片整合到一张图片文件中,再利用CSS的background-imagebackground- repeatbackground-position的组合进行背景定位,background-position可以用数字能精确的定位出背景图片的位置。可以减少http请求。

  • Q: 你最喜欢的图片替换方法是什么,你如何选择使用。

    A:

    • 一些图标是使用before和after伪元素;
    • 还有一些使用iconfont;
    • 使用sprite图;
    • 用背景图片代替图片。

    举个栗子:

      <h1 class="nir">[content]</h1>
    
    .nir {
       height: 100px; /* height of replacement image */
       padding: 0;
       margin: 0;
       overflow: hidden;
    }
    
    .nir:before {
         content: url(image.gif);
         display: block;
      }
    

    详细可阅读:CSS image replacement with pseudo-elements

  • Q:讨论CSS hacks,条件引用或者其他。

    A: CSS主要由三种方法:

    • 属性前缀法(即类内部Hack):例如 IE6能识别下划线"_"和星号" * ",IE7能识别星号" * ",但不能识别下划线"_",IE6~IE10都认识"\9",但firefox前述三个都不能认识。
    • 选择器前缀法(即选择器Hack):例如 IE6能识别*html .class{},IE7能识别*+html .class{}或者*:first-child+html .class{}
    • IE条件注释法(即HTML条件注释Hack):针对所有IE(注:IE10+已经不再支持条件注释): ,针对IE6及以下版本: 。这类Hack不仅对CSS生效,对写在判断语句里面的所有代码都会生效。
    <!DOCTYPE html>
    <html>
    <head>
        <title>Css Hack</title>
        <style>
        #test
        {
            width:300px;
            height:300px;
    
            background-color:blue;      /*firefox*/
            background-color:red\9;      /*all ie*/
            background-color:yellow\0;    /*ie8*/
            +background-color:pink;        /*ie7*/
            _background-color:orange;       /*ie6*/
        }
        :root #test { background-color:purple\9; }  /*ie9*/
        @media all and (min-width:0px){ #test {background-color:black\0;} }  /*opera*/
        @media screen and (-webkit-min-device-pixel-ratio:0){ #test {background-color:gray;} }  /*chrome and safari*/
        </style>
    </head>
    <body>
        <div id="test">test</div>
    </body>
    </html>
    

    想要更多的了解CSS hack 方面的知识可以参考:

  • Q: 如何为有功能限制的浏览器提供网页?

    • Q: 你会使用哪些技术和处理方法?

    A: 功能限制的浏览器,比如 IE 低版本、手机浏览器、奇葩国内浏览器,会在很多功能上不符合 Web 标准,而应对的方式有这么几种:

    • 只提供符合 Web 标准的页面;
    • 提供另一个符合那些浏览器标准的页面(例如说移动端一套css,电脑端一套css);
    • 兼容:这里有两种思路,一个是渐进增强,一个优雅降级。
      渐进增强的思路就是提供一个可用的原型,后来再为高级浏览器提供优化。优雅降级的思路是根据高级浏览器提供一个版本,然后有功能限制的浏览器只需要一个刚好能用的版本。当然,工作中的标准都是尽量满足设计,如果不能满足的话就尽量贴近,不得已(性能之类的问题)才会砍掉某个浏览器版本上的需求。

    相关技术:

    • Media Query
    • CSS hack
    • 条件判断 除IE外都可识别
  • Q: 有哪些的隐藏内容的方法(如果同时还要保证屏幕阅读器可用呢?)

    A: display:none看不见也摸不着,屏幕阅读器更会忽略其内容;而visibility:hidden虽然看得见但是摸不着,占据了一定的物理空间,屏幕阅读器也会忽略。如果想要在读屏设备中让这些内容可见。解决方案的基本思路都是将这些内容放到屏幕、视线意外的地方,或者就是将大小设置成 0。比如 text-indent: -9999em;overflow: hidden;height: 0

      .texthidden {
        display:block;/*统一转化为块级元素*/
        overflow: hidden;
        width: 0;
        height: 0;
       }
    

    更详细的方法可以参考这篇文章HIDING CONTENT FOR ACCESSIBILITY

    不过既然这是了读屏而优化的,那么可以用 media query 来完成,media speech 用于语音输出的读屏设备。

    @media speech {
        /* media-specify rules */
    }
    

    以上转自Witcher42给出的答案。

  • Q:你用过栅格系统吗?如果使用过,你最喜欢哪种?

    A:使用过bootstarp。易于上手,学习成本低,还能做出比较大方美观的页面。

    可阅读栅格系统延续美学

  • Q: 你用过媒体查询,或针对移动端的布局/CSS 吗?

    A:

      @media screen and (min-width:600px) {
        nav {
          float: left;
          width: 25%;
        }
        section {
          margin-left: 25%;
        }
      }
      @media screen and (max-width:599px) {
        nav li {
          display: inline;
        }
      }
    

    可参考:

  • Q:你熟悉 SVG 样式的书写吗?

    A:

    <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
     <circle cx="40" cy="40" r="24" style="stroke:#006600; fill:#00cc00"/>
     <text x="250" y="150" font-family="Verdana" font-size="10px" fill="blue">Hello, out there</text>
     <defs><style type="text/css"> <![CDATA[.sample{stroke:blue;fill:#0080FF;opacity:1;}]]></style></defs>
     <use xlink:href="#sample1" class="sample"/>
     </svg>
    

    教程参考: SVG教程

  • Q: 如何优化网页的打印样式?

    A:

    <link rel="stylesheet" type="text/css" media="screen" href="xxx.css" />

其中media指定的属性就是设备,显示器上就是screen,打印机则是print,电视是tv,投影仪是projection。

<link rel="stylesheet" type="text/css" media="print" href="yyy.css" />

但打印样式表也应有些注意事项:

1 打印样式表中最好不要用背景图片,因为打印机不能打印CSS中的背景。如要显示图片,请使用html插入到页面中。
2 最好不要使用像素作为单位,因为打印样式表要打印出来的会是实物,所以建议使用pt和cm。
3 隐藏掉不必要的内容。(@print div{display:none;}
4 打印样式表中最好少用浮动属性,因为它们会消失。
如果想要知道打印样式表的效果如何,直接在浏览器上选择打印预览就可以了。

  • Q: 书写高效 CSS 时会有哪些问题需要考虑?

    A:

    • 样式是:从右向左的解析一个选择器
    • ID最快,Universal最慢 有四种类型的key selector,解析速度由快到慢依次是:ID、class、tag和universal
    • 不要tag-qualify (永远不要这样做 ul#main-navigation { } ID已经是唯一的,不需要Tag来标识,这样做会让选择器变慢。)
    • 后代选择器最糟糕(换句话说,下面这个选择器是很低效的: html body ul li a { })
    • 想清楚你为什么这样写
    • CSS3的效率问题(CSS3选择器(比如 :nth-child)能够漂亮的定位我们想要的元素,又能保证我们的CSS整洁易读。但是这些神奇的选择器会浪费很多的浏览器资源。)
    • 我们知道#ID速度是最快的,那么我们都用ID,是不是很快。但是我们不应该为了效率而牺牲可读性和可维护性`

    可参考: http://blog.jobbole.com/55067/

    等我重写这道题答案。=。=

  • 使用 CSS 预处理器的优缺点有哪些?(SASS,Compass,Stylus,LESS)

    • 描述下你曾经使用过的 CSS 预处理的优缺点。
  • 如果设计中使用了非标准的字体,你该如何去实现?

    • Webfonts (字体服务例如:Google Webfonts,Typekit 等等。)
  • 解释下浏览器是如何判断元素是否匹配某个 CSS 选择器?

  • 解释一下你对盒模型的理解,以及如何在 CSS 中告诉浏览器使用不同的盒模型来渲染你的布局。

  • 请解释一下 * { box-sizing: border-box; } 的作用, 并且说明使用它有什么好处?

  • 请罗列出你所知道的 display 属性的全部值

  • 请解释一下 inline 和 inline-block 的区别?

  • 请解释一下 relative、fixed、absolute 和 static 元素的区别

  • 你目前在使用哪一套CSS框架,或者在产品线上使用过哪一套?(Bootstrap, PureCSS, Foundation 等等)

    • 如果有,请问是哪一套?如果可以,你如何改善CSS框架?
  • 请问你有使用过 CSS Flexbox 或者 Grid specs 吗?

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

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,725评论 1 92
  • 一:在制作一个Web应用或Web站点的过程中,你是如何考虑他的UI、安全性、高性能、SEO、可维护性以及技术因素的...
    Arno_z阅读 1,136评论 0 1
  • •前端面试题汇总 一、HTML和CSS 21 你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么? ...
    Simon_s阅读 2,219评论 0 8
  • 选择qi:是表达式 标签选择器 类选择器 属性选择器 继承属性: color,font,text-align,li...
    wzhiq896阅读 1,727评论 0 2
  • 什么是SVN SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS、CVS,它采用了分...
    荞叶阅读 1,397评论 0 1