目录

前言

理论

CSS高级技巧

一:元素的显示与隐藏

在CSS中有三个显示和隐藏的单词比较常见,我们要区分开,他们分别是 display visibility 和 overflow。

他们的主要目的是让一个元素在页面中消失,但是不在文档源码中删除。 最常见的是网站广告,当我们点击类似关闭不见了,但是我们重新刷新页面,它们又会出现和你玩躲猫猫!!

1:display 显示

display 设置或检索对象是否及如何显示。

display : none 隐藏对象 与它相反的是 display:block 除了转换为块级元素之外,同时还有显示元素的意思。

特点: 隐藏之后,不再保留位置。

2: visibility 可见性

设置或检索是否显示对象。

visible :  对象可视

hidden :  对象隐藏

特点: 隐藏之后,继续保留原有位置。(停职留薪)

3:overflow 溢出

检索或设置当对象的内容超过其指定高度及宽度时如何管理内容。

visible :  不剪切内容也不添加滚动条。

auto :   超出自动显示滚动条,不超出不显示滚动条

hidden :  不显示超过对象尺寸的内容,超出的部分隐藏掉

scroll :  不管超出内容否,总是显示滚动条

二:CSS用户界面样式

所谓的界面样式, 就是更改一些用户操作样式, 比如 更改用户的鼠标样式, 表单轮廓等。但是比如滚动条的样式改动受到了很多浏览器的抵制,因此我们就放弃了。 防止表单域拖拽

1:鼠标样式cursor

设置或检索在对象上移动的鼠标指针采用何种系统预定义的光标形状。

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以上都支持的尽量用

2: 轮廓 outline

是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。

outline : outline-color ||outline-style || outline-width

但是我们都不关心可以设置多少,我们平时都是去掉的。

最直接的写法是 :  outline: 0;   或者  outline: none;

<input  type="text"  style="outline: 0;"/>

3: 防止拖拽文本域resize

resize:none    这个单词可以防止 火狐 谷歌等浏览器随意的拖动 文本域。

右下角可以拖拽:

<textarea></textarea>

右下角不可以拖拽:

<textarea  style="resize: none;"></textarea>

4:vertical-align 垂直对齐

以前我们讲过让带有宽度的块级元素居中对齐,是margin: 0 auto;

以前我们还讲过让文字居中对齐,是 text-align: center;

但是我们从来没有讲过有垂直居中的属性, 我们的妈妈一直很担心我们的垂直居中怎么做。

vertical-align 垂直对齐, 这个看上去很美好的一个属性, 实际有着不可捉摸的脾气,否则我们也不会这么晚来讲解。

vertical-align : baseline |top |middle |bottom

设置或检索对象内容的垂直对其方式。

vertical-align 不影响块级元素中的内容对齐,它只针对于 行内元素或者行内块元素,特别是行内块元素, **通常用来控制图片/表单与文字的对齐**。

4.1:图片、表单和文字对齐

所以我们知道,我们可以通过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;"/>

五: 溢出的文字隐藏

5.1: white-space

white-space设置或检索对象内文本显示方式。通常我们使用于强制一行显示内容

normal :  默认处理方式

nowrap :  强制在同一行内显示所有文本,直到文本结束或者遭遇br标签对象才换行。

可以处理中文

5.2: text-overflow 文字溢出

text-overflow : clip | ellipsis

设置或检索是否使用一个省略标记(...)标示对象内文本的溢出

clip :  不显示省略标记(...),而是简单的裁切

ellipsis :  当对象内文本溢出时显示省略标记(...)

5.3:注意一定要首先强制一行内显示,再次和overflow属性  搭配使用

六:精灵技术产生的背景

当用户访问一个网站时,需要向服务器发送请求,网页上的每张图像都要经过一次请求才能展现给用户。

然而,一个网页中往往会应用很多小的背景图像作为修饰,当网页中的图像过多时,服务器就会频繁地接受和发送请求,这将大大降低页面的加载速度。为了有效地减少服务器接受和发送请求的次数,提高页面的加载速度,出现了CSS精灵技术(也称CSS Sprites、CSS雪碧)。

6.1: 精灵技术本质

简单地说,CSS精灵是一种处理网页背景图像的方式。它将一个页面涉及到的所有零星背景图像都集中到一张大图中去,然后将大图应用于网页,这样,当用户访问该页面时,只需向服务发送一次请求,网页中的背景图像即可全部展示出来。通常情况下,这个由很多小的背景图像合成的大图被称为精灵图(雪碧图),如下图所示为京东网站中的一个精灵图。

6.2: 精灵技术的使用

CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),然而,各个网页元素通常只需要精灵图中不同位置的某个小图,要想精确定位到精灵图中的某个小图,就需要使用CSS的background-image、background-repeat和background-position属性进行背景定位,其中最关键的是使用background-position属性精确地定位。

6.3: 制作精灵图

CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),那我们要做的,就是把小图拼合成一张大图上

大部分情况下,精灵图都是网页美工做。

我们精灵图上放的都是小的装饰性质的背景图片。 插入图片不能往上放。

我们精灵图的宽度取决于最宽的那个背景。

我们可以横向摆放也可以纵向摆放,但是每个图片之间,间隔至少隔开偶数像素合适。

在我们精灵图的最低端,留一片空隙,方便我们以后添加其他精灵图。

结束语:   小公司,背景图片很少的情况,没有必要使用精灵技术,维护成本太高。

如果是背景图片比较多,可以建议使用精灵技术。

七:滑动门

先来体会下现实中的滑动门,或者你可以叫做推拉门:

7.1:  滑动门出现的背景

制作网页时,为了美观,常常需要为网页元素设置特殊形状的背景,比如微信导航栏,有凸起和凹下去的感觉,最大的问题是里面的字数不一样多,咋办?

为了使各种特殊形状的背景能够自适应元素中文本内容的多少,出现了CSS滑动门技术。它从新的角度构建页面,使各种特殊形状的背景能够自由拉伸滑动,以适应元素内部的文本内容,可用性更强。 最常见于各种导航栏的滑动门。

7.2:  核心技术

核心技术就是利用CSS精灵(主要是背景位置)和盒子padding撑开宽度, 以便能适应不同字数的导航栏。

一般的经典布局都是这样的:

<li>

<a href="#">

<span>导航栏内容</span>

</a>

</li>

总结:

1. a 设置 背景左侧,padding撑开合适宽度。

2. span 设置背景右侧, padding撑开合适宽度 剩下由文字继续撑开宽度。

3. 之所以a包含span就是因为 整个导航都是可以点击的。

实践

最新文章

  1. css flex布局
  2. 配置python环境变量(转)
  3. 基于Hadoop生态技术构建阿里搜索离线系统
  4. 深搜+DP剪枝 codevs 1047 邮票面值设计
  5. WCF 客户端解决大数据量传输配置
  6. eclipse-统计代码行数
  7. [杂]SQL Server 之命名管道连接
  8. 现代程序设计 homework-08
  9. Microsoft 收购 Apiphany
  10. Java核心编程快速学习
  11. jmeter接口测试-文件下载
  12. gentoo freemind 安装设置
  13. Hadoop生态圈-CDH与HUE使用案例
  14. 【剑指offer】调整数组数字位置
  15. AndroidUI设计 之 图片浏览器
  16. oracle 11g完美卸载
  17. 超全面的JavaWeb笔记day20&lt;监听器&amp;国际化&gt;
  18. 使用 某款基于Socks5协议的代理软件 一段时间后 被封锁掉IP的一些技术思考
  19. 679. 24 Game
  20. WebGl 旋转(矩阵变换)

热门文章

  1. MUI-页面传参数
  2. Jesus Is Here[递推]2015沈阳online
  3. Python——面向对象编程
  4. 【sybase】You can’t run SELECT INTO in this database的解决办法
  5. 利用canvas绘制带干扰线的验证码
  6. CodeForces-768B-Code For 1+DFS类似线段树思想
  7. CodeForces 601B Lipshitz Sequence
  8. 美团2018年CodeM大赛-资格赛 分数 暴力模拟
  9. hdu 1671 Phone List 字典树模板
  10. 9道JavaScript字符串类面试题