CSS选择器 盒模型学习笔记 原创 阁主 2023-07-12 23:07:30 阅读 620 次 评论 0 条 摘要:好久没学前端了,打算从头快速过一遍,简单的记录一下CSS的 选择器/盒模型/常用单位 学习笔记。 ## 1. 伪类选择器 根据元素的*位置或状态*来匹配*子元素* - 结构伪类 与上下文选择器很相似 1. `:nth-child()`: 2. `:first-child`: 3. `:last-child`: 4. `:nth-last-child()` - 状态伪类 > 常用于链接,表单 1. `:hover`: 鼠标悬停 2. `:enabled`: 有效控件 3. `:disabled`: 禁用控件 4. `:checked`: 选中控件 5. `:required`: 必选控件 6. `:focus`: 焦点控件 7. `:not()`: 过滤掉某些元素 8. `:empty()`: 空 更多查询 [MDN](https://developer.mozilla.org/zh-CN/docs/Web/CSS) ## 2. 选择器权重 1. 原子选择器: tag,class,id 2. 原子选择器权重: tag(1),class(10),id(100) > 可简单理解为: 标签是个位, class 是十位, id 是百位 ## 3. 盒模型 - 一切皆"盒子" 1. 盒子是页面中可见的"矩形区域" 2. php.cn:``,`{outline:1px solid red}` - 五大属性 1. `width`: 宽 2. `height`: 高 3. `padding`: 内边距 4. `border`: 边框 5. `margin`: 外边距 - border 1. 可见属性 2. 可设置`width`,`style`,`color` - padding,margin 1. 不可见属性 2. 仅可设置: `width` 3. 大多数内置元素都有默认`padding/margin` 4. 建议全部重置为 0,以方便自定义布局 - width,height 1. 默认不包含 `padding`,`border` - box-sizing 1. `box-sizing`: 设置盒模型计算边界 2. `content-box`: 默认值,仅包括内容区 3. `border-box`: 推荐值,宽高扩展到可视边框 - 通用初始化 ```css * { margin: 0; padding: 0; box-sizing: border-box; } ``` ## 结构伪类选择器 经典的列表示例: ```html 结构伪类选择器 item1 item2 item3 item4 item5 item6 item7 item8 item9 ``` CSS部分,颜色为了避免重叠,颜色的代码后用横线-占位了,自行删除查看效果。 ```css /** * * 结构伪类与上下文选择器很像 * 1. 查询入口: 起点,可以是父级,也可是起始兄弟 * 2. 仅限子元素或同级兄弟,尽量用 '>',只有一级用空格 */ /* 任务1: 选择第1个,最后1个,任意1个,例如第4个 */ /* (1) 传统: class叠加 */ .list>.item.first { background-color: violet-; } .list>.item.last { background-color: violet-; } .list>.item.four { background-color: violet-; } /* (2) 伪类 */ /* :nth-child(an+b): 获取任意位置的元素 */ .list>.item:nth-child(1) { background-color: violet-; } .list>.item:nth-child(9) { background-color: violet-; } .list>.item:nth-child(4) { background-color: violet-; } /* 获取第1个和最后1个是高频操作,有快捷语法糖 */ /* :nth-child(1) === :first-child */ .list>.item:first-child { background-color: violet-; } /* :nth-child(9) === :last-child */ .list>.item:last-child { background-color: violet-; } /* ---------------------------- */ /* 任务2: 获取前3个 */ .list>.item:nth-child(-n + 3) { background-color: violet-; } /* 任务3: 获取导数第3个 */ .list>.item:nth-last-child(3) { background-color: violet-; } /* 任务3: 获取最后3个 */ .list>.item:nth-last-child(-n + 3) { background-color: violet-; } /* ============================== */ /* :nth-child(an+b) */ /** * :nth-child(an + b) * 1. a: 系数,[0,1,2,3,...] * 2. n: 参数, [0,1,2,3,...] * 3. b: 偏移量, 从0开始 * 规则: 计算出来的索引,必须是有效的(从1开始) */ /* (1) a = 1 */ /* .list > .item:nth-child(1n + 0) { background-color: violet; } */ /* 从第3个开始匹配到全部 */ .list>.item:nth-child(n + 3) { background-color: violet-; } /* (2) a = -1 反向,仅限前3个*/ .list>.item:nth-child(-n + 3) { background-color: violet-; } /* 再思考一个,如何要到最后3个,怎么办? */ .list>.item:nth-last-child(-n + 3) { background-color: violet-; } /* (3) a = 2 */ .list>.item:nth-child(2n) { background-color: violet-; } /* 2n = even 偶数 */ .list>.item:nth-child(even) { background-color: violet-; } /* 奇数: 2n+1, 2n-1也是一样 */ .list>.item:nth-child(2n + 1) { background-color: violet-; } /* 2n+1 = odd 奇数 */ .list>.item:nth-child(odd) { background-color: violet-; } /* (4) a >= 2 固定间隔,可用偏侈量进行微调,可正可负*/ .list>.item:nth-child(3n - 1) { background-color: violet; } ``` ## 状态伪类 经典表单示例: ![](https://www.mainblog.cn/zb_users/upload/2023/07/202307131532034574937.png) ```html 状态伪类 用户登录 呢称: 邮箱: 电话: 记住我 提交 ``` form.css代码: ```css .login { display: inline-grid; grid: auto-flow / 3em 1fr; gap: 10px 0; padding: 1em; } .login input { border: none; border-bottom: thin solid #666; } .login .title { text-align: center; } .login .submit, .login .remember { grid-column: 2; height: 2.2em; } ``` fake-status.css代码: ```css /* 状态伪类: 根据当前元素的状态来设置 */ /* 1. 获取焦点时 */ .login :focus { outline: 1px solid red; border-bottom: none; } /* 2. 所有必填项 */ .login :required { background-color: yellow; } /* 3. 复选框选中时将标签的文本描红 */ .login :checked + label { color: red; } /* 4. 鼠标悬停 */ .login > .submit:hover { cursor: pointer; background-color: seagreen; color: white; } ``` ## 选择器权重 HTML代码部分: ```html 选择器权重 狂飙之后无好人 ``` weight.css代码: ```css /* h1 { color: green; } */ /* 1,1,3: 极限了 */ html body h1#header.title { color: blue; } /* 0,0,1 */ h1 { color: yellowgreen !important; } /* 101: 1->id,0->class, 1->tag */ h1#header { color: red; } /* 1->id,0->class,0->tag */ /* 100 > 012 > 011 ... */ #header { color: red; } /* 0,0,2 > 0,0,1 */ body h1 { color: green; } /* 1->class,2->tag , 012 > 011 */ body h1.title { color: green; } /* 1->class,1->tag , 011 > 010 */ h1.title { color: red; } /* 010 > 003 */ .title { color: green; } /* 0,0,1 */ /* 只要使当前权重大于 0,0,2就可以了 */ /* h1 { color: red; } */ /* 三个tag, 权重 0,0, 3 */ /* 003 > 002 */ html body h1 { color: red; } /* 权重相同,依赖书写顺序 */ /* 只要提升权重,就可以摆脱对书写顺序的依赖 */ ``` ## 盒模型 ![](https://www.mainblog.cn/zb_users/upload/2023/07/202307131703387991387.png) HTML、CSS代码示例: ```html 盒模型 Hello item1 item2 item3 item4 item5 ``` 本文地址:https://www.mainblog.cn/319.html 版权声明:本文为原创文章,版权归 阁主 所有,欢迎分享本文,转载请保留出处! 免责申明:有些内容源于网络,没能联系到作者。如侵犯到你的权益请告知,我们会尽快删除相关内容。 PREVIOUS:HTML表单常用标签和常用属性 NEXT:CSS的常用五种定位方式 文章导航