1.!important拥有最高的优先级,几乎所有浏览器都支持!important,除了IE6(不完全支持)

例1(IE6支持,颜色为#e00):

.cssClass{color:#e00!important;}
.cssClass{color:#000;}

例2(IE6不支持,颜色为#000):

.cssClass{color:#e00!important; color:#000} 
 

2.display:inline-block应用此特性的元素呈现为内联对象,四周元素保持在同一行,但可以设置宽度和高度等块元素的属性

并不是所有浏览器都支持此属性

在低版本IE中对元素使用display:inline-block,行级元素不会有任何问题,但块级元素则不然...

对于行级元素,解决办法:

.cssClass{display:inline-block; zoom:;...}

对于块级元素,要想在IE6、IE7中达到inline-block的效果,解决办法:

.cssClass{display:inline-block; zoom:; *display:inline;...}
 

3.绝对定位时,层与层之间的叠盖问题

有以下代码:

<div id="block1"><div id="block3">A</div></div>
<div id="block2"><div id="block4">B</div></div>

<style type="text/css">
#block1{background:#f0c; border:1px dashed #000; position:absolute; left:0px; top:0px; width:100px; height:100px; z-index:2;}
#block2{background:#fc4; border:1px dashed #000; position:absolute; left:120px; top:0px; width:100px; height:100px; z-index:3;}
#block3{background:#c7f; border:1px dashed #000; position:absolute; left:60px; top:0px; width:50px; height:50px; z-index:10;}
#block4{background:#f00; border:1px dashed #000; position:absolute; left:-20px; top:0px; width:50px; height:50px; z-index:1;}
</style>

结果是z-index只有1的block4挡住了block3,也能挡住block1,原因是受到其父元素block2的影响(z-index值大于block1)

同理,block3不能挡住block2,原因是受到其父元素block1的影响(z-index值小于block2)

绝对定位的定位基准是最近的被定位的父级元素(该元素的定位可以是 absolute 或 relative ),若没有就一直往上一级直到body。而相对定位的定位基准则是他本身在固定定位时的所处位置。

 

4.经典的屏幕宽度自适应的左中右三列布局(左右列宽度固定,中间列宽度自适应)

解决方案1:

<div id="head">头部(3列布局,左右两栏宽度固定,中间栏自适应宽度)</div>
<div id="content">
<div id="left">左栏固定宽度为200px</div>
<div id="right">右栏固定宽度为200px</div>
<div id="center">中间自适应宽度</div>
</div>
<!--注意这里,中间3列的div的顺序不是"左中右",而"左右中",中间一列写在最后-->
<div id="foot">底部</div>

<style type="text/css">
#head{margin-bottom:10px;}
#content{overflow:hidden;}
#left{float:left; width:200px;}
#center{margin:0 210px;}
#right{float:right; width:200px;}
#foot{margin-top:10px; clear:both;}
div{background-color:#eee; border:dotted 1px #000;}
</style>

当然,在最外层添加一个宽度固定,居中的层,就可以定义页面整体的最大宽度了。

这种布局方式最大的缺点是中间块的内容宽度不能太大,若果大于“屏幕横向分辨率-左右两块宽度之和”,那中间列就“下沉”了

 

解决方案2:

<div class="main">
<div class="head">head</div>
<div class="wrap">
<div class="content">content</div>
<div class="left">left</div>
<div class="right">right</div>
<div class="clear"></div>
</div>
<div class="foot">foot</div>
</div>

<style type="text/css">
.main{width:auto; margin:0 auto; text-align:center;}
.head{height:150px; line-height:150px; background:#F00;}
.wrap{padding:0 300px 0 200px; overflow:hidden;}
.content{float:left; width:100%; height:300px; background:#0F0;}
.left,.right{position:relative; _display:inline; height:300px;}
.left{width:200px; float:left; margin-left:-100%; right:200px; _right:-300px; background:#00F;}
.right{width:300px; float:right; margin-right:-300px; background:#FF0;}
.clear{clear:both; height:0px; line-height:0px; overflow:hidden;}
.foot{height:150px; line-height:150px; background:#0FF;}
</style>

这个方案代码比方案1代码复杂了不少,但这方案是目前所知的最好、最经典的解决方案

 

5.怎样使一张大小不定的图片在容器里水平且垂直居中显示

解决方案1:

<div class="box">
<img src="data:images/icons.png" alt="11"/>
<span></span>
</div>

<style type="text/css">
.box{width:600px;height:600px;border:1px solid #000; text-align:center;}
span{display:inline-block;height:100%;vertical-align:middle;}
img{ vertical-align:middle;}
</style>

解决方案2:

<div>
<p><img src="logo.gif" /></p>
</div>

<style type="text/css">
div{
width:500px;
height:500px;
border:1px solid #ccc;
overflow:hidden;
position:relative;
display:table-cell;
text-align:center;
vertical-align:middle;
}
div p{
position:static;
+position:absolute;
top:50%;
}
img{
position:static;
+position:relative;
top:-50%;
left:-50%;
width:276px;
height:110px;
}
</style>

DIV+CSS常见面试题的更多相关文章

  1. 【javascript常见面试题】常见前端面试题及答案

    转自:http://www.cnblogs.com/syfwhu/p/4434132.html 前言 本文是在GitHub上看到一个大牛总结的前端常见面试题,很多问题问的都很好,很经典.很有代表性.上 ...

  2. Vue常见面试题汇总

    Vue框架常见面试题   1.active-class是哪个组件的属性?嵌套路由怎么定义? 答:vue-router模块的router-link组件. 2.怎么定义vue-router的动态路由?怎么 ...

  3. Web开发的常见面试题HTML和HTML5等

    作为一名前端开发人员,HTML,HTML5以及网站优化都是必须掌握的技术,下面列举一下HTML, HTML5, 网站优化等常见的面试题: HTML常见面试题: 1. 什么是Semantic HTML( ...

  4. java常见面试题及答案 1-10(基础篇)

    java常见面试题及答案 1.什么是Java虚拟机?为什么Java被称作是"平台无关的编程语言"? Java 虚拟机是一个可以执行 Java 字节码的虚拟机进程.Java 源文件被 ...

  5. 常见面试题之ListView的复用及如何优化

    经常有人问我,作为刚毕业的要去面试,关于安卓开发的问题,技术面试官会经常问哪些问题呢?我想来想去不能一股脑的全写出来,我准备把这些问题单独拿出来写,并详细的分析一下,这样对于初学者是最有帮助的.这次的 ...

  6. iOS常见面试题汇总

    iOS常见面试题汇总 1. 什么是 ARC? (ARC 是为了解决什么问题而诞生的?) ARC 是 Automatic Reference Counting 的缩写, 即自动引用计数. 这是苹果在 i ...

  7. JDBC常见面试题

    以下我是归纳的JDBC知识点图: 图上的知识点都可以在我其他的文章内找到相应内容. JDBC常见面试题 JDBC操作数据库的步骤 ? JDBC操作数据库的步骤 ? 注册数据库驱动. 建立数据库连接. ...

  8. Mybatis常见面试题

    Mybatis常见面试题 #{}和${}的区别是什么? #{}和${}的区别是什么? 在Mybatis中,有两种占位符 #{}解析传递进来的参数数据 ${}对传递进来的参数原样拼接在SQL中 #{}是 ...

  9. JavaSE:数据类型之间的转换(附常见面试题)

    数据类型之间的转换 分为以下几种情况: 1)低级到高级的自动类型转换: 2)高级到低级的强制类型转换(会导致溢出或丢失精度): 3)基本类型向类类型转换: 4)基本类型向字符串的转换: 5)类类型向字 ...

随机推荐

  1. Python 数据分析—第九章 数据聚合与分组运算

    打算从后往前来做笔记 第九章 数据聚合与分组运算 分组 #生成数据,五行四列 df = pd.DataFrame({'key1':['a','a','b','b','a'], 'key2':['one ...

  2. Mysql自动设置时间(自动获取时间,填充时间)

    应用场景: 1.在数据表中,要记录每条数据是什么时候创建的,不需要应用程序去特意记录,而由数据数据库获取当前时间自动记录创建时间: 2.在数据库中,要记录每条数据是什么时候修改的,不需要应用程序去特意 ...

  3. Inno Setup 通用脚本及简要说明( 一般情况够用了)

    ;以下脚本主要完成创建开始菜单和桌面的快捷方式,目录安装. #define MyAppName "我的软件名" #define MyAppVersion "1.0&quo ...

  4. C#设计模式系列:代理模式(Proxy Pattren)

    一.引言 在软件开发过程中,有些对象有时候会由于网络或者其他的障碍,以至于不能够或者不能直接访问到这些对象,如果直接访问对象给系统带来不必要的复杂性,这时候可以在客户端和目标对象之间增加一层中间层,让 ...

  5. ZKEACMS 自定义表单的使用

    ZKEACMS Core 2.2 已经发布了,其中主要添加了自定义表单的功能.使用自定义表单的功能,您可以在几分钟内就创建一个表单,并用它来收集一些信息.导出收集的信息,就可以做一些统计分析. 创建表 ...

  6. “全栈2019”Java第七十八章:内部类可以继承其他类吗?

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  7. luoguP3702 [SDOI2017]序列计数

    https://www.luogu.org/problemnew/show/P3702 题目让我们在 $ [1, m] $ 从中选出 $ n $ 个数,当中要有 > $ 0 $ 个质数,和是 $ ...

  8. 使用beautifulsoup和pyquery爬小说

    # -*- coding:UTF-8 -*- from bs4 import BeautifulSoup #BeautifulSoup就是处理字符串的工具 import requests, sys & ...

  9. ubuntu下搭建Discuz

      环境:我用桥接方式创建了一个ubuntu16的虚拟机,ip为192.168.0.220   1.安装mysql sudo apt-get install mysql-server mysql-cl ...

  10. Java - 多线程与锁

    进程-线程 进程,Process,处于运行中的程序,系统进行资源分配和调度的独立单位,拥有独立的内存空间(堆). 动态性:生命周期和状态: 独立性:独立实体: 并发性:Concurrency,抢占式多 ...