CSS高级技巧

## 1. 元素的显示与隐藏
1.1 display 显示(重点)

- display 设置或检索对象是否及如何显示。
  display: none 隐藏对象

  display:block 除了转换为块级元素之外,同时还有显示元素的意思。
- 特点: 隐藏之后,不再保留位置。


实际开发场景: 配合后面js做特效,比如下拉菜单,原先没有,鼠标经过,显示下拉菜单, 应用极为广泛

 1.2 visibility 可见性 (了解)
- 设置或检索是否显示对象。
  visibility:visible ;  对象可视
  visibility:hidden;    对象隐藏
- 特点: 隐藏之后,继续保留原有位置。(停职留薪)
3.让元素完全透明也可以实现隐藏

1.3 overflow 溢出(重点)

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

| 属性值      | 描述                                       |
| **visible** | 不剪切内容也不添加滚动条---默认             |
| **hidden**  | 不显示超过对象尺寸的内容,超出的部分隐藏掉 |
| **scroll**  | 不管超出内容否,总是显示滚动条             |
| **auto**    | 超出自动显示滚动条,不超出不显示滚动条     |
实际开发场景:

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

1.4 显示与隐藏总结

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

- 所谓的界面样式, 就是更改一些用户操作样式,以便提高更好的用户体验。
  - 更改用户的鼠标样式 (滚动条因为兼容性非常差,我们不研究) 
  - 表单轮廓等。
  -  防止表单域拖拽

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

| 属性值          | 描述       |
| --------------- | ---------- |
| **default**     | 小白  默认 |
| **pointer**     | 小手       |
| **move**        | 移动       |
| **text**        | 文本       |
| **not-allowed** | 禁止       |
 鼠标放我身上查看效果哦:
2.2 轮廓线 outline
 是绘制于元素周围的一条线,位于边框边缘的外围,可起到突出元素的作用。 
 outline : outline-color ||outline-style || outline-width 
 但是我们都不关心可以设置多少,我们平时都是去掉的。 li  
最直接的写法是 :  outline: 0;   或者  outline: none;
 <input  type="text"  style="outline: 0;"/>

2.3 防止拖拽文本域resize
实际开发中,我们文本域右下角是不可以拖拽: 
<textarea  style="resize: none;"></textarea>

2.4 用户界面样式总结

| 属性         | 用途                 | 用途                                                         |
| ------------ | -------------------- | 
| **鼠标样式** | 更改鼠标样式cursor   | 样式很多,重点记住 pointer                                   |
| **轮廓线**   | 表单默认outline      | outline 轮廓线,我们一般直接去掉,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 src="media/1633.png"  width="500"  style="border: 1px dashed #ccc;" />
  - 给img 添加 display:block; 转换为块级元素就不会存在问题了。<img src="media/sina1.png" width="500" style="border: 1px dashed #ccc;"/>

##  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雪碧)。

我们需要使用CSS的

* background-image、
* background-repeat
* background-position属性进行背景定位,
* 其中最关键的是使用background-position 属性精确地定位。

5.3 精灵技术使用的核心总结
首先我们知道,css精灵技术主要针对于背景图片,插入的图片img 是不需要这个技术的。
1. 精确测量,每个小背景图片的大小和 位置。
2. 给盒子指定小背景图片时, 背景定位基本都是 负值。

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

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

5.6. 滑动门
先来体会下现实中的滑动门,或者你可以叫做推拉门:
###  滑动门出现的背景---使用padding实现效果
制作网页时,为了美观,常常需要为网页元素设置特殊形状的背景,比如微信导航栏,有凸起和凹下去的感觉,最大的问题是里面的字数不一样多,咋办?
为了使各种特殊形状的背景能够自适应元素中文本内容的多少,出现了CSS滑动门技术。它从新的角度构建页面,使各种特殊形状的背景能够自由拉伸滑动,以适应元素内部的文本内容,可用性更强。 最常见于各种导航栏的滑动门。

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

达达学前端

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

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

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

打赏作者

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

抵扣说明:

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

余额充值