CSS高级技巧浏览器
在CSS中有三个显示和隐藏的单词比较常见,咱们要区分开,他们分别是 display visibility 和 overflow。服务器
他们的主要目的是让一个元素在页面中消失,可是不在文档源码中删除。 最多见的是网站广告,当咱们点击相似关闭不见了,可是咱们从新刷新页面,它们又会出现和你玩躲猫猫!!微信
display 设置或检索对象是否及如何显示。布局
display : none 隐藏对象 与它相反的是 display:block 除了转换为块级元素以外,同时还有显示元素的意思。网站
特色: 隐藏以后,再也不保留位置。spa
设置或检索是否显示对象。指针
visible : 对象可视orm
hidden : 对象隐藏对象
特色: 隐藏以后,继续保留原有位置。(停职留薪)blog
检索或设置当对象的内容超过其指定高度及宽度时如何管理内容。
visible : 不剪切内容也不添加滚动条。
auto : 超出自动显示滚动条,不超出不显示滚动条
hidden : 不显示超过对象尺寸的内容,超出的部分隐藏掉
scroll : 无论超出内容否,老是显示滚动条
所谓的界面样式, 就是更改一些用户操做样式, 好比 更改用户的鼠标样式, 表单轮廓等。可是好比滚动条的样式改动受到了不少浏览器的抵制,所以咱们就放弃了。 防止表单域拖拽
设置或检索在对象上移动的鼠标指针采用何种系统预约义的光标形状。
cursor : default 小白 | pointer 小手 | move 移动 | text 文本
鼠标放我身上查看效果哦:
<ul>
<li style="cursor:default">我是小白</li>
<li style="cursor:pointer">我是小手</li>
<li style="cursor:move">我是移动</li>
<li style="cursor:text">我是文本</li>
</ul>
尽可能不要用hand 由于 火狐不支持 pointer ie6以上都支持的尽可能用
是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的做用。
outline : outline-color ||outline-style || outline-width
可是咱们都不关心能够设置多少,咱们平时都是去掉的。
最直接的写法是 : outline: 0; 或者 outline: none;
<input type="text" style="outline: 0;"/>
resize:none 这个单词能够防止 火狐 谷歌等浏览器随意的拖动 文本域。
右下角能够拖拽:
<textarea></textarea>
右下角不能够拖拽:
<textarea style="resize: none;"></textarea>
之前咱们讲过让带有宽度的块级元素居中对齐,是margin: 0 auto;
之前咱们还讲过让文字居中对齐,是 text-align: center;
可是咱们历来没有讲过有垂直居中的属性, 咱们的妈妈一直很担忧咱们的垂直居中怎么作。
vertical-align 垂直对齐, 这个看上去很美好的一个属性, 实际有着不可捉摸的脾气,不然咱们也不会这么晚来说解。
vertical-align : baseline |top |middle |bottom
设置或检索对象内容的垂直对其方式。
vertical-align 不影响块级元素中的内容对齐,它只针对于 行内元素或者行内块元素,特别是行内块元素, **一般用来控制图片/表单与文字的对齐**。
因此咱们知道,咱们能够经过vertical-align 控制图片和文字的垂直关系了。 默认的图片会和文字基线对齐。
去除图片底侧空白缝隙
有个很重要特性你要记住: 图片或者表单等行内块元素,他的底线会和父级盒子的基线对齐。这样会形成一个问题,就是图片底侧会有一个空白缝隙。
解决的方法就是:
4.1.1: 给img vertical-align:middle | top等等。 让图片不要和基线对齐。<img src="media/1633.png" width="500" style="border: 1px dashed #ccc;" />
4.1.2: 给img 添加 display:block; 转换为块级元素就不会存在问题了。<img src="media/sina1.png" width="500" style="border: 1px dashed #ccc;"/>
white-space设置或检索对象内文本显示方式。一般咱们使用于强制一行显示内容
normal : 默认处理方式
nowrap : 强制在同一行内显示全部文本,直到文本结束或者遭遇br标签对象才换行。
能够处理中文
text-overflow : clip | ellipsis
设置或检索是否使用一个省略标记(...)标示对象内文本的溢出
clip : 不显示省略标记(...),而是简单的裁切
ellipsis : 当对象内文本溢出时显示省略标记(...)
当用户访问一个网站时,须要向服务器发送请求,网页上的每张图像都要通过一次请求才能展示给用户。
然而,一个网页中每每会应用不少小的背景图像做为修饰,当网页中的图像过多时,服务器就会频繁地接受和发送请求,这将大大下降页面的加载速度。为了有效地减小服务器接受和发送请求的次数,提升页面的加载速度,出现了CSS精灵技术(也称CSS Sprites、CSS雪碧)。
简单地说,CSS精灵是一种处理网页背景图像的方式。它将一个页面涉及到的全部零星背景图像都集中到一张大图中去,而后将大图应用于网页,这样,当用户访问该页面时,只需向服务发送一次请求,网页中的背景图像便可所有展现出来。一般状况下,这个由不少小的背景图像合成的大图被称为精灵图(雪碧图),以下图所示为京东网站中的一个精灵图。
CSS 精灵实际上是将网页中的一些背景图像整合到一张大图中(精灵图),然而,各个网页元素一般只须要精灵图中不一样位置的某个小图,要想精肯定位到精灵图中的某个小图,就须要使用CSS的background-image、background-repeat和background-position属性进行背景定位,其中最关键的是使用background-position属性精确地定位。
CSS 精灵实际上是将网页中的一些背景图像整合到一张大图中(精灵图),那咱们要作的,就是把小图拼合成一张大图上
大部分状况下,精灵图都是网页美工作。
咱们精灵图上放的都是小的装饰性质的背景图片。 插入图片不能往上放。
咱们精灵图的宽度取决于最宽的那个背景。
咱们能够横向摆放也能够纵向摆放,可是每一个图片之间,间隔至少隔开偶数像素合适。
在咱们精灵图的最低端,留一片空隙,方便咱们之后添加其余精灵图。
结束语: 小公司,背景图片不多的状况,没有必要使用精灵技术,维护成本过高。
若是是背景图片比较多,能够建议使用精灵技术。
先来体会下现实中的滑动门,或者你能够叫作推拉门:
制做网页时,为了美观,经常须要为网页元素设置特殊形状的背景,好比微信导航栏,有凸起和凹下去的感受,最大的问题是里面的字数不同多,咋办?
为了使各类特殊形状的背景可以自适应元素中文本内容的多少,出现了CSS滑动门技术。它重新的角度构建页面,使各类特殊形状的背景可以自由拉伸滑动,以适应元素内部的文本内容,可用性更强。 最多见于各类导航栏的滑动门。
核心技术就是利用CSS精灵(主要是背景位置)和盒子padding撑开宽度, 以便能适应不一样字数的导航栏。
通常的经典布局都是这样的:
<li>
<a href="#">
<span>导航栏内容</span>
</a>
</li>
总结:
1. a 设置 背景左侧,padding撑开合适宽度。
2. span 设置背景右侧, padding撑开合适宽度 剩下由文字继续撑开宽度。
3. 之因此a包含span就是由于 整个导航都是能够点击的。
实践