CSS3选择器新增问题的实现


Posted in HTML / CSS onJanuary 21, 2021

基本选择器扩展

1.子元素选择器

:tomato: #wrap > .inner {color: pink;} 也可称为直接后代选择器,此类选择器只能匹配到直接后代,不能匹配到深层次的后代元素 总结:>作用于元素的第一代后代,空格作用于元素的所有后代

2. 相邻兄弟选择器

:tomato: #wrap #first + .inner {color: #f00;}它只会匹配紧跟着的兄弟元素

3. 通用兄弟选择器

:tomato: #wrap #first ~ div { border: 1px solid;}它会匹配第二个元素,条件是它必须跟(不一定是紧跟)在第一个元素之后,且他们都有一个共同的父元素所有的兄弟元素

4. 选择器分组

:tomato: h1,h2,h3{color: pink;} 此处的逗号我们称之为结合符

属性选择器

1. 子串值属性选择器

:tomato: [attr|=val] : 选择attr属性的值是val(包括val)或以val-开头的元素。

:tomato: [attr^=val] : 选择attr属性的值以val开头(包括val)的元素。

:tomato: [attr$=val] : 选择attr属性的值以val结尾(包括val)的元素。

:tomato: [attr*=val] : 选择attr属性的值中包含字符串val的元素 少数浏览器支持子串选择元素

2. 存在和值属性选择器

:tomato: [attr]:该选择器选择包含 attr 属性的所有元素,不论 attr 的值为何。[attr=val]:该选择器仅选择 attr 属性被赋值为 val 的所有元素。

:tomato: [attr~=val]:表示带有以 attr 命名的属性的元素,并且该属性是一个以空格作为分隔的值列表,其中至少一个值为val。 比如位于被空格分隔的多个类(class)中的一个类。比如name="atguigu_llc atguigu"

:tomato: [name =val]:该选择器仅选择 name 属性被赋值为 val 的所有元素。

伪类与伪元素选择器

1. 链接伪类

:tomato: :link 表示作为超链接,并指向一个未访问的地址的所有锚

:tomato: :visited 表示作为超链接,并指向一个已访问的地址的所有锚

:tomato: :target 代表一个特殊的元素,它的id是URI的片段标识符

:exclamation: 注意:link,:visited,:target是作用于链接元素的!前两者只能在a标签上起作用

*{
                margin: 0;
                padding: 0;
            }
            div{
                width: 300px;
                height: 200px;
                line-height: 200px;
                background: palegreen;
                color: hotpink;
                text-align: center;
                display: none;
            }
            a:visited{
                color:orange;
            }
            :target{
                display: block;
            }

2. 动态伪类

:tomato: :hover表示悬浮到元素上

:tomato: :active表示匹配被用户激活的元素(点击按住时)

:tomato:由于a标签的:link和:visited可以覆盖了所有a标签的状态,所以当:link,:visited,:hover,:active同时出现在a标签身上时 :link和:visited不能放在最后!!!

:tomato: 隐私与:visited选择器只有下列的属性才能被应用到已访问链接:color、background-color、border-color

:exclamation: 注意:hover,:active基本可以作用于所有的元素!

<style type="text/css">
            *{
                margin: 0;
                padding: 0;
            }
            a{
                text-decoration: none;
                color: black;
                display: block;
            }
            a:hover{
                font-size:24px;
                /*color: red;*/
            }
            
            a:link{
                font-size:48px;
                /*color: pink;*/
            }
            a:visited{
                /*font-size:96px;*/
                /*color: deeppink;*/    
            }
        </style>

3. 表单相关伪类

①:disable 匹配被禁用的表单

②:checked 匹配被选中的表单

③:focus 匹配获焦的表单

④:enabled匹配可编辑的表单

实操练习1

<head>
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        input:enabled{
            background: skyblue;
        }
        input:disabled{
            background: deeppink;
        }
        input:checked{
            width: 200px;
            height: 200px;
        }
        input:focus{
            background: pink;
        }
    </style>
</head>
<body>
    <input type="text"  />
    <input type="text"  disabled="disabled" />
    <input type="checkbox"  />
    <input type="text"  />
</body>

实操练习2 自定义单选按钮

<head>
    <meta charset="UTF-8">
    <title></title>
    <style type="text/css">
        *{
            margin: 0;
            padding:0;
        }
        label{
            position: relative;
            float:left; /*转换为块级元素撑开大小*/
            width:100px;
            height:100px;
            border:2px solid;
            border-radius: 50%;
            overflow:hidden;
        }
        label > span{
            position: absolute;
            left:0;
            top:0;
            bottom:0;
            right:0;
        }
        input{
            position: absolute;
            left:-50px;
            top:-50px;
        }
        input:checked + span{
            background:pink;
        }
    </style>
</head>
<body>
    <label>
        <input type="radio" name="rongtuowulian" />
        <span></span>
    </label>
    <label>
        <input type="radio" name="rongtuowulian" />
        <span></span>
    </label>
    <label>
        <input type="radio" name="rongtuowulian" />
        <span></span>
    </label>
</body>

CSS3选择器新增问题的实现

4. 伪元素

:tomato: 概念:伪元素表示页面中一些特殊的并不真实存在的元素(特殊的位置)

:tomato: 语法使用 ::开头

:tomato: 类别:①::first-letter ②::first-line ③::selection ④::before ⑤::after 注意:④和⑤必须结合content属性来使用

:tomato: 代码示例:

<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></title>
    <style type="text/css">
    p:first-letter{
        color: #008000;
        font-size: 2.5rem;
    }
    p:first-line{
        color: aqua;
    }
    p::selection{
        color:red;
    }
    p:before{
        content: ''I will love you forever';
        color:blue;
    }
    p:after{
        content: 'sure are you';
        color:green;
    }
    </style>
</head>
<body>
    <div>Hello are you okay</div>
    <p> 我还是一个段落 我是一个很多很多解放碑还不错保持经济刺激
    哈哈哈啊哈哈哈哈哈哈哈哈哈哈哈哈啊哈哈哈哈哈哈哈哈哈哈哈
    </p>
</body>

5. 结构性伪类(重点)

:tomato: index的值从1开始计数!!!!index可以为变量n(只能是n)index可以为even odd

:tomato: #wrap ele:nth-child(index)表示匹配#wrap中第index的子元素,这些伪类都是根据所有的子元素进行排序,这个子元素必须是ele

:tomato: #wrap ele:nth-of-type(index)表示匹配#wrap中第index的ele子元素

除此之外:nth-child和:nth-of-type有一个很重要的区别!!nth-of-type以元素为中心,在同一类型中排序,nth-child (相对于:first-child:last-child 或者 :nth-child(1):nth-last-child(1))

/* even表示偶数

odd表示奇数

first-of-type:在p类型中排

first-child:所有元素排

*/

:tomato::nth-child(index)系列

:first-child

:last-child

:nth-last-child(index)

:tomato::nth-of-type(index)系列

:first-of-type
:last-of-type
:nth-last-type(index)
:only-of-type(相对于:first-of-type:last-of-type
 或者 :nth-of-type(1):nth-last-of-type(1))    
:not        
:empty(内容必须是空的,有空格都不行,有attr没关系)

代码实例

*{
            margin: 0;
            padding: 0;
        }
        #wrap li:nth-of-type(1){
            color: pink;
        }
        p:only-of-type{
            border: 1px solid;
        }

6. 伪元素选择器

::after

::before

::firstLetter

::firstLine

::selection

#wrap::before{
        content:"";
        display:block;
        width:200px;
        height:200px;
        background: #00FFFF;
    }
    #wrap::after{
        content:"";
        display:block;
        width:200px;
        height:200px;
        background: #0000FF;
    }

到此这篇关于CSS3选择器新增问题的实现的文章就介绍到这了,更多相关CSS3选择器新增内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
css3实现背景模糊的三种方式
Mar 09 HTML / CSS
表单button的outline在firefox浏览器下的问题
Dec 24 HTML / CSS
css3实现超炫风车特效
Nov 12 HTML / CSS
canvas绘制表情包的示例代码
Jul 09 HTML / CSS
Html5移动端获奖无缝滚动动画实现示例
Jun 25 HTML / CSS
HTML5边玩边学(2)基础绘图实现方法
Sep 21 HTML / CSS
html5中valid、invalid、required的定义
Feb 21 HTML / CSS
浅谈html5 响应式布局
Dec 24 HTML / CSS
使用html5 canvas 画时钟代码实例分享
Nov 11 HTML / CSS
Html5大文件断点续传实现方法
Dec 05 HTML / CSS
HTML5本地存储之Web Storage详解
Jul 04 HTML / CSS
html5 canvas手势解锁源码分享
Jan 07 HTML / CSS
CSS3.0实现霓虹灯按钮动画特效的示例代码
Jan 12 #HTML / CSS
css3 实现滚动条美化效果的实例代码
Jan 06 #HTML / CSS
CSS3实现苹果手机解锁的字体闪亮效果示例
Jan 05 #HTML / CSS
使用CSS3制作版头动画效果
Dec 24 #HTML / CSS
CSS3实现红包抖动效果
Dec 23 #HTML / CSS
html5+css3之制作header实例与更新
Dec 21 #HTML / CSS
CSS3中animation实现流光按钮效果
Dec 21 #HTML / CSS
You might like
Terran热键控制
2020/03/14 星际争霸
世界收音机发展史
2021/03/01 无线电
php下几个常用的去空、分组、调试数组函数
2009/02/22 PHP
关于PHP session 存储方式的详细介绍
2013/06/25 PHP
php实现字符串首字母大写和单词首字母大写的方法
2015/03/14 PHP
WAMP环境中扩展oracle函数库(oci)
2015/06/26 PHP
ThinkPHP框架下微信支付功能总结踩坑笔记
2019/04/10 PHP
laravel与thinkphp之间的区别与优缺点
2021/03/02 PHP
js判断浏览器的比较全的代码
2007/02/13 Javascript
jQuery.holdReady()方法用法实例
2014/12/27 Javascript
jQuery使用$.get()方法从服务器文件载入数据实例
2015/03/25 Javascript
jQuery实现可兼容IE6的淡入淡出效果告警提示功能示例
2017/09/20 jQuery
VueJS事件处理器v-on的使用方法
2017/09/27 Javascript
vuejs项目打包之后的首屏加载优化及打包之后出现的问题
2018/04/01 Javascript
详解ES6中的 Set Map 数据结构学习总结
2018/11/06 Javascript
解决vue项目中页面调用数据 在数据加载完毕之前出现undefined问题
2019/11/14 Javascript
JS数组方法slice()用法实例分析
2020/01/18 Javascript
js与jquery获取input输入框中的值实例讲解
2020/02/27 jQuery
利用webpack理解CommonJS和ES Modules的差异区别
2020/06/16 Javascript
Python3实现的旋转矩阵图像算法示例
2019/04/03 Python
Django工程的分层结构详解
2019/07/18 Python
python 上下文管理器及自定义原理解析
2019/11/19 Python
python爬虫模拟浏览器的两种方法实例分析
2019/12/09 Python
Python中如何添加自定义模块
2020/06/09 Python
用pandas划分数据集实现训练集和测试集
2020/07/20 Python
python 获取剪切板内容的两种方法
2020/11/28 Python
HTML+CSS3+JS 实现的下拉菜单
2020/11/25 HTML / CSS
美国网上花店:JustFlowers
2017/02/12 全球购物
聪明的粉丝购买门票的地方:TickPick
2018/03/09 全球购物
KIKO MILANO西班牙官网:意大利领先的化妆品和护肤品品牌
2019/05/03 全球购物
美国踏板车和轻便摩托车销售网站:Mega Motor Madness
2020/02/26 全球购物
事业单位人员的自我评价范文
2014/09/21 职场文书
领导干部作风整顿个人剖析材料
2014/10/11 职场文书
2017春节晚会开幕词
2016/03/03 职场文书
在Java中Collection的一些常用方法总结
2021/06/13 Java/Android
OpenCV实现反阈值二值化
2021/11/17 Java/Android