[Bootstrap 源码解析]——bootstrap源码之初始化

bootstrap源码之初始化

我们先来分析normalize.less编译后的源码,我们知道normalize.css是一个专门将不同浏览器的默认css特性设置为统一效果的css库,它和reset.css还是有区别的,normalize.css并不是简单的重置了所有的样式,而是有针对的修改,同时也保留了标签的语义化。

1
2
3
4
5
<strong>技能一:</strong><br><br>html {
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;  //防止IOS系统方向改变(特别是手持设备)后字体大小的调整,不禁用用户缩放。
      -ms-text-size-adjust: 100%;
}

  text-size-adjust:auto | none | <percentage>

  检索或设置移动端页面中对象文本的大小调整。

  • 该属性只在移动设备上生效;
  • 如果你的页面没有定义meta viewport,此属性定义将无效;
  • 对应的脚本特性为textSizeAdjust
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<strong>技能二:</strong><br>article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block; //修正IE中未定义的html5块状元素
}

  

1
2
3
4
<strong>技能三:</strong><br>audio:not([controls]) {//否定伪类,匹配所有没有controls属性的audio
  display: none;  //防止现代浏览器显示没有控制条的音频。
  height: 0;  //在iOS5设备中去除多余的高度。
}

  audio 这个标签在移动端是设备会出现多余的高度 在iPhone5上 自动会出现播放控制栏 这个标签的兼容 要重视哦

1
2
3
<strong>技能四:</strong><br>template {//template标签主要用于声明是“模板元素”。
  display: none; //template标签和有hidden属性的元素不显示
}

  

1
2
3
4
<strong>技能五:</strong><br>mark { //部分文本高亮显示,请在需要突出显示文本时使用
  color: #000;
  background: #ff0;
}

  

1
2
3
4
5
6
7
<strong>技能六:</strong><br>sub,
sup { //防止sub sup影响行高
  position: relative;
  font-size: 75%;
  line-height: 0;
  vertical-align: baseline;
}

  

1
2
3
<strong>技能七:</strong><br>svg:not(:root) {//非根目录的svg标签
  overflow: hidden;
}

  

1
2
3
4
<strong>技能八:</strong><br>input::-moz-focus-inner { //删除在火狐浏览器4及以上中的按钮的内部填充和边框
  padding: 0;
  border: 0;
}

  

1
2
3
4
5
<strong>技能九:</strong><br>fieldset {//将表单内的相关元素分组。
  padding: .35em .625em .75em;
  margin: 0 2px;
  border: 1px solid #c0c0c0;
}

  

1
2
3
<strong>技能十:</strong><br>optgroup {//用于把相关的选项组合在一起。
  font-weight: bold;
}

还是贴一份源码出来 这样大家阅读文章的时候,顺便吧源码给读了

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */
 
//
// 1. Set default font family to sans-serif.
// 2. Prevent iOS and IE text size adjust after device orientation change,
//    without disabling user zoom.
//
 
html {
  font-family: sans-serif; // 1
  -ms-text-size-adjust: 100%; // 2
  -webkit-text-size-adjust: 100%; // 2
}
 
//
// Remove default margin.
//
 
body {
  margin: 0;
}
 
// HTML5 display definitions
// ==========================================================================
 
//
// Correct `block` display not defined for any HTML5 element in IE 8/9.
// Correct `block` display not defined for `details` or `summary` in IE 10/11
// and Firefox.
// Correct `block` display not defined for `main` in IE 11.
//
 
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}
 
//
// 1. Correct `inline-block` display not defined in IE 8/9.
// 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
//
 
audio,
canvas,
progress,
video {
  display: inline-block; // 1
  vertical-align: baseline; // 2
}
 
//
// Prevent modern browsers from displaying `audio` without controls.
// Remove excess height in iOS 5 devices.
//
 
audio:not([controls]) {
  display: none;
  height: 0;
}
 
//
// Address `[hidden]` styling not present in IE 8/9/10.
// Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
//
 
[hidden],
template {
  display: none;
}
 
// Links
// ==========================================================================
 
//
// Remove the gray background color from active links in IE 10.
//
 
a {
  background-color: transparent;
}
 
//
// Improve readability of focused elements when they are also in an
// active/hover state.
//
 
a:active,
a:hover {
  outline: 0;
}
 
// Text-level semantics
// ==========================================================================
 
//
// Address styling not present in IE 8/9/10/11, Safari, and Chrome.
//
 
abbr[title] {
  border-bottom: 1px dotted;
}
 
//
// Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
//
 
b,
strong {
  font-weight: bold;
}
 
//
// Address styling not present in Safari and Chrome.
//
 
dfn {
  font-style: italic;
}
 
//
// Address variable `h1` font-size and margin within `section` and `article`
// contexts in Firefox 4+, Safari, and Chrome.
//
 
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
 
//
// Address styling not present in IE 8/9.
//
 
mark {
  background: #ff0;
  color: #000;
}
 
//
// Address inconsistent and variable font size in all browsers.
//
 
small {
  font-size: 80%;
}
 
//
// Prevent `sub` and `sup` affecting `line-height` in all browsers.
//
 
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
 
sup {
  top: -0.5em;
}
 
sub {
  bottom: -0.25em;
}
 
// Embedded content
// ==========================================================================
 
//
// Remove border when inside `a` element in IE 8/9/10.
//
 
img {
  border: 0;
}
 
//
// Correct overflow not hidden in IE 9/10/11.
//
 
svg:not(:root) {
  overflow: hidden;
}
 
// Grouping content
// ==========================================================================
 
//
// Address margin not present in IE 8/9 and Safari.
//
 
figure {
  margin: 1em 40px;
}
 
//
// Address differences between Firefox and other browsers.
//
 
hr {
  box-sizing: content-box;
  height: 0;
}
 
//
// Contain overflow in all browsers.
//
 
pre {
  overflow: auto;
}
 
//
// Address odd `em`-unit font size rendering in all browsers.
//
 
code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
 
// Forms
// ==========================================================================
 
//
// Known limitation: by default, Chrome and Safari on OS X allow very limited
// styling of `select`, unless a `border` property is set.
//
 
//
// 1. Correct color not being inherited.
//    Known issue: affects color of disabled elements.
// 2. Correct font properties not being inherited.
// 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
//
 
button,
input,
optgroup,
select,
textarea {
  color: inherit; // 1
  font: inherit; // 2
  margin: 0; // 3
}
 
//
// Address `overflow` set to `hidden` in IE 8/9/10/11.
//
 
button {
  overflow: visible;
}
 
//
// Address inconsistent `text-transform` inheritance for `button` and `select`.
// All other form control elements do not inherit `text-transform` values.
// Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
// Correct `select` style inheritance in Firefox.
//
 
button,
select {
  text-transform: none;
}
 
//
// 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
//    and `video` controls.
// 2. Correct inability to style clickable `input` types in iOS.
// 3. Improve usability and consistency of cursor style between image-type
//    `input` and others.
//
 
button,
html input[type="button"], // 1
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button; // 2
  cursor: pointer; // 3
}
 
//
// Re-set default cursor for disabled elements.
//
 
button[disabled],
html input[disabled] {
  cursor: default;
}
 
//
// Remove inner padding and border in Firefox 4+.
//
 
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
 
//
// Address Firefox 4+ setting `line-height` on `input` using `!important` in
// the UA stylesheet.
//
 
input {
  line-height: normal;
}
 
//
// It's recommended that you don't attempt to style these elements.
// Firefox's implementation doesn't respect box-sizing, padding, or width.
//
// 1. Address box sizing set to `content-box` in IE 8/9/10.
// 2. Remove excess padding in IE 8/9/10.
//
 
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box; // 1
  padding: 0; // 2
}
 
//
// Fix the cursor style for Chrome's increment/decrement buttons. For certain
// `font-size` values of the `input`, it causes the cursor style of the
// decrement button to change from `default` to `text`.
//
 
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
 
//
// 1. Address `appearance` set to `searchfield` in Safari and Chrome.
// 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
//
 
input[type="search"] {
  -webkit-appearance: textfield; // 1
  box-sizing: content-box; //2
}
 
//
// Remove inner padding and search cancel button in Safari and Chrome on OS X.
// Safari (but not Chrome) clips the cancel button when the search input has
// padding (and `textfield` appearance).
//
 
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
 
//
// Define consistent border, margin, and padding.
//
 
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}
 
//
// 1. Correct `color` not being inherited in IE 8/9/10/11.
// 2. Remove padding so people aren't caught out if they zero out fieldsets.
//
 
legend {
  border: 0; // 1
  padding: 0; // 2
}
 
//
// Remove default vertical scrollbar in IE 8/9/10/11.
//
 
textarea {
  overflow: auto;
}
 
//
// Don't inherit the `font-weight` (applied by a rule above).
// NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
//
 
optgroup {
  font-weight: bold;
}
 
// Tables
// ==========================================================================
 
//
// Remove most spacing between table cells.
//
 
table {
  border-collapse: collapse;
  border-spacing: 0;
}
 
td,
th {
  padding: 0;
}

  

 后言:

作者的注释已经写得很好了,我只是摘抄翻译了几个 ,你觉得还有很不错的,欢迎评论走起

本人最近一直在阅读bootstrap的源码,发现更多好玩的分享后期分享给大家。这也是给自己的一分笔记,毕竟我读过嘛~

posted @   FannieGirl  阅读(1484)  评论(0编辑  收藏  举报
编辑推荐:
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
点击右上角即可分享
微信分享提示