几个常用的CSS选择器

袁志蒙 963次浏览

摘要:一、:focus-within 选择器在CSS中 :focus-within 是一个伪类选择器,它代表的是在一个元素内部获得焦点的元素。这个选择器主要用于确定当用户在某个元素内部点击或者通过键...

一、:focus-within 选择器

在CSS中 :focus-within 是一个伪类选择器,它代表的是在一个元素内部获得焦点的元素。这个选择器主要用于确定当用户在某个元素内部点击或者通过键盘导航到某个元素时,哪个元素应该获得焦点,这个选择器非常有用,尤其是在处理复杂的交互式界面时,它可以帮助你更好地控制和规划元素的焦点行为。

例如,如果你有一个大的容器元素,里面包含一些输入框或者链接等可以获得焦点的元素,当用户在这个容器内部点击或者使用键盘导航到一个可获得焦点的元素时,这个元素就会获得:focus-within状态。

以下是一个简单的示例:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .form-item:focus-within {
        	border: 0.0052rem solid #0067FF;
        	background: #eee;
        }
        .input-text:focus{
        	border: 1px solid red;
        }
  </style>
</head>

<body>
    <form method="post">
        <div class="form-item">
            <span>name:</span>
            <input type="text" name="name" class="input-text">
        </div>
        <div class="form-item">
            <span>age:</span>
            <input type="text" name="age" class="input-text">
        </div>
    </form>
</body>
</html>

二、::first-letter 选择器

在CSS中 ::first-letter 是一个伪元素选择器,它用来指定元素第一个字母的样式。通常情况下,我们可以使用该伪元素来增加文本块的可读性和美观性。

使用 ::first-letter 时需要注意以下几点:

1. ::first-letter 只能用于块级元素(如 p、div、h1 等),不适用于行内元素(如 span、a 等)。

2. ::first-letter 只能选择文本块中的第一个字母,而不能选择第一个字符(如数字、标点符号等)。

3. ::first-letter 选择器只能应用于包含文本的元素,否则无效。

4. ::first-letter 选择器不能应用于空元素。

使用 ::first-letter 可以设置的样式属性有:

1. color:设置字体颜色。

2. font-size:设置字体大小。

3. font-family:设置字体。

4. font-weight:设置字体粗细。

5. font-style:设置字体样式(如斜体)。

6. text-transform:设置字母大小写转换(如大写或小写)。

7. line-height:设置行高。

8. float:设置浮动。

9. margin:设置外边距。

10. padding:设置内边距。

11. background-color:设置背景颜色。

12. text-decoration:设置文本装饰(如下划线、删除线等)。

例如:

p::first-letter {
	font-size: 2em;
	color: red;
	float: left;
	margin-right: 5px;
}

三、::selection 选择器

在CSS中 ::selection 伪元素是用来匹配突出显示的文本(用鼠标选择文本时的文本)。

例如,下面的CSS会使得被选中的文本颜色变为蓝色,背景色变为白色:

::selection {
  color: blue;
  background-color: white;
}


随机内容

表情

共0条评论
  • 这篇文章还没有收到评论,赶紧来抢沙发吧~