重置(Reboot)
针对单一文件内CSS的特定元素重置样式,重置以便Bootstrap准确且一致的建立样式。
方法
重置建立在Normalize的基础上,仅使用元素选择器来为许多HTML元素提供自定义的样式。附加样式仅能利用class建立。例如,我们重置<table>
的一些样式让它更简化,以利套用.table、.table-bordered及其他类别。
以下是Bootstrap重置元件的规范和原因:
- 更新部分浏览器的预设值,在可变动的元件间距上使用rem替代em。
- 避开使用margin-top。垂直边界的margins可能会重叠,进而产生不能预期的结果。更重要的是,使用单向的margin是一个更单纯的思考模式。
- 为便于跨设备大小进行缩放,块元素应使用rems作为边距。
- 尽量减少字体相关属性的声明,尽可能使用inherit。
页面默认值
为了提供更好的整体页面预设值而更新和元素。具体而言:
- 在每个元素上设定全局性的box-sizing,包括*::before和*::after,将它们设为border-box。这确保元素不会因为padding或border超过元素声明的宽度数值。
-
不在
<html>
上声明基础的font-size,而是假定字体尺寸为16px(浏览器预设)。font-size: 1rem被应用在上,以利透过media queries做响应式缩放,同时尊重使用者的喜好。可以通过修改$font-size-root变量来覆盖此浏览器的预设值。
-
不在
-
<body>
设定了全局的font-family、font-weight、line-height及color,让随后的元素可以继承此格式以防止字体不一致。 - 为了安全起见,
<body>
已声明background-color,预设为#fff。
原生字体堆栈
Bootstrap利用“native font stack”或“system font stack”在每个设备和操作系统上获得最佳的阅读呈现。这些系统字体是特别为现今设备所设计的,具备更好的屏幕渲染、多元的文字支持以及更多。在此Smashing Magazine文章中了解更多有关原生字体堆叠的信息。 native font stacks in this.
$font-family-sans-serif:
// Cross-platform generic font family (default user interface font)
system-ui,
// Safari for macOS and iOS (San Francisco)
-apple-system,
// Chrome < 56 for macOS (San Francisco)
BlinkMacSystemFont,
// Windows
"Segoe UI",
// Android
Roboto,
// Basic web fallback
"Helvetica Neue", Arial,
// Linux
"Noto Sans",
"Liberation Sans",
// Sans serif fallback
sans-serif,
// Emoji fonts
"Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji" !default;
请注意,由于字体堆栈包含emoji字体,因此许多常见的symbol/dingbat unicode字符将呈现为多色象形文字。它们的外观会有所不同,这取决于浏览器/平台本机emoji字体中使用的样式,并且它们不会受到任何CSS颜色样式的影响。
此字体系列应用于 <body>
并在整个Bootstrap中自动全局继承。要切换全局字体系列,请更新$font family base并重新编译Bootstrap程序。
标题和段落
所有标题元素(例如, <h1>
—and <p>
)都被重置为删除其边距顶部。标题有
margin-bottom: .5rem
,段落margin-bottom: 1rem
以便于间距。
Heading | Example |
---|---|
<h1></h1>
|
h1. Bootstrap heading |
<h2></h2>
|
h2. Bootstrap heading |
<h3></h3>
|
h3. Bootstrap heading |
<h4></h4>
|
h4. Bootstrap heading |
<h5></h5>
|
h5. Bootstrap heading |
<h6></h6>
|
h6. Bootstrap heading |
列表
所有列表-<ul>
, <ol>
, and
<dl>
-都删除了它们的margin-top
和 margin-bottom: 1rem
。嵌套列表没有页边距底部。我们还重置了<ul>
and
<ol>
元素的padding-left
。
- 所有列表的上边距都已删除
- 他们的底边正常化了
- 嵌套列表没有下边距
- 这样他们的外表就更匀称了
- 尤其是后面有更多的列表项时
- 左侧填充也已重置
- 这是一份有序的清单
- 有几个列表项
- 它有相同的整体外观
- 与前一个无序列表相同
为了更简单的样式、清晰的层次结构和更好的间距,描述列表更新了边距,<dd>
将左边边距重置为0,并在底部添加边距margin-bottom: .5rem
,<dt>
以粗体显示。
- 描述列表
- 描述列表非常适合定义术语。
- 术语
- 术语的定义。
- 同一术语的第二个定义。
- 其他术语
- 其他术语的定义。
内联代码
Wrap inline snippets of code with <code>
. Be sure to escape HTML angle brackets.
用<code>
包装内联代码段。确保转义HTML尖括号。
<section>
应包装为内联代码。
例如, <code><section></code> 应包装为内联代码。
代码块
<pre>
用于多行的代码。再提醒一次,确保在代码中转义任何尖括号,以便正确渲染。<pre>
移除margin-top以及使用rem作为margin-bottom的单位。
<p>此处为示例文本...</p>
<p>这里还有一行示例文本...</p>
<pre><code><p>此处为示例文本...</p>
<p>这里还有一行示例文本...</p>
</code></pre>
变量
使用<var>
标签来指定变量。
<var>y</var> = <var>m</var><var>x</var> + <var>b</var>
用户输入
使用<kbd>
标签来表示通过键盘输入的指令。
要编辑设置,请按 ctrl + ,
要切换目录,请键入 <kbd>cd</kbd> ,后跟目录名。<br>
要编辑设置,请按 <kbd><kbd>ctrl</kbd> + <kbd>,</kbd></kbd>
实例输出
使用 <samp>
标签来表示由程序输出的实例。
<samp>This text is meant to be treated as sample output from a computer program.</samp>
表格
微调整表格中的<caption>
样式,合并边框,并确保整体的text-align是一致的。针对borders、padding以及更多的其他变化将通过.table类别达成。
Table heading | Table heading | Table heading | Table heading |
---|---|---|---|
Table cell | Table cell | Table cell | Table cell |
Table cell | Table cell | Table cell | Table cell |
Table cell | Table cell | Table cell | Table cell |
表单
不同的表单元素已被重置为更简洁的基本样式。如下式变化最为显著的部分:
<fieldset>
没有borders、padding或margin以便包覆独立的input或input群组。<legend>
如同fieldset,已被重新定义样式用来显示分类的标题。<label>
被设定为display: inline-block以便让margin可以应用。<input>
s,<select>
s,<textarea>
s, and<button>
s 主要由Normalize处理,不过Reboot移除了它们的margin并设定line-height: inherit
。<textarea>
s修改为仅可调整垂直尺寸,因为水平调整大小通常会“破坏”页面布局。- 当
<button>
和<input>
按钮元素状态为:not(:disabled),会呈现cursor: pointer
。
更多的变化都在下方进行展示。
Date & color input support
Keep in mind date inputs are not fully supported by all browsers, namely Safari.
按钮上的指针
重置增加role="button"
将预设光标改为pointer。此属性添加到元素上用来辅助指示元素是可以互动的。button原先就具有cursor的变化,所以这个不是必须的。
<span role="button" tabindex="0">Non-button element button</span>
其他元素
地址
<address>
元素重置浏览器的预设font-style,由italic转为normal。line-height现在也可以继承属性,另外增加margin-bottom:
1rem。<address>
用来表示作者(或是产品主体)的联络信息。使用<br>
保留结束行的格式。
1355 Market St, Suite 900
San Francisco, CA 94103
P: (123) 456-7890 Full Name
first.last@example.com
引用
blockquotes上的默认边距是1em 40px,因此我们将其重置为0 0 1rem
,以便与其他元素更加一致。
A well-known quote, contained in a blockquote element.
Someone famous in Source Title
内联元素
<abbr>
元素的基本样式让它与段落文字之间有明显突出。
摘要
summary的预设cursor是text,所以我们将其重置为pointer,元素可以透过点击产生互动性。
Some details
More info about the details.
Even more details
Here are even more details about the details.
HTML5隐藏属性
HTML5新增一个新的全局属性[hidden]
,预设样式为display:
none。我们从PureCSS获得的想法,改良为[hidden] { display: none !important; }
以预防display被意外覆盖。
<input type="text" hidden>
jQuery 的不相容性
[hidden]
is not compatible with jQuery’s $(...).hide()
and
$(...).show()
methods. Therefore, we don’t currently especially endorse [hidden]
over other techniques for
managing
the display
of elements.
[hidden]与jQuery的$(...).hide()
and
$(...).show()
方法不兼容。因此,我们现在不特别推崇使用[hidden]技术来处理元素的display。
仅仅切换元素的visibility,代表display并没有被修改,元素还是会影响网页流动,因此可以使用.invisible
类取代。