详细理解CSS中的outline

详细理解 CSS 中的 outline

在 CSS 中,outline 属性可以用来给 HTML 元素添加轮廓线。这个属性通常用于指示用户当前选中了哪个元素,或者作为键盘导航时的可访问性工具。

基本语法

outline 属性有三个可选值:

  • outline-width:轮廓线的宽度,默认为 medium
  • outline-style:轮廓线的样式,默认为 none
  • outline-color:轮廓线的颜色,默认为当前文字颜色

可以通过以下方式设置 outline 属性:

-- ---- - ------ --
- -
  -------- --- ------ ----
-

-- ---------------- --
------ -
  -------------- ----
  -------------- -------
  -------------- -----
-

与 border 的区别

虽然 outline 属性看起来很像 border,但它们之间有一些重要的区别:

  1. outline 不占据空间:outline 不会增加元素的大小或改变排列位置。这意味着即使将 outline 设置为很大的值,也不会影响页面布局。

  2. outline 不支持圆角:与 border-radius 不同,outline 不支持圆角。如果你需要在元素周围添加圆角的轮廓线,需要将其设置为边框。

  3. outline 可以居于元素之上:outline 总是在元素的前面显示,不受 z-index 影响。这意味着即使父级元素设置了 overflow: hiddenoutline 也会超出该区域。

实际应用

1. 改变链接被选中时的样式

可以使用 :focus 伪类和 outline 属性来改变链接被选中时的样式:

------- -
  -------- --- ----- -----
-

2. 对键盘焦点进行指示

当用户使用键盘导航时,可以使用 :focus 焦点状态和 outline 属性来指示当前聚焦的元素:

-- ------------- --
------ -
  -------- --- ------ ------
-

3. 给图像添加焦点轮廓线

如果网站包含大量图像,并且希望在使用键盘浏览器时能够看到图像的焦点位置,则可以给 img 标签添加 outline 属性:

--------- -
  -------- --- ------ -----
-

总结

outline 属性在前端开发中有很多实际用途,例如改变链接被选中时的样式,对键盘焦点进行指示,或给图像添加焦点轮廓线。需要注意的是,outlineborder 之间有很多区别,必须理解这些区别才能正确使用该属性。

来源:JavaScript中文网 ,转载请联系管理员! 本文地址:https://www.javascriptcn.com/post/44224


猜你喜欢

  • npm 包 filepaths 使用教程

    在前端开发中,我们常常需要操作文件路径。有时候需要批量处理一些文件,有时候需要获取某个文件夹下的所有文件名。这时候,npm 包 filepaths 可以帮助我们完成这些任务。

    6 年前
  • npm 包 dirmap 使用教程

    介绍 dirmap 是一个基于 Node.js 的小型工具,可以快速地创建目录结构并生成文件。它可以让前端开发者更好地管理项目的目录结构,提高代码组织和可读性。 本文将详细介绍如何安装使用 dirma...

    6 年前
  • npm 包 jsinspect 使用教程

    简介 jsinspect 是一个基于 Node.js 的工具,用于检测 JavaScript 代码中的重复部分。它可以帮助开发者快速定位代码中可能存在的问题,并提供相应的解决方案。

    6 年前
  • npm 包 codacy-coverage 使用教程

    简介 codacy-coverage 是一个用于测量代码覆盖率的 npm 包,它可以帮助前端开发者更好地了解他们的应用程序代码覆盖情况。codacy-coverage 可以使用不同的代码覆盖率工具来生...

    6 年前
  • npm 包 grunt-sourcemap-localize 使用教程

    简介 grunt-sourcemap-localize 是一个基于 Grunt 构建工具的 npm 包,可以用于本地化 JavaScript 代码的源映射文件。如果你需要在本地化过程中调试和测试 Ja...

    6 年前
  • npm 包 verbal-expressions 使用教程

    在前端开发中,我们常常需要使用正则表达式来匹配或替换字符串。然而,正则表达式语法繁琐复杂,很难记忆和书写。这时,npm 包 verbal-expressions 就可以派上用场了,它能够以一种更加直观...

    6 年前
  • npm 包 silent-npm-registry-client 使用教程

    什么是 silent-npm-registry-client? silent-npm-registry-client 是一个 Node.js 模块,它提供了用于与 npm 注册表进行交互的 API。

    6 年前
  • npm 包 repo-url 使用教程

    在前端开发中,我们经常需要使用 npm 包来扩展我们的项目。但是,在选择要使用的包时,除了查看官方文档和 Github 上的说明之外,我们还可以从 repo-url 中获取更多有价值的信息。

    6 年前
  • npm 包 fs-sync 使用教程

    在 Node.js 中,fs 模块提供了读取和写入文件的基本方法,但是它们都是异步操作。如果你需要同步读取或写入文件,就需要使用第三方模块 fs-sync。 安装 使用 npm 进行安装: --- -...

    6 年前
  • npm 包 tmp-sync 使用教程

    介绍 在前端开发中,临时文件的处理是一个经常需要解决的问题。在 Node.js 中,有一款非常好用的工具包——tmp-sync,它可以帮助我们方便地创建和管理临时文件。

    6 年前
  • npm 包 npm-utils 使用教程

    简介 npm-utils 是一个 Node.js 的包管理工具,可以帮助开发者更方便地管理项目中所需要的各种依赖。它提供了很多的功能和命令,如安装、卸载、更新、搜索等等。

    6 年前
  • npm 包 really-need 使用教程

    前言 在前端开发中,我们使用许多第三方库和工具来加速开发过程。但是每个库都有其依赖项,这些依赖项可能会导致我们的项目变得庞大且不必要。 随着时间的推移,这些依赖可能会变得陈旧或者不再需要。

    6 年前
  • npm 包 changed-log 使用教程

    前言 在开发过程中,项目代码的版本变更是必不可少的。而 changed-log 是一个用于生成项目代码更新日志的工具,通过它可以自动生成每个版本的变更记录文档,并且可以指定输出格式和排序规则。

    6 年前
  • npm 包 ci-publish 使用教程

    介绍 在前端开发中,npm 是一个非常重要的工具,它提供了各种各样的包来帮助我们更加轻松地管理项目依赖。而 ci-publish 则是一个可以将 npm 包发布到 GitHub Packages 或者...

    6 年前
  • npm包hasha使用教程

    前言 在前端开发中,我们经常会需要对一些数据进行哈希操作,比如密码加密、文件校验等。在 Node.js 中,有一个非常好用的哈希工具库,那就是 hasha。本文将介绍 hasha 的基本使用方法以及一...

    6 年前
  • npm 包 twig-loader 使用教程

    简介 Twig 是一种流行的模板引擎,支持在 HTML 中使用变量、流程控制和模板继承等功能。而 Twig-loader 是 Webpack 中用于编译 Twig 模板文件的 npm 包。

    6 年前
  • npm 包 webpack-toolkit 使用教程

    简介 webpack-toolkit 是一个用于辅助 Webpack 配置和管理的 npm 包。它可以帮助前端开发者更轻松地构建、打包和优化项目,提高开发效率。 安装 可以通过以下命令来安装 webp...

    6 年前
  • 使用 Wallaby.js 和 Webpack 的 NPM 包

    在前端开发中,我们经常需要运行大量的测试来确保代码质量。Wallaby.js 是一个可以实时运行 JavaScript 测试的工具,它可以自动编译和运行您的测试,从而使测试更快、更可靠。

    6 年前
  • npm 包 svgo-loader 使用教程

    简介 在前端开发中,我们常常需要优化 SVG 图片以提升页面加载速度和性能。其实,我们可以借助一些工具来自动完成这些任务,其中一个比较好用的工具是 svgo(SVG Optimizer)。

    6 年前
  • npm 包 svg-sprite-loader 使用教程

    如果你正在开发一个前端项目,那么你可能会经常使用 SVG 图标。为了提高性能和可维护性,通常需要将这些 SVG 图标合并成一个 Sprite 表示。 svg-sprite-loader 是一个非常实用...

    6 年前

相关推荐

    暂无文章