热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

CSS3属性选择器的几种用法(代码实例)

1、整个div宽为850,要求在页面中居中显示;2、标题大小为28,加粗显示;3、其他字体14px大小;4、点击明星八卦,跳转到tobagua.html,点击军事新闻跳转到toaffairs.html现在来具体操作...

本文目标:

1、掌握CSS3中属性选择器几种用法

问题:

1、要求使用div+css实现以下效果,但是要求css文件中全部使用属性选择器来设置元素样式

附加说明:

1、整个div宽为850,要求在页面中居中显示

2、标题大小为28,加粗显示

3、其他字体14px大小

4、点击明星八卦,跳转到tobagua.html,点击军事新闻跳转到toaffairs.html

现在来具体操作

1、因为该案例不需要一些额外的素材,所以准备素材这一步就可以省略了

2、创建好index.html,写好架构,架构如何分析呢

思路分析:

1、目标分成左右2个部分,每个部分都是显示新闻列表,只是每个新闻的类别不一样,且一些样式也不同

2、含有林心如的新闻颜色要单独设置

3、含有f15的新闻颜色也要单独设置

4、两个部分的标题也要单独设置,所以要给他们单独设置一些属性,这才可以通过属性选择器来匹配到

5、因为每个部分都是列表,所以我们可以使用ul,但是两个ul都是平齐的,所以需要用到float,既然是float了,那么为了确保外层的容器依然能包裹住浮动的元素,所以最后需要加上clear元素来清除浮动

根据分析,我们得出以下代码




    
    



    
明星八卦
  • ->林心如女儿小海豚正面照被公开颜值撞脸年轻时的霍建华,太美了
  • ->倪萍还是胖点好,瘦下来后太显老了,一点精神没有穿衣也不好看!
  • ->汪小菲晒儿女沙滩上顽皮玩耍,儿子长高不少,女儿一身泥被指酷似奶奶张兰
  • ->伊能静给婆婆安排了个小次卧, 走进秦妈妈的表情变化让人心疼!
军事新闻
  • ->F15E成为首型接收B61-12核弹的战斗机
  • ->越南的骑兵警队,马略矮了点啊
  • ->美军运输机降落时冲出跑道后撞墙起火 4人受伤
  • ->不到一个月又出事:美军F-35降落时起落架折断
 

3、写样式 ,创建css文件夹,里面新建index.css,里面的样式怎么写了,以下是分析思路

思路分析:

container容器的所有子元素

1、因为要求每个样式必须使用属性选择器来匹配设置,所以我们的思路是首先要获取到属性cOntainer=true的元素,然后给它设置一些共同的样式,比如最常见的padding,margin,因为不这样设置的话,有些元素的默认padding你未必清楚,为了让你专心写逻辑,我们统一他们的padding,margin都为0

所以index.css中添加代码如下:

div[cOntainer=true] *{
    padding:0;
    margin:0;
}

container容器

1、根据要求得知,最外层容器的宽为850,要居中,上下左右都有padding,带灰色边框,默认字体大小为14px,哪个是container容器呢,就是container属性=true的元素

所以index.css中添加代码如下:

div[cOntainer=true] {
   width: 850px;
   margin: 0 auto;
   font-size: 14px;
   border: 1px solid lightgray;
   padding: 10px;
}

2个标题公共样式设置

1、因为标题都要求居中,字体大小为28px,加粗显示,哪些是标题呢,就是属性title=true的所有元素

所以index.css中添加代码如下:

span[title=true] {
   text-align: center;
   font-size: 28px;
   font-weight: bold;
}

2个标题连接的单独设置

1、八卦标题颜色是带红色的

2、军事标题颜色是蓝色的

3、属性href含有bagua字符串的就是左边的标题连接,href属性以toaffairs开头的就是右边标题连接

*= 表示包含,^=表示开头

所以index.css中添加代码如下:

a[href *=bagua] {
   color: rgb(234, 84, 23);
}

a[href ^=toaffairs] {
   color: green;
}

左右浮动div设置

1、左边div需要向左浮动,那哪个是左边那个div呢,其实就是left属性为true的div

2、右边div需要向右浮动,那哪个是右边那个div呢,其实就是right属性为true的div

3、作用为清除浮动的div,其实就是 class 以clear结尾的那个

注:$= 表示以什么结束

所以index.css中添加代码如下:

div[left =true] {
   float: left;
}

div[right =true] {
   float: right;
}

div[class $= clear] {
   clear: both;
   float: none;
   width: 0;
   height: 0;
}

li设置

1、li不包含黑色圆点,所以list-style:none

2、属性class包含news字符串的元素即为li

3、根据效果得出上下左右有一定的间距

所以index.css中添加代码如下:

li[class =news] {
   list-style: none;
   height: 42px;
   line-height: 42px;
   padding:3px 10px;
}

含有林心如的标题设置

1、此标题颜色为土黄色,字体加粗

2、class属性以lxr结尾的为林心如的标题,所以用$=

[class $=lxr]{
    color:peru;
    font-weight: bold;
}

含有f15的标题设置

1、此标题颜色为蓝色,字体加粗

2、class属性包含f15字符串的标题为目标设置标题,所以用 *=

[class*=f15]{
    color:blue;
    font-weight: bold;
}

到此为止,index.css的全部内容如下:

div[cOntainer=true] *{
    padding:0;
    margin:0;
}
div[cOntainer=true] {
   width: 850px;
   margin: 0 auto;
   font-size: 14px;
   border: 1px solid lightgray;
   padding: 10px;
}

span[title=true] {
   text-align: center;
   font-size: 28px;
   font-weight: bold;
}

a[href *=bagua] {
   color: rgb(234, 84, 23);
}

a[href ^=toaffairs] {
   color: green;
}

div[left =true] {
   float: left;
}

div[right =true] {
   float: right;
}

div[class $= clear] {
   clear: both;
   float: none;
   width: 0;
   height: 0;
}

li[class *=news] {
   list-style: none;
   height: 42px;
   line-height: 42px;
   padding:3px 10px;
}
[class $=lxr]{
    color:peru;
    font-weight: bold;
}
[class*=f15]{
    color:blue;
    font-weight: bold;
}

然后将index.css引入index.html




    
    
     



    
明星八卦
  • ->林心如女儿小海豚正面照被公开颜值撞脸年轻时的霍建华,太美了
  • ->倪萍还是胖点好,瘦下来后太显老了,一点精神没有穿衣也不好看!
  • ->汪小菲晒儿女沙滩上顽皮玩耍,儿子长高不少,女儿一身泥被指酷似奶奶张兰
  • ->伊能静给婆婆安排了个小次卧, 走进秦妈妈的表情变化让人心疼!
军事新闻
  • ->F15E成为首型接收B61-12核弹的战斗机
  • ->越南的骑兵警队,马略矮了点啊
  • ->美军运输机降落时冲出跑道后撞墙起火 4人受伤
  • ->不到一个月又出事:美军F-35降落时起落架折断
 

运行结果为:

A=B表示A属性值等于B字符串

A*=B表示A属性值包含B字符串

A$=B表示A属性值以B字符串结尾

A^=B表示A属性值以B字符串开头

以上就是CSS3属性选择器的几种用法(代码实例)的详细内容,更多请关注 第一PHP社区 其它相关文章!


推荐阅读
  • 本文深入探讨了 hCalendar 微格式在事件与时间、地点相关活动标记中的应用。作为微格式系列文章的第四篇,前文已分别介绍了 rel 属性用于定义链接关系、XFN 微格式增强链接的人际关系描述以及 hCard 微格式对个人和组织信息的描述。本次将重点解析 hCalendar 如何通过结构化数据标记,提高事件信息的可读性和互操作性。 ... [详细]
  • 本文详细介绍了在 Vue.js 前端框架中集成 vue-i18n 插件以实现多语言支持的方法。通过具体的配置步骤和示例代码,帮助开发者快速掌握如何在项目中实现国际化功能,提升用户体验。同时,文章还探讨了常见的多语言切换问题及解决方案,为开发人员提供了实用的参考。 ... [详细]
  • 捕获并处理用户输入数字时的异常,提供详细的错误提示与指导
    在用户输入数字时,程序能够有效捕获并处理各种异常情况,如非法字符或格式错误,并提供详尽的错误提示和操作指导,确保用户能够准确输入有效的数字数据。通过这种方式,不仅提高了程序的健壮性和用户体验,还减少了因输入错误导致的系统故障。具体实现中,使用了Java的异常处理机制,结合Scanner类进行输入读取和验证,确保了输入的合法性和准确性。 ... [详细]
  • VC维在机器学习中的应用与解析
    VC维在机器学习中的应用与解析VC维是指在机器学习中,一个假设空间能够正确分类的最大样本数量。具体而言,如果一个假设空间能够将N个样本以所有可能的 \(2^N\) 种方式完全分开,则称该假设空间具有N的VC维。VC维是衡量模型复杂度的重要指标,对于理解模型的泛化能力和过拟合风险具有重要意义。本文详细探讨了VC维的定义、计算方法及其在机器学习中的应用,并通过实例分析展示了其在模型选择和评估中的关键作用。 ... [详细]
  • C++入门必备:首个博客知识点汇总
    本文总结了C++初学者需要掌握的关键知识点,特别强调了成员类型的区分。其中,protected成员与private成员在本类中的作用相同,但protected成员允许派生类的成员函数访问,而private成员则不允许。此外,文章还介绍了其他重要的C++基础概念,如类的构造函数、析构函数以及继承机制,为初学者提供了一个全面的学习指南。 ... [详细]
  • 在使用Block时,正确的声明方法和确保线程安全是至关重要的。为了保证Block在堆中分配,应使用`copy`修饰符进行声明,因为栈中的Block与栈的生命周期绑定,容易导致内存问题。此外,还需注意Block捕获外部变量的行为,以避免潜在的循环引用和数据不一致问题。建议深入研究相关文档,以掌握更多高级技巧和最佳实践。 ... [详细]
  • vtkGlyph3D 是一种强大的符号化可视化工具,能够将三维数据集中的每个点用预定义的几何图形(如球体或箭头)进行表示。该工具不仅支持自定义符号的方向和缩放比例,还能够在复杂的数据场中突出显示关键特征,从而提高数据的可解释性和可视化效果。通过这种方式,用户可以更直观地理解和分析三维数据集中的重要信息。 ... [详细]
  • MongoVUE基础操作指南:轻松上手数据库管理
    本文介绍了MongoVUE的基础操作,旨在帮助用户轻松掌握数据库管理技巧。MongoVUE是一款功能强大的MongoDB客户端工具,虽然需要注册,但其用户友好的界面和丰富的功能使其成为许多开发者的首选。文中详细解释了安装步骤、基本配置以及常见操作方法,并对一些常见的问题进行了修正和补充,确保用户能够快速上手并高效使用MongoVUE进行数据库管理。 ... [详细]
  • 在Python网络编程中,多线程技术的应用与优化是提升系统性能的关键。线程作为操作系统调度的基本单位,其主要功能是在进程内共享内存空间和资源,实现并行处理任务。当一个进程启动时,操作系统会为其分配内存空间,加载必要的资源和数据,并调度CPU进行执行。每个进程都拥有独立的地址空间,而线程则在此基础上进一步细化了任务的并行处理能力。通过合理设计和优化多线程程序,可以显著提高网络应用的响应速度和处理效率。 ... [详细]
  • HDU1176:免费馅饼问题的动态规划解法分析
    题目“免费馅饼”通过动态规划方法进行了解析。该问题的时间限制为 Java 2000ms 和其他语言 1000ms,内存限制为 Java 65536K 和其他语言 32768K。本文详细探讨了如何利用动态规划算法高效求解此问题,并对算法的时间复杂度和空间复杂度进行了深入分析。此外,还提供了具体的实现步骤和代码示例,帮助读者更好地理解和应用这一方法。 ... [详细]
  • 在处理遗留数据库的映射时,反向工程是一个重要的初始步骤。由于实体模式已经在数据库系统中存在,Hibernate 提供了自动化工具来简化这一过程,帮助开发人员快速生成持久化类和映射文件。通过反向工程,可以显著提高开发效率并减少手动配置的错误。此外,该工具还支持对现有数据库结构进行分析,自动生成符合 Hibernate 规范的配置文件,从而加速项目的启动和开发周期。 ... [详细]
  • PHP开发人员薪资水平分析:工程师平均工资概况
    PHP开发人员薪资水平分析:工程师平均工资概况 ... [详细]
  • 在遍历集合的过程中,若需根据特定条件对集合进行修改操作,如添加或删除元素,应特别注意避免引发 `ConcurrentModificationException` 异常。例如,在当前场景中,当集合中的对象ID与另一个集合中的对象ID不匹配时,需要向集合中添加新元素。为了避免这一异常,建议使用迭代器的 `remove` 方法或采用线程安全的集合类型,如 `CopyOnWriteArrayList`,以确保操作的安全性和一致性。 ... [详细]
  • 如何在Mac上构建高效的本地服务器环境
    在Mac上构建高效的本地服务器环境,首先需要了解基本步骤:1. 配置目录基础;2. 启动Apache服务;3. 添加自定义文档至本地服务器;4. 查看自定义效果。此外,还可以通过手机或其他电脑访问本机服务器,以确保跨设备的兼容性和调试效果。Mac系统自带的Apache服务为本地开发提供了便捷的工具,本文将详细介绍每个步骤的具体操作方法。 ... [详细]
  • CAS 机制下的无锁队列设计与实现 ... [详细]
author-avatar
Saber木木-汐7rv
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有