CSS学习笔记10—CSS高级技巧

目标

  • 理解
    • 能说出元素显示隐藏最常见的写法
    • 能说出精灵图产生的目的
    • 能说出去除图片底侧空白缝隙的方法
  • 应用
    • 能写出最常见的鼠标样式
    • 能使用精灵图技术

1. 元素的显示与隐藏

  • 目的

    让一个元素在页面中消失或者显示出来

  • 场景

    类似网站广告,当我们点击关闭就不见了,但是我们重新刷新页面,会重新出现!

1.1 display 显示(重点)

  • display:设置或检索对象是否显示,以及如何显示。
  display: none; /*隐藏对象*/
  display: block; /*除了转换为块级元素之外,同时还有显示元素的意思。*/
  • 特点: 隐藏之后,不再保留原位置。

    实际开发场景

配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单, 应用极为广泛。

1.2 visibility 可见性 (了解)

  • visbility:设置或检索是否显示对象。
visibility: visible;  /*对象可视*/
visibility: hidden;   /*对象隐藏*/
  • 特点: 隐藏之后,继续保留原有位置。
    在这里插入图片描述

1.3 overflow 溢出(重点)

  • overflow:检索或设置当对象的内容超过其指定高度及宽度时如何管理内容。
属性值描述
visible不剪切内容也不添加滚动条
hidden不显示超过对象尺寸的内容,超出的部分隐藏掉
scroll不管超出内容否,总是显示滚动条
auto超出自动显示滚动条,不超出不显示滚动条

在这里插入图片描述
实际开发场景

  • 清除浮动
  • 隐藏超出内容,隐藏掉, 不允许内容超过父盒子。

1.4 显示与隐藏总结

属性区别用途
display隐藏对象,不保留位置配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单, 应用极为广泛
visibility隐藏对象,保留位置使用较少
overflow只是隐藏超出大小的部分1. 可以清除浮动 2. 保证盒子里面的内容不会超出该盒子范围

2. CSS用户界面样式

所谓的界面样式, 就是更改一些用户操作样式,以便提高更好的用户体验。例如:

  • 更改用户的鼠标样式 (滚动条因为兼容性非常差,通常很少改变)
  • 表单轮廓等。
  • 防止表单域拖拽

2.1 鼠标样式cursor

  • cursor:设置或检索在对象上移动的鼠标指针采用何种系统预定义的光标形状。
属性值描述
default小白 默认
pointer小手
move移动
text文本
not-allowed禁止

案例

鼠标放选项上查看效果。

<ul>
  <li style="cursor:default">我是小白</li>
  <li style="cursor:pointer">我是小手</li>
  <li style="cursor:move">我是移动</li>
  <li style="cursor:text">我是文本</li>
  <li style="cursor:not-allowed">我是文本</li>
</ul>

2.2 轮廓线 outline

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

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

使用场景

使用outline去掉轮廓线: outline: 0; 或者 outline: none;

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

2.3 防止拖拽文本域resize


使用场景

防止文本域右下角可以拖拽:

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

2.4 用户界面样式总结

属性用途用途
鼠标样式更改鼠标样式cursor样式很多,重点记住 pointer
轮廓线表单默认outlineoutline 轮廓线,我们一般直接去掉,border是边框,我们会经常用
防止拖拽主要针对文本域resize防止用户随意拖拽文本域,造成页面布局混乱,我们resize:none

3. vertical-align 垂直对齐

  • 有宽度的块级元素居中对齐,是margin: 0 auto;
  • 文字居中对齐,是 text-align: center;
  • 行内元素或者行内块元素垂直居中要使用vertical-align
    在这里插入图片描述
vertical-align : baseline |top |middle |bottom /*基线|顶线|中线|底线*/

注意

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

3.1 图片、表单和文字对齐

可以通过vertical-align 控制图片和文字的垂直关系。 默认的图片会和文字基线对齐。
在这里插入图片描述

3.2 去除图片底侧空白缝隙

在这里插入图片描述
原因

  • 图片或者表单等行内块元素,他的底线会和父级盒子的基线对齐。就是图片底侧会有一个空白缝隙。

解决方法

  • 给img的vertical-align设置为middle | top| bottom。 让图片不要和基线对齐。
    在这里插入图片描述
  • 给img 添加 display:block; 转换为块级元素就不会存在问题了。
    在这里插入图片描述

4. 溢出的文字省略号显示

4.1 white-space

  • white-space设置或检索对象内文本显示方式。通常使用来强制一行显示内容 。
white-space:normal; /*默认处理方式*/
white-space:nowrap; /*强制在同一行内显示所有文本,直到文本结束或者遭遇br标签对象才换行。*/

4.2 text-overflow 文字溢出

  • 设置或检索是否使用一个省略标记(…)标示对象内文本的溢出
text-overflow : clip; /*不显示省略标记(...),而是简单的裁切*/ 
text-overflow:ellipsis; /*当对象内文本溢出时显示省略标记(...)*/

在这里插入图片描述
注意

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

4.3 总结三步曲

  /*1. 先强制一行内显示文本*/
      white-space: nowrap;
  /*2. 超出的部分隐藏*/
      overflow: hidden;
  /*3. 文字用省略号替代超出的部分*/
      text-overflow: ellipsis;

5. CSS精灵技术(sprite) 重点

5.1 为什么需要精灵技术


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

然而,一个网页中往往会应用很多小的背景图像作为修饰,当网页中的图像过多时,服务器就会频繁地接受和发送请求,这将大大降低页面的加载速度。

为了有效地减少服务器接受和发送请求的次数,提高页面的加载速度,出现了CSS精灵技术(也称CSS Sprites、CSS雪碧)。

5.2 精灵技术

CSS 精灵其实是将网页中的一些背景图像整合到一张大图中(精灵图),然而,各个网页元素通常只需要精灵图中不同位置的某个小图,要想精确定位到精灵图中的某个小图。
在这里插入图片描述
这样,当用户访问该页面时,只需向服务发送一次请求,网页中的背景图像即可全部展示出来。

需要使用的CSS属性有:

  • background-image
  • background-repeat
  • background-position

其中最关键的是使用background-position 属性精确地定位。

5.3 精灵技术使用的核心总结

css精灵技术主要针对于背景图片,插入的图片img 是不需要这个技术的。

  1. 精确测量,每个小背景图片的大小和位置。
  2. 给盒子指定小背景图片时, 背景定位基本都是 负值。

5.4 制作精灵图(了解)

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

  • 大部分情况下,精灵图都是网页美工做。
  • 精灵图上放的都是小的装饰性质的背景图片。 插入图片不能往上放。
  • 可以横向摆放也可以纵向摆放,但是每个图片之间留有适当的空隙
  • 在精灵图的最底端,留一片空隙,方便以后添加其他精灵图。

小公司、背景图片很少的情况,没有必要使用精灵技术,维护成本太高。 如果是背景图片比较多,可以建议使用精灵技术。

6. 拓展@

6.1 margin负值之美

负边距+定位:水平垂直居中

前面讲过, 一个绝对定位的盒子, 利用 父级盒子的 50%, 然后 往左(上) 走自己宽度的一半 ,可以实现盒子水平垂直居中。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

少儿编程乔老师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值