大前端基础

 一、清浮动的方法

```html

清除浮动的方法

        1.给浮动元素的父级盒子设置一个固定的高度

          优缺点:不够灵活,适用于高度固定的布局中

        2.为浮动元素的父级盒子设置浮动

          优缺点:会产生新的浮动问题

        3.为浮动元素的父盒子添加overflow属性;overflow的属性值可以为hidden,scroll,auto

          优缺点:可能会隐藏内容或触发不需要的滚动条;代码简洁

        4.在浮动元素之后,与浮动元素呈并列关系的位置,加一个不浮动块元素(空的div标签(div本身不浮动,没有尺寸)),在空的div标签上加上属性:clear:both;

          优缺点:代码冗余,通俗易懂,书写方便

            clear: left; 清除左侧浮动带来的影响

            clear: right;清除右侧浮动带来的影响

            clear: both;清除两侧浮动带来的影响

        5.推荐方式:用伪元素清除浮动,给浮动元素的父级盒加类名.clearfix,并在.clearfix中添加样式:

       

           .clearfix::after{

                 content:'';

                 display:block;

                 clear:both;

            }

            优缺点:不会再结构上产生冗余代码,可以重复使用,结构语义化正确

```

1)什么是伪元素

用css语言创造出来的标签

伪元素创造的标签是行级标签

2)如何创建伪元素

- element::before{ content:"伪元素的文本内容"; 属性名: 属性值; }

  element元素内部,内容之前,添加“伪元素的文本内容”

- element::after{ content:"伪元素的文本内容"; 属性名: 属性值; }

  element元素内部,内容之后,添加“伪元素


 

## 浮动特性应用实例

### 应用实例—图文绕排

- 总结:浮动脱离文档流不脱离文本流

- 最初只用于在成块的文本内浮动图像为图片和文字之间的对齐方式是基线对齐  要想图文环绕 需要给图片设置浮动

```html

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>Document</title>

    <style>

        .box{

            width: 500px;

            height: 500px;

            border:1px solid #333

        }

        img{

            float: left;

        }

    </style>

</head>

<body>

    <div class="box">

        <img src="./images/pic_4.jpg" alt="">

      我是图片的介绍我是图片的介绍我是图片的介绍我是图片的介绍我是图片的介绍我是图片的介绍我是图片的介绍我是图片的介绍我是图片的介绍我是图介

    </div>

</body>

</html>

```

### 应用实例—两列自适应

- 实现要点:单列定宽,单列自适应

- 浮动实现

  - 左边的盒子固定宽度,添加float:left

  - 右边盒子宽度自适应, 添加margin-left:左盒子宽度。

```html

<!DOCTYPE html>

<html lang="en">

<head>

    <meta charset="UTF-8">

    <meta http-equiv="X-UA-Compatible" content="IE=edge">

    <meta name="viewport" content="width=device-width, initial-scale=1.0">

    <title>Document</title>

    <style>

        .box{

            border: 1px solid #333;

        }

        .left{

            width: 300px;

            height: 300px;

            background: red;

            float: left;

        }

        .right{

            height:350px ;

            background: yellow;

            margin-left: 300px;

        }

    </style>

</head>

<body>

     <div class="box">

         <div class="left"></div>

         <div class="right"> 我是文本内容</div>

     </div>

</body>

</html>

```


 

# 二、CSS 精灵(雪碧图、精灵图)

学习目标

- 能够说出什么是CSS精灵

- 掌握CSS精灵在实际示案例中的应用

### 概述

css精灵英文叫法 css sprites,通常被解释为“CSS 图像拼合”或“CSS 贴图定位”;其实就

是把网页中一些背景图片整合到一张图片文件中,再利用 CSS “background-image”,

“background- repeat”,“background-position”的组合进行背景定位,background-position 精确的定位出背景图片的位置

### 精灵图的原理

- 将页面中的背景图合并成一张图片

- 利用背景属性,使不同元素显示图片的不同部分

### 实现步骤:

1.测量图片大小

2.通过引入背景图片,用背景定位实现

## 2、css sprites的优缺点

* 优点:

1.减少网页的http请求,提高页面的性能

2.减少在图片上的命名困扰

3.更换网页风格方便

* 缺点:

1.必须要限定容器的大小

2.背景图位置需要计算

## 3、适用场景

适用于一般小图片(如小图标,小背景),不适合大背景大布局背景。

# 三、滑动门

### 概述:

 css精灵图可以实现特殊形状的背景自由拉伸滑动,能适应不同字数的内容

### 实例预览

https://weixin.qq.com/

### 实现要点

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

```html

滑动门实现:

        a  span

            a用来撑开左边的小括号

            span用来撑开右边的小括号

            给a设置padding-left: 让文字距离左边有点距离,美观

            给span设置padding-right 让文字距离右边有点距离,美观

            实际文字写在span里面,span的宽度由文字和内边距撑开

            a的宽度是由span撑开了

```

```html

<!DOCTYPE html>

<html lang="en">

<head>

  <meta charset="UTF-8">

  <meta http-equiv="X-UA-Compatible" content="IE=edge">

  <meta name="viewport" content="width=device-width, initial-scale=1.0">

  <title>Document</title>

  <style>

    * {

      margin: 0;

      padding: 0;

      list-style: none;

    }

    a {

      text-decoration: none;

      color: #fff;

    }

    .wrap {

      height: 74px;

      background: url(../img/css滑动.jpg) repeat-x;

    }

    .wrap ul {

      height: 74px;

      line-height: 74px;

      padding-left: 200px;

      box-sizing: border-box;

    }

    .wrap ul li {

      float: left;

      margin-right: 20px;

    }

    /* a用来撑开左边的小括号 */

    .wrap ul li a {

      height: 33px;

      line-height: 33px;

      display: inline-block;

      background: url(../img/hua.png) no-repeat 0% 0%;

      padding-left: 15px;

    }

    /* span用来撑开右边的小括号 */

    .wrap ul li span {

      height: 33px;

      line-height: 33px;

      display: inline-block;

      background: url(../img/hua.png) no-repeat 100% 100%;

      padding-right: 15px;

    }

    .wrap ul li:hover a {

      /* background: url(../img/hua.png) no-repeat 0% 0%; */

    }

    .wrap ul li:hover span {

      /* background: url(../img/hua.png) no-repeat 100% 100%; */

    }

  </style>

</head>

<body>

  <div class="wrap">

    <ul>

      <!-- 实际文字写在span里面,

            span的宽度由文字和内边距撑开

            a的宽度是由span撑开了 -->

      <li>

        <!-- a用来撑开左边的小括号 -->

        <a href="#">

          <!--    span用来撑开右边的小括号 -->

          <span>首页</span>

        </a>

      </li>

      <li>

        <a href="#"><span>帮助与反馈</span></a>

      </li>

      <li>

        <a href="#"><span>公众与平台</span></a>

      </li>

      <li>

        <a href="#"><span>开发平台</span></a>

      </li>

      <li>

        <a href="#"><span>微信支付</span></a>

      </li>

    </ul>

  </div>

</body>

</html>

```

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值