CSS第二天

2.1什么是元素显示模式

HTML元素一般分为块元素行内元素。块元素独占一行,行内元素一行可以放好多个。

2.2块元素

常见的块元素有h1\div,ol,li等。

特点:

  • 比较霸道、自己独占一行
  • 高度、宽度、内外边距都可以控制(样式设置)
  • 宽度默认是容器的容器的100%
  • 是个容器及盒子,里面可以放行或者块级元素。

注意:

  • 文字类的元素不能使用块级元素
  • <p>标签主要存放文字,所以p标签不能存放块级元素,特别是不能放div
  • 同理,<h1-6>等都是文字类块级标签,里面也不能存放其它块级元素。
2.2行内元素

常见的行内元素span、em、i、strong、b、del、a

特点:

  • 相邻的行内元素在一行,一行可以放多个。
  • 宽度和高度直接设置是无效的
  • 默认宽度就是本身内容的元素
  • 行内元素只能容纳文本或其他行内元素。

注意:

  • 链接里面不不能再放其他链接了
  • 特殊情况链接标签里可以放块级元素,但是给<a>转换一下块级模式最安全。
2.3 行内块元素

<img>、<input/>、<td>

特点:

  • 和相邻行内元素在一行上、但是他们之间有空白缝隙、一行可以显示多个。
  • 默认宽度就是它本身内容的宽度
  • 高度、行高、内外边距都可以设置。
2.4元素显示模式总结

2.5 元素显示模式转化

特殊情况下,需要元素模式的转化,也就是一个模式的元素需要另外一种模式的特性。

比如想要增加链接a的触发范围

    <style>
        a {
            width: 150px;
            height: 190px;
            /* 把行内元素a转换为块级元素 */
            display: block;
        }

        div {
            /* 把块级元素转换为行内元素 */
            display: inline;
        }

        input {
            /* 把行内元素转换为行内块元素 */
            width: 130px;
            height: 70px;
            display: inline-block;
        }
    </style>
2.6 单行文字垂直居中的代码

解决方案:文字的行高等于盒子的高度。line-height = height

3 css背景

backgroud-color定义背景颜色

默认值是transparent(透明颜色)、

3.2背景图片

backgroud-image属性描述了元素的背景元素,实际中一些logo和背景。

参数是none或者url(这里填写图片的地址)

div {
            background-image: url(images/logo.png);
    }
3.3 背景平铺 

background-repeat:no-repeat | repeat |repeat-x | repeat-y

背景图片不设置就默认平铺

背景图片和插入的图片区别在于前者可以平铺整个盒子,并且控制他的位置非常方便。

3.4 背景图片的位置(重要)

1、参数可以是方位名词

        div {
            /* background-position: 方位名词; */
            background-position: center top;
            /* 如果是方位名词跟顺序没有关系,效果一致 */
            background-position: right center;
            /* 此时图片水平方向靠右侧对齐,第二个参数y轴方向是垂直居中显示的 */
            background-position: right;
            /* 此时图片y轴方向靠上侧对齐,第二个参数x轴方向是水平居中显示的  */
            background-position: top;
        }

如果要设置超大的背景图片时候,直接给body设置style。

   body {
            background-image: url(image/bg.png);
            background-position: center top;
            background-repeat: no-repeat;
        }

2、参数是精确坐标,严格按照x,y值赋值。

如果只写了一个参数,那么认为只给x坐标赋值,另一个默认垂直居中,原点为左上角。

3、参数是混合单位

当两者混用的时候,顺序也是严格按照x y。

3.5 背景固定(背景附着)

background-attachment属性设置背景图像是否固定或者随着页面的其余部分滚动。

        body {
            background-image: url(image/bg.png);
            background-position: center top;
            background-repeat: no-repeat;
            /* 背景图片固定不动,不随内容滚动而滚动 */
            background-attachment: fixed;
            /* 背景图片随页面的滚动而滚动 */
            background-attachment: scroll;
        }
3.6 背景属性复合写法

在实际开发中更推荐此种写法,他们之间的顺序没有要求

 background: transparent url(image/bg.png) no-repeat  fixed top ;

3.7 背景颜色半透明

background: rgba(0,0,0,1)

  • 最后一个参数alpha代表透明度,取值范围在0-1之间。数值越小越透明。
总结

案案例

 

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .nav a {
            display: inline-block;
            width: 138px;
            height: 29px;
            text-align: center;
            line-height: 29px;
            color: #ffff;
            text-decoration: none;
        }

        .nav .bg1 {
            background: url(images/1.png) no-repeat;
        }

        .nav .bg1:hover {
            background-image: url(images/2.png);
        }

        .nav .bg2 {
            background: url(images/2.png) no-repeat;
        }

        .nav .bg3 {
            background: url(images/3.png) no-repeat;
        }

        .nav .bg4 {
            background: url(images/4.png) no-repeat;
        }
    </style>
</head>

<body>
    <div class="nav">
        <a href="#" class="bg1">五彩导航</a>
        <a href="#" class="bg2">五彩导航</a>
        <a href="#" class="bg3">五彩导航</a>
        <a href="#" class="bg4">五彩导航</a>
    </div>
</body>

</html>

  • 12
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值