在CSS中,列表元素是一个块框,列表中的每个表项也是一个块框,只是在表项前面多了一个项目符号。列表的格式化,主要由浏览器完成,而不是由设计人员完成。设计人员只能通过 list-style属性来定义列表的样式。

list-style属性只对 display 属性值为 list-item 的对象有效,对其它类型对象无效。list-style属性的语法格式为:

  1. list-style:[ list-style-type ] || [ list-style-position ] || [ list-style-image ]

也就是说,list-style属性可以分解为 list-style-type、list-style-position和list-style-image 这3个独立的属性,下面分别进行介绍。

list-style-type

list-style-type属性用来定义列表所使用的项目符号的类型,可选值有 none | disc | circle | square | decimal | decimal-leading-zero | lower-alpha | upper-alpha | lower-roman | upper-roman,默认值为 disc。常用属性值及效果说明见表 6‑1:

表 6-1 list-style-type属性的常用属性值及效果说明
属性值 效果说明
none 不使用任何项目符号
disc 默认值,实心圆
circle 空心圆
square 实心矩形
decimal 数字1、2、3、4、5
decimal-leading-zero 以0打头的数字,01、02、03、04、05
lower-alpha 小写英文字母,a、b、c、d、e
upper-alpha 大写英文字母,A、B、C、D、E
lower-roman 小写罗马数字,ⅰ、ⅱ、ⅲ、ⅳ、ⅴ
upper-roman 大写罗马数字,Ⅰ、Ⅱ、Ⅲ、Ⅳ、Ⅴ

如果一个元素的 list-style-image属性的值设置为 none,或者 list-style-image属性指定的图像无法正常时,则由 list-style-type属性来决定 list-item 元素的外观。

由于CSS无法区别一个列表是有序列表,还是无序列表,因此,不管是有序列表还是无序列表,都是使用 list-style-type属性来定义列表项符号。只要你愿意,完全可以让一个有序列表使用实心圆,而非数字作为项目符号。如果项目符号设置为数字或字母,这些数字或字母由浏览器自动计算。

如果为 ul 或 ol 元素定义 list-style-type属性,则其内部的所有 li 子元素都使用相同的项目符号。当然,也可以为 li 元素单独设置 list-style-type属性,让其只对该 li 元素有效。

  1. .disc {
  2.    list-style-type: disc;
  3. }
  4. .circle {
  5.    list-style-type: circle;
  6. }
  7. .decimal-leading-zero {
  8.    list-style-type: decimal-leading-zero;
  9. }
  10. .lower-alpha {
  11.    list-style-type: lower-alpha;
  12. }
  13. .upper-roman {
  14.    list-style-type: upper-roman;
  15. }

上述代码定义了 5 个类,每个类定义了不同的列表项目符号类型,把这 5 个类分别应用于同一个 ul 元素下的不同 li 元素。

  1. <ul>
  2.     <li class="disc">disc:默认值,实心圆</li>
  3.     <li class="circle">circle:空心圆</li>
  4.     <li class="decimal-leading-zero">decimal-leading-zero:以0打头的数字 01、02</li>
  5.     <li class="lower-alpha">lower-alpha:小写英文字母a、b、c、d、e</li>
  6.     <li class="upper-roman">upper-roman:大写罗马数字Ⅰ、Ⅱ、Ⅲ、Ⅳ、Ⅴ</li>
  7. </ul>

上述代码的运行结果如图 6‑2 所示:

图6-2 list-style-type属性效果

从上图可以看出,把上述  5 个类分别应用于同一个 ul 元素下的不同 li 元素后,不同的 li 元素具有不同的项目符号。

如果想禁止显示项目符号,就可以把 list-style-type属性值设置为 none,none 会导致浏览器在原本放置项目符号的位置不显示任何内容,不过,它不会中断有序列表的计数。如,有以下有序列表元素:

  1. <ol>
  2.     <li>List Item 1</li>
  3.     <li style = "list-style-type: none;">List Item 2</li>
  4.     <li>List Item 3</li>
  5. </ol>

上述列表中,禁止第二个列表项的项目符号。运行结果如图 6‑3 所示:

图6-3 禁止项目符号

由于 list-style-type属性具有继承性,所以,如果希望嵌套列表中使用不同的项目符号,可能需要在内层列表中单独定义。

list-style-position

list-style-position属性设置列表项目符号的位置及列表项的对齐方式,取值 outside | inside,默认值为 outside。

outside 表示列表项目符号放置在内容以外,列表项以内容为准对齐;inside 表示列表项目符号放置在内容以内,列表项以项目符号为准对齐。如:

  1. ul  {
  2.    padding: 0;
  3.    border: 1px solid #444;
  4.    list-style-type: square;
  5. }
  6. .outside  {
  7.     list-style-position: outside;
  8. }
  9. .inside  {
  10.     list-style-position: inside;
  11. }
  1. <ul class = "outside">
  2.     <li>outside的列表,列表项以内容为准对齐</li>
  3.     <li>outside的列表,列表项以内容为准对齐</li>
  4. </ul>
  5. <ul class = "inside">
  6.     <li>inside的列表,列表项以标记为准对齐</li>
  7.     <li>inside的列表,列表项以标记为准对齐</li>
  8. </ul>

上述代码中,第一个列表采用 outside 列表项标记,第二个列表采用 inside 列表项标记。运行结果如图 6‑4 所示:

图6-4 list-style-position属性效果

从上图可以看出,如果列表项的内容为多行,在内容发生换行后,outside 的列表项是以内容为准对齐,而 inside 的列表项则以项目符号为准对齐。

上图还告诉我们,outside 列表的项目符号不但出现在列表项的内容之外,也出现在列表元素的内容之外,这是因为项目符号实际上并不是列表内容区的一部分,它不占据容器的空间。所以,在列表元素的 margin 或 padding 为 0 时,项目符号就有可能覆盖其它元素或被其它元素覆盖。如果发现列表的项目符号显示不出来,这可能是原因之一。

list-style-image

浏览器提供的列表项目符号,不能满足所有人的需要,并且可选择的范围有限。因此,可以通过 list-style-image属性定义一幅图像,来取代默认的列表项目符号。语法格式为:

list-style-image: none | url()

默认值为none,表示使用 list-style-type属性指定的列表项目符号;url()表示使用 url 指定的图像来取代默认的列表项目符号,如果图像无效,则 list-style-type属性会生效。如:

  1. ul  {
  2.     list-style-image: url(img/square.png);
  3. }
  1. <ul>
  2. <li>list-style-type属性</li>
  3. <li>list-style-position属性</li>
  4. <li>list-style-image属性</li>
  5. <ul>

上述代码中,使用图像 square.png 作为列表项标记。运行结果如图 6‑5 所示:

图6-5 list-style-image属性效果

不错,就这么简单,只需一个简单的 url() 值,就可以使用图像作为项目符号。不过,在选择图像时要当心,尽量选择合适尺寸的图片,否则项目符号可能不清晰。

通常,为了防止一些意外情况,如图像未能加载、或被破坏、或浏览器无法识别图像的格式等等,为列表定义一个备用的 list-style-type 是一个很好的实践。

  1. ul  {
  2.     list-style-image: url(img/square.png);
  3.     list-style-type: square;
  4. }

由于list-style-image属性具有继承性,所以,内层的所有列表都会使用该图像作为项目符号。如果不希望这种情况发生,假如希望内层列表使用实心矩形,就需要把内层列表的 list-style-type属性设置为 square。另外,由于 list-style-image属性比 list-style-type属性的优先级要高。因此,还需要把内层列表的 list-style-image属性重置为 none。

  1. ul ul {
  2.     list-style-image: none;
  3.     list-style-type: square;
  4. }

得到的运行结果如图 6‑6 所示:

图6-6 改变嵌套列表符号

关于作者

歪脖先生,十五年以上软件开发经验,酷爱Web开发,精通 HTML、CSS、JavaScript、jQuery、JSON、Python、Less、Bootstrap等,著有《HTML宝典》、《揭秘CSS》、《Less简明教程》、《JSON教程》、《Bootstrap2用户指南》、《Bootstrap3实用教程》,并全部在 GitHub 上开源。

CSS 列表的样式 list-style-type、list-style-position和list-style-image 属性相关推荐

  1. php文章列表样式,css列表样式有哪些?css设置列表样式的方法

    关于列表的css样式有哪些以及如何设置css列表样式?接下来的这篇文章将为大家介绍关于css列表样式的内容. 1.css有序列表(ol)和css无序列表(ul) list.html 列表样式 水果 苹 ...

  2. CSS叠层样式表(三)

    CSS叠层样式表(三) 文档流 display和visibility属性 定位 浮动 背景 文档流 display和visibility属性 display属性定义了元素的基本显示方式,它的常用值包括 ...

  3. CSS的表格样式和列表样式

    -----------------------------------------------CSS的表格样式和列表样式---------------------------------------- ...

  4. 前端:JS/28/CSS DOM动态样式(style对象,style 对象属性与CSS属性的转换),Event DOM,事件对象简介(DOM和IE中的Event对象),实例:点出满天小星星

    CSS DOM动态样式 使用JS操作CSS中的各个属性: JS只能操作或修改行内样式,如:imgObjstyle.border = "1px solid red"; 对于类样式,通 ...

  5. CSS修改默认列表元素样式(1.修改默认元素样式 2.伪元素选择器)

    CSS修改默认列表元素样式 1. 修改默认元素样式 <!DOCTYPE html> <html lang="en"><head><meta ...

  6. html css表格样式模板_HTML amp; CSS 基础入门【4】列表及其样式

    前面 网页中漂亮的导航.整齐规范的文章标题列表和图片列表等等.这些都是离不开HTML里一个重要的元素----列表,在HTML中有无序列表.有序列表和定义列表三种类型.其中,无序列表应用最为广泛,下面, ...

  7. html中正方形列表标签属性,CSS 列表样式

    我们知道在 HTML 中列表可以分为无序列表.有序列表.定义列表.在网页中经常可以看到无序列表的使用,例如像导航栏菜单.新闻列表.商品分类.图片展示等,基本都是通过无序列表来实现的. 无序列表中每个列 ...

  8. 1.1 css style 样式定义:行内 style 属性、单页 <style> 标签、多页 <style> 标签

    1.1 style 样式定义:行内 style 属性.单页 <style> 标签.多页 <style> 标签 文章目录 1.1 style 样式定义:行内 style 属性.单 ...

  9. CSS 列表样式(ul)

    1.CSS列表属性作用如下: 设置不同的列表项标记为有序列表 设置不同的列表项标记为无序列表 设置列表项标记为图像 2.在HTML中,有两种类型的列表: 无序列表 - 列表项标记用特殊图形(如小黑点. ...

最新文章

  1. flutter项目迁移空安全
  2. java防止批量攻击_java 防止 XSS 攻击的常用方法总结
  3. 在 Docker 里运行 Microsoft SQL 服务器
  4. 微信小程序下拉刷新列表onPullDownRefresh;微信小程序上划加载列表onReachBottom;uni-app微信小程序下拉加载数据;uni-app微信小程序上划页面加载数据
  5. Devexpress Chart series 点击时获取SeriesPoint的值
  6. 云服务器 ECS > 安全 > 实例RAM角色 > 概述
  7. el如何获取复选框的值_element ui 表格提交时获取所有选中的checkbox的数据
  8. 我觉得我们看到的所谓“善良人”
  9. HF-NET环境配置与安装
  10. 程序员面试金典——2.4链表分割
  11. 《Thumbs up? Sentiment Classification using Machine Learning Techniques》笔记
  12. 软件工程基础-个人项目-数独的生成与求解
  13. UE4 特效生成函数
  14. Java内部类介绍 - 局部内部类和匿名内部类
  15. 817考研c语言程序设计,2017年沈阳航空航天大学计算机学院817程序设计[专业硕士]考研题库...
  16. 边策划边制作的游戏开发日志(一) 用Untiy制作类似《莱莎的炼金工坊》移动和视角系统(第三人称控制系统)
  17. 数据库——ODBC连接
  18. 个性化学习之自适应测试[Adaptive Test]
  19. 深度优先搜索-Python
  20. 放榜时刻!RT-Thread应用创新大赛圆满收官

热门文章

  1. 多智能体强化学习与博弈论-博弈论基础
  2. 指导饮水机卡逻辑算法
  3. Android TV开发(二)处理TV硬件
  4. Rainbow Brackets 彩色括号 兼容Solarized Themes日晒主题的配色方案
  5. 在 IPMONTR.DLL 中初始化函数 INITHELPERDLL 启动失败,错误代码为 10107
  6. 第十一天堂的学习笔记Ubuntu第一篇,分区安装,设置root密码,安装五笔和VMtools
  7. 《学习之道》第七章再次强调回想是最好的学习方式
  8. C#作业调度Quartz简单使用
  9. 我的复习计划(很有借鉴意义)
  10. 用某宝上的板子制作可调的正负电源