Python HTML和CSS 4:CSS常用文本样式与样式选择器

简介: Python HTML和CSS 4:CSS常用文本样式与样式选择器

一、常用的应用文本的css样式



  • 1.1、文本的css样式其实也就是给一段文本设置 字体大小、颜色、背景色、是否加粗等等,如下:
  • color 设置文字的颜色,如: color:red;
  • font-size 设置文字的大小,如:font-size:12px;
  • font-family 设置文字的字体,如:font-family:'微软雅黑';建议使用 'Microsoft YaHei',中文容易乱码
  • font-style 设置字体是否倾斜,如:font-style:'normal'; 设置不倾斜,font-style:'italic';设置文字倾斜


image.png

  • font-weight 设置文字是否加粗,如:font-weight:bold; 设置加粗 font-weight:normal 设置不加粗


  • line-height 设置文字的行高,设置行高相当于在每行文字的上下同时加间距, 如:line-height:24px;


image.png

  • font 同时设置文字的几个属性,写的顺序有兼容问题,建议按照如下顺序写: font:是否加粗 字号/行高 字体;如:font:normal 12px/36px 'Microsoft YaHei';


注意:font 值要求顺序的,不能错,否则会失效


  • text-decoration 设置文字的下划线,如:text-decoration:none; 将文字下划线去掉


image.png

text-indent 设置文字首行缩进,如:text-indent:24px; 设置文字首行缩进24px


image.png



  • text-align 设置文字水平对齐方式,如text-align:center 设置文字水平居中

建议:遇到不会的去 w3school 查找


二、css颜色表示法与CSS样式选择器



  • 2.1、css颜色表示法(主要有三种)
  • 第一种:颜色名表示,比如:red 红色,gold 金色


color: red;
  • 第二种:rgb表示,比如:rgb(255,0,0) 表示红色


color: rgb(255,0,0);
  • 第三种:16进制数值表示,比如:#ff0000 表示红色,这种可以简写成 #f00


color: #ff0000;
  • 2.2、CSS样式选择器,常用的选择器有如下几种
  • <1>、标签选择器:(不推荐使用),此种选择器影响范围大,建议尽量应用在层级选择器中。如下


<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>CSS选择器</title>
   <style type="text/css">
      div {
           color: green;
      }
   </style>
</head>
<body>
    <div>这是第 1 个div</div>
    <div>这是第 2 个div</div>
    <div>这是第 3 个div</div>
</body>
</html>


提一下:*{font-size: 20px;},其中的 * 代表所有的选择器,范围太广,不建议使用,了解一下即可


image.png


提示:从上面我们看出来,div 选择器会影响所有的 div 标签,如何区分不同的div标签来设置样式,我们看接着往下看


  • <2>、id选择器:(不推荐使用),通过id名来选择元素,元素的id名称不能重复,所以一个样式设置项只能对应于页面上一个元素,不能复用,损耗资源,id名一般给程序使用,所以不推荐使用id作为选择器。如下


image.png


id选择器在使用的是:#+id的名字+{},如上图


  • <3>、类选择器:(推荐使用),通过类名来选择元素,一个类可应用于多个元素,一个元素上也可以使用多个类,应用灵活,可复用,是css中应用最多的一种选择器。类选择器可以先定义再使用,类选择器使用的是 .,如下代码


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>CSS选择器</title>
    <style type="text/css">
       #div1{
          color: palegreen;
          font-size: 20px;
       }
       .fontSet{
          font-size: 28px;
       }
     </style>
</head>
<body>
    <div id="div1" class="fontSet">这是第 1 个div</div>
    <div class="fontSet">这是第 2 个div</div>
    <div>这是第 3 个div</div>
</body>
</html>


image.png

提一下: class 后面可以设置多个 name,name之间用 空格 隔开,如下

<div class="fontSet colorSet">这是第 2 个div</div>


image.png


  • <4>、层级选择器:主要应用在选择父元素下的子元素,或者子元素下面的子元素,可与标签元素结合使用,减少命名,同时也可以通过层级,防止命名冲突。如下


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>层级选择器</title>
    <style type="text/css">
       .box{
           color: green;
        }
        .box em{
           color: brown;
           font-style: normal;
        }
    </style>
</head>
<body>
     <div class="box">层级选择器:主要应用在选择父元素下的<em>子元素</em>,或者子元素下面的<em>子元素</em>,<br/>
可与标签元素结合使用,减少命名,同时也可以通过层级,防止命名冲突。</div>
</body>
</html>


  • 提示:标签选择器一般都是用在层级选择器里面,不要单独使用,个别的地方可以单独使用
  • 当然你也可以在内嵌标签里面再定义class,在样式里面进行多层 定义,如上面的 .box em,一般来说最多4层,再多性能就不好了
    层级选择器是用 逗号 隔开的


  • <5>、组选择器:多个选择器,如果有同样的样式设置,可以使用组选择器。如下:格式是:各个选择器之间用 , 隔开


<!DOCTYPE html>
<html lang="en">
<head>
   <meta charset="UTF-8">
   <title>组选择器</title>
   <style type="text/css">
       .box1,.box2,.box3{
           font-size: 25px;
           text-indent: 40px;
        }
       .box1{
           color: red;
       }
       .box2{
           color: brown;
       }
       .box3{
           color: gold;
       }
    </style>
</head>
<body>
     <div class="box1">我是第 1 个div</div>
     <div class="box2">我是第 2 个div</div>
     <div class="box3">我是第 3 个div</div>
</body>
</html>


image.png


提示:三个标签的 字体的大小、首行缩进的大小都是一样的,只有字体的颜色不一样,我们可以采用如上的组选择器方式来定义样式


  • <6>、伪类及伪元素选择器:常用的伪类选择器有hover,表示鼠标悬浮在元素上时的状态,伪元素选择器有before和after,它们可以通过样式在元素中插入内容。如下
  • 伪类选择器 (在给标签设置鼠标悬浮在其上面的样式,如下面的 .box1:hover)


<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>伪类与伪元素的使用</title>
    <style type="text/css">
       .box1{
          color: brown;
          font-size: 20px;
       }
       .box1:hover{
          color: red;
          font-size: 28px;
       }
    </style>
</head>
<body>
    <div class="box1">我是第 1 个div</div>
</body>
</html>
  • 伪元素选择器 :(主要是下面 :beforeafter 的使用),都是在添加内容


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>伪类与伪元素的使用</title>
    <style type="text/css">
       .box2,.box3{
            color: brown;
            font-size: 20px;
       }
      .box2:before{
            content: "前面的内容";
            color: green;
      }
      .box3:after{
            content: "后面的内容";
            color: green;
      }
    </style>
</head>
<body>
    <div class="box2">我是第 2 个div</div>
    <div class="box3">我是第 3 个div</div>
</body>
</html>


目录
相关文章
|
2月前
|
数据挖掘 Shell 测试技术
怎么用Python解析HTML轻松搞定网页数据
**Python解析HTML摘要** 本文介绍了使用Python处理HTML的常见需求,如数据提取、网络爬虫和分析,并讨论了三种解析方法。正则表达式适用于简单匹配,但对复杂HTML不理想;BeautifulSoup提供简单API,适合多数情况;lxml结合XPath,适合处理大型复杂文档。示例展示了如何用这些方法提取链接。
|
5天前
|
XML 数据格式 Python
Python技巧:将HTML实体代码转换为文本的方法
在选择方法时,考虑到实际的应用场景和需求是很重要的。通常,使用标准库的 `html`模块就足以满足大多数基本需求。对于复杂的HTML文档处理,则可能需要 `BeautifulSoup`。而在特殊场合,或者为了最大限度的控制和定制化,可以考虑正则表达式。
21 12
|
1月前
|
Python
Python 下载 html 中的 图片
Python 下载 html 中的 图片
21 2
|
1月前
|
数据采集 前端开发 JavaScript
CSS与Python爬虫
【8月更文挑战第9天】
22 8
|
2月前
|
数据采集 自然语言处理 大数据
​「Python大数据」词频数据渲染词云图导出HTML
使用Python,本文展示数据聚类和办公自动化,焦点在于通过jieba分词处理VOC数据,构建词云图并以HTML保存。`wordCloud.py`脚本中,借助pyecharts生成词云,如图所示,关键词如&quot;Python&quot;、&quot;词云&quot;等。示例代码创建了词云图实例,添加词频数据,并输出到&quot;wordCloud.html&quot;。
55 1
​「Python大数据」词频数据渲染词云图导出HTML
|
2月前
|
XML 移动开发 数据格式
【Python】已解决:bs4.FeatureNotFound: Couldn’t find a tree builder with the features you requested: html5
【Python】已解决:bs4.FeatureNotFound: Couldn’t find a tree builder with the features you requested: html5
91 1
|
2月前
|
Unix Linux Shell
Sphinx是一个Python文档生成工具,它可以解析reStructuredText或Markdown格式的源代码注释,并生成多种输出格式,如HTML、LaTeX、PDF、ePub等。
Sphinx是一个Python文档生成工具,它可以解析reStructuredText或Markdown格式的源代码注释,并生成多种输出格式,如HTML、LaTeX、PDF、ePub等。
|
2月前
|
前端开发 JavaScript C++
CSS 【详解】样式选择器(含ID、类、标签、通配、属性、伪类、伪元素、Content属性、子代、后代、兄弟、相邻兄弟、交集、并集等选择器)
CSS 【详解】样式选择器(含ID、类、标签、通配、属性、伪类、伪元素、Content属性、子代、后代、兄弟、相邻兄弟、交集、并集等选择器)
37 0
|
4月前
|
前端开发 JavaScript UED
【专栏:HTML与CSS移动端开发篇】移动端触摸事件与手势识别
【4月更文挑战第30天】本文探讨了移动端触摸事件和手势识别在网页开发中的重要性。介绍了基础触摸事件如`touchstart`, `touchmove`, `touchend`, `touchcancel`及相关属性。文章列举了处理触摸事件的方法,包括单点触摸、多点触摸、滑动、长按、捏合缩放、旋转检测和事件代理。建议使用第三方库如Hammer.js简化手势处理,并分享了最佳实践,如避免意外触摸、提供视觉反馈、考虑性能和跨设备测试。理解并有效利用这些技术能提升用户交互体验。
178 7
|
4月前
|
缓存 前端开发 JavaScript
【专栏:HTML与CSS移动端开发篇】移动端网页性能优化策略
【4月更文挑战第30天】本文探讨了移动端网页性能优化的重要性,并提出了优化策略。HTML方面,建议精简结构、使用语义化标签、异步加载脚本和压缩文件;CSS优化包括精简样式、使用CSS3动画、媒体查询和压缩文件。其他策略涉及图片和字体压缩、缓存利用、数据压缩、减少HTTP请求及根据网络状态调整加载。综合运用这些策略能提升网页性能和用户体验。
82 6