IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 前端css class嵌套/选择器总结(目的:识别less文件中嵌套的写法) -> 正文阅读

[JavaScript知识库]前端css class嵌套/选择器总结(目的:识别less文件中嵌套的写法)

1 问题

  • 写前端代码,css调半天,最后还被前端无情地推倒重写,最后人家写的还看不懂

2 css基础整理

  • 任意一种class都有效
.classA,.classB{
}
<div class="classA"></div>
<div class="classB"></div>
  • 同时拥有两个class才有效
.classA.classB{
 }
<div class="classA classB"></div>
  • classA元素内部所有声明了classB的元素都有效(空格隔开)
.classA .classB{
}
<div class="classA">
	<div class="classB"></div>
	<div>
		<div class="classB"></div>
    </div>
</div>
  • classA内部第一层声明了classB的所有元素有效
.classA > .classB {
}
<div class="classA">
	<div class="classB">有效</div>
	<div>
		<div class="classB">无效</div>
    </div>
    <div class="classB">有效</div>
</div>
  • 标签的对应组
/*所有<div>,<p>都生效*/
div,p{
}
/*<div>内部的所有<p>都生效*/
div p{
}
/*<div>内部第一层<p>生效*/
div > p{
}

3 class与标签的混合

  • 基本混合
/*声明了classA的所有<div>*/
div.classA {
}
/*声明了classA的元素,内部的所有<div>有效*/
.classA div{
}
  • 逗号、空格、小于号(<), 意义是一样的,无论两边是class还是html元素

4 注意事项

  • 同等效果的class,优先级取决于css文件的加载顺序,而不是元素class=""中的声明顺序
.classB{
	color:red;
}
.classA{
	color:green;
}
<div class="classA classB">文字是绿色</div>

5 摆脱css被覆盖的两小技巧

目前很多前端组件框架的样式,让人很难更改,尤其是加载在最后的css文件,会让自定义css被覆盖,一般分两种情况

目标元素可加class

  • 元素添加自定义classB
  • copy出实际生效的classA
  • css文件中粘贴实际生效的classA,然后加上自定义classB, 这样你的优先极更高,即使classA在最后加载
.classA.classB{
}
<div class="classB">框架自动会加上classA</div>

目标元素不可加class

这种情况一般是框架组件自动生成多层元素,自定义的class加不进去
思路:从父级元素入手,最上层的元素肯定是可以加自定义class的,实在不行,大不了直接套一层div. 然后利用层级关系达到设置的目的

  • 父级div声明classA
  • 按照层级直接设置
.classA div>p>span{
    color:purple;
}
.classC{
    color:red;
}
<div class="classA">
    <div>
        <p><span class="classC">text</span></p>
    </div>
</div>

注 :nth-child(num) 可以指定第几个子元素

6 less文件写法的规则

  • 通过 { } 隔开,最终生成css文件是通过空格连接
.classA{
	div{
	}
}
/*等效于*/
.classA div{
}
  • less的&:nth-child写法
.classA {
	div {
      &:nth-child(1){
      
      }
	}
}
/*等效于*/
.classA div:nth-child(1){
}
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-04-06 16:08:57  更:2022-04-06 16:11:06 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 20:59:21-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码