虎说:bootstrap源码解读(重置模块)
------<!--action-->------
开场show:前不生“不犹豫”,后半生“不后悔”。今天又逃课,我不后悔
素材:推特公司的前端框架bootstrap(下称bt),解读源码(当然你也可以在官网分分钟下载一个源码包应用学习)
介绍:不介绍,著名的流行的框架,总有一大推的介绍
思考(或许会打自己脸):bt给我的感觉就像是人家写好的模板,虽然是顶级公司写的,但总感觉很别扭,就像厨师使用的是大师配置好,现成的高汤,料汁,只是在应用层。优秀的前端不应该自己配置调料吗,最好的办法,就是偷学,偷学,手里拿到人家不外传的菜品祖传秘制蜜汁,品尝分析,之后自成一派,成为人生赢家(有没有人家的感受),当然这是在厨师界,秘制不外传。
理解毕竟是关乎吃饭的家伙事,被人学会怎么办,在前端,风气不一样,就讲究开源,所以咱赚了,把bt当成一个学习的途径,品尝大牛配置的汤料,阅读优秀的代码,是happy的,废话讲完....
------<!--片头-->------
本文由:小老虎中午喝的蛋花汤,
电脑旁5cm长铅笔,
bt还有normalize赞助

bt的重置模块直接使用的是normalize(他是什么?一个优秀的浏览器默认样式重置组件也好,文件也好)
如果你有兴趣,直接搜索在文件中引入,或者使用sass和compass更加灵活运用它,说起compass就不得不提reset和normalize的关系(这里埋下伏笔)
使用bt做项目,既会引入normalize,他是嵌入在bt文件中的,在源码开头即可见
这里可能会出现代码冗余的现象,也就是说,有些重置并不需要,你也可以修改源代码,除了这个没有其他更好的方法
我在这里对compass的reset模块,和本文主角进行些许对比
重置宗旨“保证所有浏览器的统一”
1.normalize有(下称nm)
| 页面重置组 | block组 | inline-block组 | 文字格式化组 | 表单重置组 | 表格重置组 |
2.reset有(下称rs)
| 去边距组 | 去文字样式组 | block组 | 去边框组 |
整体模块:
nm对body和html进行了边距,字体,字号,行高的重置
疑惑:其中定义html字号为10号,body字号定义为14号,明显页面中的字号会继承body的,于是html的字号等于多余(个人之见)
在测试中也是如此,改变html的字号,并不会对页面中的文字产生影响()
html {
font-size: 10px; /*是不是10px,无意义*/
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
font-family: sans-serif; /*无意义*/
}
body {
font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
font-size: 14px; /*是不是14px,继承者的爸爸*/
line-height: 1.42857143;
color: #333;
background-color: #fff;
}
页面中的文字会继承那个呢,请看大屏幕

------------------分隔线--------------------

疑问:正常情况下,会禁用body的字号吗,或许是nm维护者设置的第二道防线
说明:这里html{font-size:10px}设置无意义,
还有html的字体设置{font-falimy:sans-serif;}也无意义,我真的想不出哪里有应用场景
-------<!--尿点-->------
block组:
你说html标签中有哪些是display:block(块级元素)的,div是不是,p是不是,ul ol dl是不是,都是!!然而新元素呢
div在浏览器中,默认是block,浏览器自动添加,看下面的大屏幕,
咱啥都没有干,只在html中添加div还有header,article(没有样式表)
在firebug中发现


神奇:居然自动添加显示属性,里外呼应,正好
于是又出现疑问:既然浏览器会自动默认这些元素为block显示属性,为什么需要再加上去能呢,代码又冗余
article,aside,details,figcaption,figure,footer,header,main,nav,section,summary {display: block;}/*源码*/
再看上面的源码就会发现,有增无减,多了三四个标签,也许这就是需要加上去的理由
再说:列表中的标签大多不需要更改display值,所以为了加强强度,和保证浏览器的统一性,加上了这句话
------<!--尿点-->------
inline-block组:
是啥?摆明了是不想兼容ie6,7,啥,那俩玩意儿连video都不支持,好吧,看来他已经被抛弃
需要ie6 7这俩古董兼容inline-block的话,是这样写的
{display:inline-block;
*display:inline;
*zoom:1;}
而nm是这样的
audio,canvas,progress,video {display: inline-block;vertical-align: baseline;}
所以,国外就是好,把时间放在更好的属性研究上面
疑问:为什么没有inline组呢,难道是看不起内联样式?
OH,别烦我好吗(待研究)
------<!--尿点-->------
文字格式化组:
并没有说头,个人喜好,随意定制,
原谅我这一生不羁放纵爱自由
表单重置组:
这里只对基本的属性做了重置,看了半天,也说不出一个花来,行高,边距
对不同属性框的重置,搜索框,数字框,单选框,复选框
如果你想有更深的体会的话,还是自行下载bootstrap源代码学习,并且他完全不要钱
表格重置组:
表格的使用场景,布局,数据,反正我就只试过这两个用途
说起布局,我就想到使用表格做表单的布局,说起来有点绕,但是以前有小伙伴说,为了语义化,所以不使用table做表格布局,我当然同意
不过表格输入框这种等于是小布局,就算是使用语义化,也没有适合的标签可以使用
见得最多的是使用div ul ol dl做表单的布局
看大屏幕:

网易注册页,表单使用的是dl,壮观,如果使用table布局呢,我就说,有一次我还用了呢
咱大汽车之家

壮观的tr,不管怎么样,咱之家还是年收入过亿
(以后深入探讨使用table做表单布局)
------<!--没有尿点 end-->------
尾部:normalize是一个好东西,bootstrap也是好东西(词穷)
申明:本文中的观点只是博主的观点,不代表博客园的以及其他大神的见解,
如果有疏漏那也是正常的,欢迎各行业大神
前来交流辩驳!
虎说:bootstrap源码解读(重置模块)的更多相关文章
- Bootstrap源码解读之栅格化篇
本文纯属自己研究所写笔记,如果有错误还请多多指教提出 版心(container) 版心:class名为.container的容器,其版心的宽度在各个屏幕设备下是不一样的值,版心两边就是留白. 各尺寸下 ...
- Webpack探索【16】--- 懒加载构建原理详解(模块如何被组建&如何加载)&源码解读
本文主要说明Webpack懒加载构建和加载的原理,对构建后的源码进行分析. 一 说明 本文以一个简单的示例,通过对构建好的bundle.js源码进行分析,说明Webpack懒加载构建原理. 本文使用的 ...
- Webpack探索【15】--- 基础构建原理详解(模块如何被组建&如何加载)&源码解读
本文主要说明Webpack模块构建和加载的原理,对构建后的源码进行分析. 一 说明 本文以一个简单的示例,通过对构建好的bundle.js源码进行分析,说明Webpack的基础构建原理. 本文使用的W ...
- Abp 审计模块源码解读
Abp 审计模块源码解读 Abp 框架为我们自带了审计日志功能,审计日志可以方便地查看每次请求接口所耗的时间,能够帮助我们快速定位到某些性能有问题的接口.除此之外,审计日志信息还包含有每次调用接口时客 ...
- Normalize.css 介绍与源码解读
开始 Normalize.css 是一个可定制的 CSS 文件,使浏览器呈现的所有元素,更一致和符合现代标准;是在现代浏览器环境下对于CSS reset的替代. 它正是针对只需要统一的元素样式.该项目 ...
- etcd学习(6)-etcd实现raft源码解读
etcd中raft实现源码解读 前言 raft实现 看下etcd中的raftexample newRaftNode startRaft serveChannels 领导者选举 启动并初始化node节点 ...
- Vue 源码解读(8)—— 编译器 之 解析(上)
特殊说明 由于文章篇幅限制,所以将 Vue 源码解读(8)-- 编译器 之 解析 拆成了上下两篇,所以在阅读本篇文章时请同时打开 Vue 源码解读(8)-- 编译器 之 解析(下)一起阅读. 前言 V ...
- SDWebImage源码解读之SDWebImageDownloaderOperation
第七篇 前言 本篇文章主要讲解下载操作的相关知识,SDWebImageDownloaderOperation的主要任务是把一张图片从服务器下载到内存中.下载数据并不难,如何对下载这一系列的任务进行设计 ...
- AFNetworking 3.0 源码解读(一)之 AFNetworkReachabilityManager
做ios开发,AFNetworking 这个网络框架肯定都非常熟悉,也许我们平时只使用了它的部分功能,而且我们对它的实现原理并不是很清楚,就好像总是有一团迷雾在眼前一样. 接下来我们就非常详细的来读一 ...
随机推荐
- J2SE知识点摘记(二十三)
我们简单介绍一下这个接口: 1.4.3 Comparable 接口 在 java.lang 包中,Comparable 接口适用于一个类有自然顺序的时候.假定对象集合是同一类型,该接口允 ...
- N沟道和P沟道MOS FET开关电路
在电路中常见到使用MOS FET场效应管作为开关管使用.下面举例进行说明. 如图1所示,使用了P沟道的内置二极管的电路,此处二极管的主要作用是续流作用,电路是Li电池充放电电路,当外部电源断开时采用L ...
- VC中利用多线程技术实现线程之间的通信
当前流行的Windows操作系统能同时运行几个程序(独立运行的程序又称之为进程),对于同一个程序,它又可以分成若干个独立的执行流,我们称之为线程,线程提供了多任务处理的能力.用进程和线程的观点来研究软 ...
- C语言 linux环境基于socket的简易即时通信程序
转载请注明出处:http://www.cnblogs.com/kevince/p/3891033.html ——By Kevince 最近在看linux网络编程相关,现学现卖,就写了一个简易 ...
- JAVA集合LIST MAP SET详解
1. 集合框架介绍 我们知道,计算机的优势在于处理大量的数据,在编程开发中,为处理大量的数据,必须具备相应的存储结构,之前学习的数组可以用来存储并处理大量类型相同的数据,但是通过上面的课后练习,会发现 ...
- ubuntu13.04安装SenchaArchitect-2.2无法启动的问题
系统是ubuntukylin-13.04-desktop版本,不知道别的版本有没有这个问题,未测试.SenchaArchitect采用最新版本2.2.2,我安装的是32位的. 具体无法启动的问题如下: ...
- cocos2d-x 3.0rc2 对于每个包执行情况的重要平台 (超级方便)
首先,你需要下载三个文件:每间 android-ndk android-sdk ant 下载位置可以随意:由于3.0rc2执行setup.py 自己主动搜索这三个文件 win32cmd以下: (1) ...
- ItextSharp代码示例
示例代码目录 示例代码0101. 5 示例代码0102. 7 示例代码0103. 9 示例代码0104. 11 示例代码0105. 13 示例代码0106. 15 示例代码0107. 17 示例代码0 ...
- <学习>.NET的反射基础
关键词 Assembly 使用Assembly定义和加载程序集,加载在程序集清单中列出模块,以及从此程序集中查找类型并创建该类型的实例. Module 通过它可以获取包含模块的程序集以及模块中的类等, ...
- oracle 提示口令失效解决方法
Oracle错误代码:ORA-28002. 受影响版本:Oracle11g以上版本. 导致密码消失的原因:Oracle 11g中默认的DEFAULT概要文件中口令有效期PASSWORD_LIFE_TI ...