CSS非布局样式和重点内容

CSS基础非布局样式

  • Cascading Style Sheet 层叠 、样式、表
    可以简单理解为PS中图层的样式和叠加

选择器

selecter{
	prop:value;
}

选择器用于匹配HTML元素,有不同的匹配规则,多个选择器可以叠加


解析方式和性能
浏览器的解析方式是从右往左的

body div .class{
	color:red;
}
//浏览器先查询.class,再查询对应元素是否在div元素中再去查找是否在body元素中

选择器的分类

在这里插入图片描述

选择器的权重

名称 权重(不能进位)
important max
行间样式 1000
id 100
class | 属性 | 伪类 10
标签 | 伪元素 1
通配符 0

字体分类

  • serif
  • sans-serif
  • monispace
  • cuisive
  • fantasy

这块对于设计出身的小伙伴来说非常好理解。需要注意的地方就是在设置font-family的时候指定字体组是不要引号的

多字体fallback机制,一个个往下找,没有就找同类的,再没有就有啥用啥。┑( ̄Д  ̄)┍
fallback机制是直接面对文字的,而不是某个元素

.chinese{
            font-family: "PingFang SC", "Microsoft Yahei", monospace;
        }

引入自定义字体

        @font-face {
            font-family: "IF";
            src: url("./IndieFlower.ttf");//引用远程字体需要对方允许跨域或者在头部使用link到对方指定的css
        }
        .custom-font{
            font-family: IF;
        }

iconfont:可以理解为做成字体的矢量图标


行和行高

  • 行高的构成
  • 行高的相关现象和方案
  • 行高的调整

相关的知识点

行内元素的行高会撑起外部block,不会引起内部的变化 。

行内元素高度和字体大小有关系和line-height没有关系。

同一块级元素内的行内元素默认是以基线对齐的(所有内联元素包括img都受其影响)
可以通过vertical-align修改对齐方式(基线 中线 顶线 底线)
vertical-align:0px;这样写的话是以基线为基础的,正值是向上偏移


背景

  • 单色背景
  • 渐变色背景
  • 多背景叠加
  • 背景图片和属性(雪碧图)
  • base64
  • 多分辨率适配

单色背景的写法

        .class{
        	height:90px;
            background:rgba(255,0,0, .3); 
            background:hsla(360,50%,80%,0.5)
            background:white
        }

渐变色背景

        .class2{
            height:90px;
            background: -webkit-linear-gradient(left, red, green);/* 由左到右 */
            background: linear-gradient(to right, red, green);/* 由左到右,标准写法 */
            background: linear-gradient(180deg, red, green); /* 0deg是从下到上,顺时针旋转*/
            background: linear-gradient(135deg, red 0, green 10%, yellow 50%, blue 100%);/* 参照PS渐变,百分比写的是位置*/
            background: linear-gradient(135deg, transparent 0, transparent 49.5%, green 49.5%, green 50.5%, transparent 50.5%, transparent 100%),
                		linear-gradient(45deg, transparent 0, transparent 49.5%, red 49.5%, red 50.5%, transparent 50.5%, transparent 100%);
            background-size: 30px 30px;/* 规定单个背景的大小*/
        }

background属性和雪碧图

background-repeat:no-repeat; //禁止平铺; repeat-x /repeat-y
background-position:center center //也可以指定左上边距
background-size: 30px 30px;
width:20px;
height:20px;
background:url(./test_bg.png) no-repeat;
background-position: -17px -5px;//相对于容器而非背景图
background-size: 30px 30px;
//通过修改位置和大小来定位需要的区域

适应高清屏需要缩小图片来增加dpi


base64 图片

background:red url();
background-repeat: no-repeat;

图片转换成base64 体积会增大大约1/3
有传输优势,但是会增加浏览器的负载,适用于小图
生产环境中一般交给打包框架来做


边框

  • 线形 大小 颜色
  • 边框背景图
  • 边框衔接(默认斜切)//画三角?23333
/*基础使用方式*/
border: 1px solid red; 
border:5px solid red; 
border:5px dotted red; 
border:5px dashed red;
border-radius:2px;

/*边框背景图(九宫格、中间可复用)*/
width:400px;
height: 200px;
/* border-width: 30px; */
border:30px solid transparent;
border-image:url(./border.png) 30 round;  //round repeat 

滚动

  • 滚动行为和滚动条

在这里插入图片描述


文字折行

  • overflow-wrap (word-wrap) 通用换行控制
  • word-break 针对多字节文字 单词是否换行(中文句子也是单词)
  • white-space 空白处是否断行
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>warp</title>
    <style>
        .c1{
            border: 1px solid;
            width: 8em;
            overflow-wrap: normal;
            word-break: normal;
            white-space: normal;
        }

    </style>
</head>
<body>
    <div class="c1">
        This is a long and Supercalifragilisticexpialidocious sentence. 一二三四五六,七八九零一二,这是一句巨长巨长又没有空间可以换行的句子哦。
    </div>
</body>
</html>

装饰性属性

  • 字重 font-weight
  • 斜体 font-style:itatic
  • 下划线 text-decoration
  • 指针 cursor
<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>fonts</title>
    <style>
        .weight{
            font-weight: normal;/*400*/
            font-weight: bold;/*700*/
            font-weight: bolder;
            font-weight: lighter;
            font-weight: 200;
        }
    </style>
</head>
<body class="body" id="body">
    <div class="weight">你好 Hello World</div>
</body>
</html>

CSS HACK(比较过时)

主要用于兼容性
是一种不合法但生效的写法,主要用于区分不同浏览器
缺点,难理解、难维护、易失效
替代方案:特性检测,针对性加class

body{
	width:180px;
	width:160px\9;
}

在这里插入图片描述


**CSS 自定义checkbox**

图片自己替换

 <!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>checkbox</title>
    <style>
        .checkbox{

        }
        .checkbox input{
            display: none;
        }
        .checkbox input + label{
            background:url(./checkbox1.png) left center no-repeat;
            background-size:20px 20px;
            padding-left:20px;
        }
        .checkbox input:checked + label{
            background-image:url(./checkbox2.png);
        }
    </style>
</head>
<body>
    <div class="checkbox">
        <input type="checkbox" id="handsome"/>
        <label for="handsome">我很帅</label>
    </div>
</body>
</html>

猜你喜欢

转载自blog.csdn.net/weixin_43590947/article/details/84035003
今日推荐