0

0

《CSS网站布局实录》学习笔记(六)_html/css_WEB-ITnose

php中文网

php中文网

发布时间:2016-06-24 12:05:19

|

1227人浏览过

|

来源于php中文网

原创

第六章 css高级应用与技巧

6.1 id与class

6.1.1 什么是id

  id是XHTML元素的一个属性,用于标识对象名称。无论是class还是id,都是XHTML所支持的公共属性,并且也是其核心属性。class的主要功能是用来对对象的样式设置,而id除了可以定义样式外,还能够成为服务网站交互行为一个特殊标识。每一个被定义了id名称的对象,其id名字在每个页面有且仅能出现一次。

6.1.2 如何使用id

立即学习前端免费学习笔记(深入)”;

  在不考虑使用JavaScript脚本,而是XHTML代码及CSS样式应用的情况下,应当有选择地使用id属性来对元素进行标识,具体使用上应当具备下面的原则。

  • 样式只使用一次:如果有一段样式代码在页面中只可能被使用一次,那么可以使用id进行标识。
  • 用于对页面的区域进行标识:使用id对页面中某个区域进行标识,有助于XHTML结构的可读性。
  • 6.1.3 什么是class

      class直译为类、种类。class是相对于id的又一个属性。id是对单独元素的标识,而class是对一类元素的标识。与id相反,同一页面中的每个class名称都允许重复使用。

    6.1.4 何地使用class

  • 同一页面中出现多次
  • 通用及经常能使用的元素
  • 6.1.5 同时使用多个类

      XHTML允许在标签的class属性设置中,同时使用一个以上的类名,使用空格来分隔多个class样式名称。

    6.2 div与span

      很多人都容易混淆div元素与span元素的真正用途,那到底该如何使用它们,先来W3C对它们两个的官方定义:

  • div: generic language/style container.
  • span: generic language/style container.
  •   在W3C对div及span的简要描述中,可以看到同样的说明??用于定义样式的容器。虽然W3C在对div及span的描述中都说明了相同的用法,而且非常准确。实际上,div与span在使用方式上还是存在很大的差别的。

      在相同的CSS样式情况下, div之间出现了换行,而span则是同行左右关系。这就是它们之间存在的使用差别。造成差别的原因就在于其默认显示模式的不同,可以通过display属性来修改元素的显示模式。

    总结:div对象的默认显示模式是display: block;块状元素。span对象的默认显示模式是display: inline;内联元素。

    6.3 CSS选择符命名

    6.3.1 大小写敏感

      XHTML对大小写并不敏感。CSS对对象选择符(如body、td、div)也是不分区大小写的,但是CSS对id及class选择符的名称则是区分大小写的。

    6.3.2 合法字符及组合

      在CSS及XHTML中,class及id必须由大写或者小写字母开始,随后可以使用任意的字母、数字、连接线或者下划线。

    6.3.3 命名建议

  • 使用具有语义命名
  • 使用大小写组合命名
  • 使用下划线及连接线命名
  • 根据网站需要定制命名规则
  • 6.4 CSS文件结构设计与优化

      尽管CSS能够实现表现与内容的分离,但也引发了另一个新问题??CSS文件日益庞大。出现这种情况,会直接导致网站两个致命的问题:

  • 初次载人网站速度慢
  • 维护困难
  •   当然CSS的设计者已经想到了这一点,提供了导入命令,从而可以从别的地方导入样式表,这样就便于网站的后期维护。

    6.4.1 导入结构

      @import导入命令是CSS提供的一个实用命令,主要功能是根据路径导入一个样式表文件,并且能够制定样式表所服务的设备类型。这样可以将别的样式表导入当前样式表中,使样式表文件不必写在同一个文件之中。使用方法为:@import url("xxx.css");

      除此之外,@import命令还能够为导入的样式表制定一个设备类型,指明当前的样式表用于什么用途。比如:@import url("xxx.css") print;

    6.4.2 结构优化

    LALALAND
    LALALAND

    AI驱动的时尚服装设计平台

    下载

      对于大型网站的样式设计而言,可以通过@import命令这样的分离技术,让不同种类的样式各自写在独立的文件之中,这样也就实现了CSS代码层面的结构优化。下面讨论几种常用的结构模式及使用方法。

  • 根据样式特点进行CSS结构设计
  • 根据功能进行CSS结构设计
  • 根据页面需要进行CSS导入组合
  • 6.5 使用CSS缩写

      CSS缩写是指将多个CSS属性集合到一行中的编写方式,这种方式能够缩减大量的代码,使代码便于阅读、理解。

    6.5.1 font字体缩写

      字体缩写是针对字体样式进行的缩写形式,包含字体、字号等属性,使用方法如下:

      font: font-style | font-variant | font-weight | font-size | line-height | font-family

      对于字体的样式缩写,只要使用font作为属性名称,后接各个属性的值即可,各个属性值之间使用空格分开。

    6.5.2 margin与padding边距缩写

      默认情况下,margin及padding的缩写需要提供4个参数,按照顺序分别为上、右、下、左。下面来举例:(这里以margin来举例,padding的设置方法与margin完全相同)

  • 单独使用一个参数:p {margin: 20px; }表示p对象四周的外边距均为20px
  • 使用两个参数:p { margin: 20px 10px; }表示对上下边距为20px,左右边距为10px
  • 使用三个参数:p { margin: 20px 10px 100px; }表示上边距为20px,左右边距为10px,下边距为100px
  • 使用四个参数:p { margin: 20px 10px 10px 20px; }表示上边距为20px,右边距为10px,下边距为10px,左边距为20px
  • 注:margin/padding的设置完全是按照顺时针方向进行边距设置。

    6.5.3 border边框缩写

      border对象包含四条边的不同宽度、不同颜色以及不同样式。所以,不仅可以对整个对象进行border缩写,也可以对单个边进行缩写。使用方法如下:

      border: border-width | border-style | color

    6.5.4 list列表缩写

      list缩写是针对list-style-type、list-style-position等用于ul的list属性。使用方法如下:

      list-style: list-style-type | list-style-position | list-style-image

    6.5.5 background背景缩写

      背景缩写用于针对对象的背景以控制其相关属性进行缩写。使用方法如下:

      background: background-color | background-image | background-repeat | background-attachment | background-position

    6.5.6 color颜色缩写

      CSS对对象的颜色缩写主要是针对十六进制颜色。当A与B、C与D、E与F数字相同时,可以使用颜色缩写。比如#FFFFFF可以缩写为#FFF,#2255BB可以缩写为@25B。

    6.6 CSS代码优化

      代码优化是软件开发的重要原则之一,这里对于CSS样式布局设计非常重要。

    6.6.1 增加代码重用率

      有时候,尽管发现同一属性在多个区域同时出现的情况,但由于每个区域其使用目的不同,因此在对CSS进行简化的时候,不能一概而论,一定要根据当前页面的结构与对未来扩展的预期进行合理的分析与配置,最终实现CSS简化的目的。

    6.6.2 使用样式覆盖进行简化

      如果CSS对某一元素应用了多个样式代码,往往是后一段代码替代前一段代码。利用这个特性,可以采用覆盖方式,使得代码得到重用。

    相关文章

    HTML速学教程(入门课程)
    HTML速学教程(入门课程)

    HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

    下载

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

    幻方量化公司旗下的开源大模型平台

    豆包大模型
    豆包大模型

    字节跳动自主研发的一系列大型语言模型

    通义千问
    通义千问

    阿里巴巴推出的全能AI助手

    腾讯元宝
    腾讯元宝

    腾讯混元平台推出的AI助手

    文心一言
    文心一言

    文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

    讯飞写作
    讯飞写作

    基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

    即梦AI
    即梦AI

    一站式AI创作平台,免费AI图片和视频生成。

    ChatGPT
    ChatGPT

    最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

    相关专题

    更多
    俄罗斯Yandex引擎入口
    俄罗斯Yandex引擎入口

    2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

    21

    2026.01.28

    包子漫画在线官方入口大全
    包子漫画在线官方入口大全

    本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

    5

    2026.01.28

    ao3中文版官网地址大全
    ao3中文版官网地址大全

    AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

    24

    2026.01.28

    php怎么写接口教程
    php怎么写接口教程

    本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

    1

    2026.01.28

    php中文乱码如何解决
    php中文乱码如何解决

    本文整理了php中文乱码如何解决及解决方法,阅读节专题下面的文章了解更多详细内容。

    3

    2026.01.28

    Java 消息队列与异步架构实战
    Java 消息队列与异步架构实战

    本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

    6

    2026.01.28

    Python 自然语言处理(NLP)基础与实战
    Python 自然语言处理(NLP)基础与实战

    本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

    23

    2026.01.27

    拼多多赚钱的5种方法 拼多多赚钱的5种方法
    拼多多赚钱的5种方法 拼多多赚钱的5种方法

    在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

    122

    2026.01.26

    edge浏览器怎样设置主页 edge浏览器自定义设置教程
    edge浏览器怎样设置主页 edge浏览器自定义设置教程

    在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

    51

    2026.01.26

    热门下载

    更多
    网站特效
    /
    网站源码
    /
    网站素材
    /
    前端模板

    精品课程

    更多
    相关推荐
    /
    热门推荐
    /
    最新课程
    Node.js 教程
    Node.js 教程

    共57课时 | 9.5万人学习

    Vue 教程
    Vue 教程

    共42课时 | 7.3万人学习

    Django 教程
    Django 教程

    共28课时 | 3.6万人学习

    关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
    php中文网:公益在线php培训,帮助PHP学习者快速成长!
    关注服务号 技术交流群
    PHP中文网订阅号
    每天精选资源文章推送

    Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号