CSS3 高级选择器

高级选择器:

   1>层次选择

   2>结构伪类选择

   3>属性选择器

详细介绍这几个选择器:

 层次选择

  

 页面:

<body>
		<!--格式化代码:ctrl+shift+F-->
		<h2>兄弟</h2>
		<p>1</p>
		<!-- 为了说明相邻兄弟选择器,在此处添加一个类名active -->
		<p>2</p>
		<p>3</p>
		<ul>
			<li>
				<p>张三</p>
			</li>
			<li>
				<p>李四</p>
			</li>
			<li>
				<p>王五</p>
			</li>
		</ul>
	</body>
/*后代选择器:孩子的孩子...*/
body p{
	 /*border: 1px solid red;*/
}

/*子选择器:body的孩子*/
body>p{
	/*border: 1px solid blue;*/
}

/*相邻兄弟选择器:比较近的兄弟*/
h2+p{
	/*border: 2px solid yellowgreen;*/
}


/*通用兄弟选择器:找到p远近兄弟*/
h2~p{
	border: 5px solid chocolate;
}

效果:

结构伪类选择

页面:

<body>
		<p>1</p>
		<p>2</p>
		<p>3</p>
		<ul>
			<li>
				<p>张三0</p>
			</li>
			<li>
				<p>李四1</p>
			</li>
			<li>
				<p>王五2</p>
			</li>
			<li>
				<p>熊大3</p>
			</li>
		</ul>
	</body>
/*E:first-child :找父的第一个孩子 */

/*注意:不能用body作为父*/
li:first-child{
	border: 2px solid darkcyan;
}

/*E:first-child :找父的最后一个孩子 */

li:last-child{
	border: 2px solid brown;
}

/*E F:nth-child(n): 找到父的孩子第几个
   odd:奇数 ,even:偶数(从1开始数)
 */
/*ul li:nth-child(odd){*/
ul li:nth-child(3){
	/*background-color: coral;*/
}

/*E:first-of-type:父级的第一个元素*/
li:first-of-type{
	background: cornflowerblue;
}

/*E:last-of-type:父级的最后一个元素*/
li:last-of-type{
	background: chartreuse;
}

/*E F:nth-of-type(n):找到子孩子的第几个*/
ul li:nth-of-type(2){
	border: 10px double darkgrey;
}

/*E F:nth-last-of-type(n):子孩子中的倒数第1个同级兄弟*/
li:nth-last-of-type(1){
	border: 5px double red;
}

效果:

属性选择器

页面:

<body>
		<a href="http://www.baidu.com" id="first">1</a>
		<a href="#" title="test website" target="_blank">2</a>
		<a href="sites/file/test.html">3</a>
		<a href="sites/file/test.png" class="links item"> 4</a>
		<a href="sites/file/image.jpg">5</a>
		<a href="efc" title="website link">6</a>
		<a href="/a.pdf">7</a>
		<a href="/abc.pdf">8</a>
		<a href="abcdef.doc">9</a>
		<a href="abd.doc" id="last">10</a>

	</body>
a{
	width: 60px;
	height: 60px;
	border: 0px solid red;
	background: gainsboro;
	display: block;  /*行级转换成块级*/
	float: left;   /*浮动*/
	margin: 5px 10px;  /*外边距*/
	border-radius: 20%;  /* 圆角  */
	text-align: center;  /*水平文本居中*/
	line-height: 55px;  /*垂直居中*/
	font-weight: bolder; /*字体加粗*/
	text-decoration: none; /*去掉下划线*/
	color:black;  /*字体颜色*/
}


/*E[attr]: E标签的属性id*/
a[id]{
	background: mediumaquamarine;
}

/*E[attr=val]:E标签的属性href=#*/
a[href='#']{
	background: chocolate;
}


/*E[attr^=val]:E标签的属性href的值以s开头*/
a[href^='s']{
	background: yellowgreen;
}

/*E[attr$=val]:E标签的属性href的值以f结尾*/
a[href$='f']{
	background: blueviolet;
}

/*E[attr*=val]:E标签的属性href的值包含f所有的*/
a[href*='f']{
	background:coral;
}

效果:

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Selenium CSS选择器是一种在Selenium中用于定位网页元素的方法。它使用CSS选择器语法,通过指定元素的标签名、类名、id、属性等信息来唯一地定位元素。 在Selenium中使用CSS选择器时,可以通过`By.cssSelector`方法将CSS选择器作为参数传递给`findElement`方法来定位元素。例如,如果要定位一个名为"email"的输入框,可以使用以下CSS选择器:`input.inputtext[name=email]`。 下面是一个使用CSS选择器定位并操作网页元素的示例代码: ```java import org.openqa.selenium.By; import org.openqa.selenium.WebDriver; import org.openqa.selenium.chrome.ChromeDriver; public class SeleniumCSSLocators { public static void main(String[] args) { WebDriver driver = new ChromeDriver(); driver.get("https://www.facebook.com/"); driver.findElement(By.cssSelector("input.inputtext[name=email")).sendKeys("journaldev"); } } ``` 这段代码中,通过`By.cssSelector`方法和CSS选择器`input.inputtext[name=email]`定位了一个名为"email"的输入框,并使用`sendKeys`方法往该输入框中输入了"journaldev"。 CSS选择器还支持一些高级的定位方式,例如使用子串匹配来定位元素。通过使用`*=`操作符可以实现子串匹配,可以匹配元素的属性中包含指定字符串的元素。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [SeleniumCSS选择器](https://blog.csdn.net/cunchi4221/article/details/107472314)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值