css高级选择器&盒模型

1.组合选择器
  • 群组选择器

    1. /* 每个选择器为可以为三种基础选择器的任意一个,用逗号隔开,控制多个*/
    2. div,.div,#div{
    3. color:red
    4. }
  • 后代(子代)选择器

    1. /*后代选择器:用空格将父级和子级连接*/
    2. .sup .sub{
    3. color:red
    4. }
    5. /*子代选择器:用 > 将父级和子级连接,即父级 > 子级*/
    6. .sup > .sub{
    7. color:red
    8. }
    1. 1.子代选择器是(一级嵌套关系)
    2. 2.后代选择器(一级或者多级嵌套关系)
  • 兄弟(相邻)选择器

    1. /*兄弟选择器:用~连接*/
    2. .up ~ .down{
    3. color:red
    4. }
    5. /*相邻选择器:用+连接*/
    6. .up + .down{
    7. color:red
    8. }
    1. 1.相邻选择器必须为直接相邻关系(必须挨着)
    2. 2.兄弟选择器可以为直接或者间接相邻关系(必须是同一级,可以相邻,也可以相间)
  • 交集选择器

    1. <div class="ss" id="dd"></div>
    2. div.ss.#dd{
    3. color:red
    4. }
2.复杂选择器的优先等级
  1. 1.与修饰符位置无关
  2. 2.属性选择器与类选择器的优先级相同
  3. 3.优先级大前提: id选择器 无限大于 类选择器[属性选择器] 无限大于 标签选择器
  4. 4.优先级权重:
  5. if id个数多,则优先级高,else 判断类选择器个数
  6. if 类选择器个数多,则优先级高,else 判断标签选择器个数
  7. if 标签选择器个数多,则优先级高,else 个数和类型均相同则由位置决定
3.伪类标签选择器
  • a标签四大伪类选择器

    1. /*悬浮: 鼠标悬浮到链接上,链接显示红色*/
    2. a:hover{color:red}
    3. /*访问时: 访问链接时,链接显示为绿色*/
    4. a:active{color:green}
    5. /*未访问: 未访问链接时,链接为蓝色*/
    6. a:link{color:blue}
    7. /*已访问状态: 访问过链接后,链接为黑色 注意浏览器会有记录*/
    8. a:visiter{color:black}
  • 索引伪类选择器

    1. /*位置优先: 每层结构中第一取出来,再匹配标签是否是section*/
    2. section:nth-child(3)
    3. /*类型优先: 每层结构中先取出标签为section,然后在取出的section中匹配位置第一的*/
    4. section:nth-of-type(1)
    1. 1. 位置: 最后一个为last-child()
    2. 2. 类型: 最后一个为last-of-type()
  • 取反伪类选择器

    1. /*先确定对谁取反,然后加上not*/
    2. :not(nth-child(2))
4.盒模型
  1. # 什么是盒模型?
  2. 通配选择器能够控制的页面标签都是盒模型(一般我们操作的都是块级标签)
  3. # 盒模型由什么作用?
  4. 页面书写的标签初始状态级别都不能满足显示要求,需要再次再次修改,修改的就是盒模型的各个属性。
  5. # 盒模型组成部分?
  6. content(内容) + padding (内边框) + border (外边框) + margin(边距)
  • content(内容)

    1. 1.通过设置 width height 来规定content
    2. 2.块级标签可以设置自身宽高,默认宽为父级宽(width=auto),高为0,高度可以由内容决定
    3. 3.内联标签不可以设置自身宽高,默认宽高均为0,宽高一定由内容决定
    4. 4.是子标签或子内容的显示区域
    1. # 1.参与盒子显示,颜色为background-color
  • padding (内边框)

    1. # padding 组成:
    2. padding-top|right|bottom|left
    1. # 1.参与盒子显示,颜色为背景色
  • border (外边)

    1. # border 组成
    2. 1.border-width
    3. border-top|right|tobbom|left-width
    4. 2.border-color
    5. border-top|right|tobbom|left-color
    6. 3.border-style
    7. border-top|right|tobbom|left-style
    1. # 1.border: 参与盒子显示,颜色由自己定义(transparent 为透明)
  • margin (边距)

    1. # margin 组成
    2. margin-top|right|bottom|left
    1. # 1.没有颜色,不参与盒子显示,决定何止布局(位置信息)
  • margin坑一:父子联动

    1. 当上下移动子box时,父级的box也会跟着移动
    1. /*解决方法:固定父级box的dorder或者padding*/
    2. .sup{
    3. border-top:1px solid transparent
    4. }
    5. /*解决方法二*/
    6. .sup{
    7. padding-top:1px ;
    8. }
  • margin坑二:上兄弟margin-bottom与下兄弟margin-top重合

    1. 解决方法:只设置一个,建议设置下兄弟的margin-top

css高级选择器&盒模型的更多相关文章

  1. Python-ccs高级选择器 盒模型

    css高级选择器与盒模型 脱离文档流 ,其中就是产生了BFC 1.组合选择器 - 群组选择器 /* 每个选择器位可以位三种基础选择器的任意一个, 用逗号隔开, 控制多个 */ div, #div, . ...

  2. web开发: css高级与盒模型

    一.组合选择器 二.复制选择器优先级 三.伪类选择器 四.盒模型 五.盒模型显示区域 六.盒模型布局 一.组合选择器 <!DOCTYPE html> <html> <he ...

  3. 浅谈css中的盒模型(框模型)

    css中的盒模型是css的基础,盒模型的理解可以帮助我们进行对样式进行修改.废话不多说,进入正题: 在w3c中,CSS 框模型 (Box Model) 规定了元素框处理元素内容.内边框.边框 和 外边 ...

  4. 李洪强和你一起学习前端之(6)css行高,盒模型,外边距

    李洪强和你一起学习前端之(6)css行高,盒模型,外边距 复习昨天的知识 1.1css书写位置: 内嵌式写法 外联式写法 <link href = "1.css" rel = ...

  5. 87.CSS Flex 弹性盒模型布局教程(共用的css在48篇文章gird)

    CSS Flex 弹性盒模型布局教程 Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性. flex布局就是给任何一个容器添加 dis ...

  6. day40 css高级选择器

    一.高级选择器 高级选择器分为:后代选择器.子代选择器.并集选择器.交集选择器 后代选择器 使用空格表示后代选择器.顾名思义,父元素的后代(包括儿子,孙子,重孙子) .container p{ col ...

  7. (4)《Head First HTML与CSS》学习笔记---文本的CSS规则和盒模型;div与span;<a>元素的链接色;伪类

    1.每个font-family包含一组共同特征的字体.共五个字体系列: sans-serif----这个系列包括了没有衬线的字体,与serif相比,通常认为这个系列更容易在计算机上识读. serif- ...

  8. 一分钟让你明白CSS中的盒模型

    想必初学者对CSS盒模型总是很困惑吧.下面一分钟让你彻底明白盒模型: <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" &q ...

  9. CSS学习笔记——盒模型,块级元素和行内元素的区别和特性

    今天本来打算根据自己的计划进行前端自动化的学习的,无奈早上接到一个任务需求需要新增一个页面.自从因为工作需要转前端之后,自己的主要注意力几 乎都放在JavaScript上面了,对CSS和HTML这方面 ...

随机推荐

  1. Hibernate 再接触 HQL

    Category.java package com.bjsxt.hibernate; import javax.persistence.Entity; import javax.persistence ...

  2. Linux简单学习

    参考自:http://www.runoob.com/linux/linux-tutorial.html  一.是什么 Linux 类Unix操作系统.是一个基于POSIX和UNIX的多用户.多任务.支 ...

  3. EOS踩坑记 2

    [EOS踩坑记 2] 1.--contracts-console 在开发模式下,需要将 nodeos 添加此选项. 2.Debug Method The main method used to deb ...

  4. 如何强制停止http请求

    http请求很多时候会受到网络阻塞.重连等原因导致响应很慢,如果此时做了一些操作,但过几秒后又响应了之前的请求,就会造成很多问题,此时我们可以使用abort()方法强制停止http请求: let aj ...

  5. hdoj3709(数位dp)

    题目链接:https://vjudge.net/problem/HDU-3709 题意:求出[l,r]中的平衡数,平衡数即存在一个中心点使得两边的力矩和相等. 思路:首先需要知道一个数最多只有一个中心 ...

  6. Python SMTP发送邮件

    import smtplibfrom email.mime.text import MIMEText  # 引入smtplib和MIMEText host = 'smtp.163.com'  # 设置 ...

  7. SpringBoot集成Jasypt安全框架,配置文件内容加密

    我们在SpringBoot项目中的yml或者properties配置文件中都是明文的,相对而言安全性就低了很多.都知道配置文件中的都是一些数据库连接用户名密码啊.一些第三方密钥等信息.所以我们谨慎点, ...

  8. python 2与python3 区别

    源码区别 python3:python2 a) py3 优美简单清晰. b) py2:源码重复,混乱,不规范,冗(rong)余(不需要特多,啰嗦). test a)    py3:可以中文也可以英文( ...

  9. ABP Quartz 作业调度第三篇

    1.第一步安装Abp.Quartz ,把他安装到核心层 核心模块添加对quarz的依赖, 领域层创建firstjob类 public class FirstJob : JobBase, ITransi ...

  10. springmvc为什么是线程不安全的

    1.因为springmvc默认是单例的,所以会有线程安全的问题,如果存在全局变量,因为全局变量是存在方法区的,而局部变量是放在栈中的,方法区是所有线程公用的,而每个线程都有属于自己的栈.所以如果使用单 ...