20180820 bootstrap學(xué)習(xí)筆記

Bootstrap簡(jiǎn)介

基本了解

Bootstrap是由Mark Otto和Jacob Thornton合作完成的,基于HTML、CSS剩晴、JavaScript的基礎(chǔ)上開(kāi)發(fā)的前端開(kāi)發(fā)框架牢裳,具有簡(jiǎn)潔、直觀犀农、強(qiáng)悍的優(yōu)點(diǎn),使Web開(kāi)發(fā)更加快捷宰掉。
Bootstrap由動(dòng)態(tài)css語(yǔ)言less寫成呵哨,個(gè)人理解是將常用的一些樣式打包成一些類,在需要使用的時(shí)候轨奄,直接調(diào)用相應(yīng)的類孟害,就可以達(dá)到預(yù)期的樣式形式,不用利用組件和js進(jìn)行進(jìn)一步的組合封裝挪拟。

Bootstrap包含內(nèi)容

基本結(jié)構(gòu):Bootstrap 提供了一個(gè)帶有網(wǎng)格系統(tǒng)挨务、鏈接樣式、背景的基本結(jié)構(gòu)。
CSS:Bootstrap 自帶以下特性:全局的 CSS設(shè)置谎柄、定義基本的 HTML 元素樣式丁侄、可擴(kuò)展的 class,以及一個(gè)先進(jìn)的網(wǎng)格系統(tǒng)朝巫。
組件:Bootstrap 包含了十幾個(gè)可重用的組件鸿摇,用于創(chuàng)建圖像、下拉菜單劈猿、導(dǎo)航拙吉、警告框、彈出框等等揪荣。
JavaScript 插件:Bootstrap包含了十幾個(gè)自定義的jQuery 插件筷黔。您可以直接包含所有的插件,也可以逐個(gè)包含這些插件仗颈。
定制:您可以定制Bootstrap的組件佛舱、LESS 變量和jQuery 插件來(lái)得到您自己的版本。
——百度百科

Bootstrap特點(diǎn)

  1. 移動(dòng)設(shè)備優(yōu)先揽乱,然后才是桌面設(shè)備名眉,框架包含了貫串與整個(gè)庫(kù)的移動(dòng)設(shè)備優(yōu)先的樣式
  2. 響應(yīng)式設(shè)計(jì),能夠自適應(yīng)于臺(tái)式機(jī)凰棉、平板電腦损拢、手機(jī),確保了適當(dāng)?shù)睦L制和觸屏縮放撒犀,同時(shí)可以設(shè)置禁止縮放功能福压,使網(wǎng)站看上去感覺(jué)更像原生應(yīng)用
  3. 包含了功能強(qiáng)大的內(nèi)置組件,易于定制
  4. 它是開(kāi)源的

Bootstrap瀏覽器/設(shè)備支持

| | Chrome | Firefox | IE | Opera | Safari |
| :---------|
| Android | YES | YES | 不適用 | 不適用 | 不適用 |
| IOS | YES | 不適用 | 不適用 | 不適用 | YES |
| Mac OS X | YES | YES | 不適用 | YES | YES |
| Windows | YES | YES | YES | YES | 不適用 |

學(xué)習(xí)筆記

或舞!DOCTYPE必要

Bootstrap使用了一些HTMl5元素和CSS屬性荆姆,因此為了讓這些元素和屬性正常工作,必須保證在使用Bootstrap項(xiàng)目的開(kāi)頭包含<!DOCTYPE html>
以下是Bootstrap手冊(cè)上給出的一份HTML的基本模板映凳,之后網(wǎng)頁(yè)新增的內(nèi)容只要在這份模板的基礎(chǔ)上進(jìn)行增刪基本就可以實(shí)現(xiàn)了

<!DOCTYPE html>
<html lang="zh-CN">
  <head>
    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 上述3個(gè)meta標(biāo)簽*必須*放在最前面胆筒,任何其他內(nèi)容都*必須*跟隨其后! -->
    <title>Bootstrap 101 Template</title>

    <!-- Bootstrap -->
    <link  rel="stylesheet">

    <!-- HTML5 shim 和 Respond.js 是為了讓 IE8 支持 HTML5 元素和媒體查詢(media queries)功能 -->
    <!-- 警告:通過(guò) file:// 協(xié)議(就是直接將 html 頁(yè)面拖拽到瀏覽器中)訪問(wèn)頁(yè)面時(shí) Respond.js 不起作用 -->
    <!--[if lt IE 9]>
      <script src="https://cdn.bootcss.com/html5shiv/3.7.3/html5shiv.min.js"></script>
      <script src="https://cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
    <![endif]-->
  </head>
  <body>
    <h1>你好诈豌,世界仆救!</h1>

    <!-- jQuery (Bootstrap 的所有 JavaScript 插件都依賴 jQuery,所以必須放在前邊) -->
    <script src="https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
    <!-- 加載 Bootstrap 的所有 JavaScript 插件矫渔。你也可以根據(jù)需要只加載單個(gè)插件彤蔽。 -->
    <script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
  </body>
</html>

如果在Bootstrap創(chuàng)建的網(wǎng)頁(yè)開(kāi)頭不使用<!DOCTYPE html>,可能將導(dǎo)致一些瀏覽器顯示不一致的問(wèn)題

移動(dòng)設(shè)備優(yōu)先

上面說(shuō)過(guò)Bootstrap是對(duì)移動(dòng)設(shè)備優(yōu)先的庙洼,因此為了讓Vootstrap開(kāi)發(fā)的網(wǎng)站對(duì)移動(dòng)設(shè)備更友好顿痪,確保適當(dāng)?shù)睦L制和觸屏縮放是有必要的镊辕,因此最好在網(wǎng)頁(yè)的head之中添加viewport meta標(biāo)簽
<meta name="viewport" content="width=device-width, initial-scale=1.0">
device-width保證網(wǎng)頁(yè)能在帶有不同屏幕分辨率的設(shè)備下仍然能呈現(xiàn)出預(yù)想的格式
initial-scale=1.0是讓網(wǎng)頁(yè)以1:1的比例呈現(xiàn),不會(huì)有任何的縮放
另外可以通過(guò)為viewport meta標(biāo)簽添加user-scalable=no來(lái)禁止其縮放功能

網(wǎng)格系統(tǒng)

Bootstrap提供了一套響應(yīng)式蚁袭、移動(dòng)設(shè)備優(yōu)先的流式網(wǎng)格系統(tǒng)征懈,隨著屏幕或viewport尺寸的增加,系統(tǒng)會(huì)自動(dòng)分為最多12列
在查看相關(guān)資料后揩悄,個(gè)人認(rèn)為網(wǎng)格系統(tǒng)就類似以前用過(guò)的方塊本受裹,將一頁(yè)紙豎向分為幾塊,最多12塊虏束,所有長(zhǎng)度的判定都是在頁(yè)面分為12格之后,再根據(jù)相應(yīng)的需求進(jìn)行合并


1.png

下表總結(jié)了Bootstrap網(wǎng)格系統(tǒng)如何跨多個(gè)設(shè)備工作


2.png

下圖是我根據(jù)菜鳥(niǎo)教程中的學(xué)習(xí)進(jìn)行實(shí)踐的結(jié)果


3.png
注意事項(xiàng)

行必須放置在 .container class 內(nèi)厦章,以便獲得適當(dāng)?shù)膶?duì)齊(alignment)和內(nèi)邊距(padding)镇匀。
使用行來(lái)創(chuàng)建列的水平組。
內(nèi)容應(yīng)該放置在列內(nèi)袜啃,且唯有列可以是行的直接子元素汗侵。
預(yù)定義的網(wǎng)格類,比如 .row 和 .col-xs-4群发,可用于快速創(chuàng)建網(wǎng)格布局晰韵。LESS 混合類可用于更多語(yǔ)義布局。
列通過(guò)內(nèi)邊距(padding)來(lái)創(chuàng)建列內(nèi)容之間的間隙熟妓。該內(nèi)邊距是通過(guò) .rows 上的外邊距(margin)取負(fù)雪猪,表示第一列和最后一列的行偏移。
網(wǎng)格系統(tǒng)是通過(guò)指定您想要橫跨的十二個(gè)可用的列來(lái)創(chuàng)建的起愈。例如只恨,要?jiǎng)?chuàng)建三個(gè)相等的列,則使用三個(gè) .col-xs-4

強(qiáng)調(diào)

類似html抬虽,bootstrap將文本的一些常用的樣式打包成一個(gè)個(gè)類官觅,調(diào)用這個(gè)類時(shí)就會(huì)出現(xiàn)相應(yīng)的形式,而html中是需要通過(guò)<strong><em>等標(biāo)簽來(lái)進(jìn)行修改表現(xiàn)形式
下圖是我進(jìn)行嘗試時(shí)創(chuàng)建的html

4.png

圖中比較不明顯阐污,但實(shí)際上可以比較明顯的感覺(jué)到container是一個(gè)居中的盒子休涤,來(lái)自bootstrap的container帶了自己的光環(huán),而像html里的盒子模型笛辟,都是需要自己自動(dòng)設(shè)置margin功氨、padding來(lái)使這個(gè)盒子居中

引用

下圖是菜鳥(niǎo)教程中的示例圖


5.png

這個(gè)示例中采用了html的三個(gè)標(biāo)簽,<blockquote><small><cite>
其中<cite>標(biāo)簽是我平時(shí)不常用的隘膘,所以去網(wǎng)上找了一些關(guān)于它的資料

<cite> 標(biāo)簽通常表示它所包含的文本對(duì)某個(gè)參考文獻(xiàn)的引用疑故,比如書籍或者雜志的標(biāo)題。
按照慣例弯菊,引用的文本將以斜體顯示纵势。
<cite>標(biāo)簽把指向其他文檔的引用分離出來(lái)踱阿,尤其是分離那些傳統(tǒng)媒體中的文檔,如書籍钦铁、雜志软舌、期刊,等等牛曹。如果引用的這些文檔有聯(lián)機(jī)版本佛点,還應(yīng)該把引用包括在一個(gè)<a> 標(biāo)簽中,從而把一個(gè)超鏈接指向該聯(lián)機(jī)版本黎比。
<cite> 標(biāo)簽還有一個(gè)隱藏的功能:它可以使你或者其他人從文檔中自動(dòng)摘錄參考書目超营。我們可以很容易地想象一個(gè)瀏覽器,它能夠自動(dòng)整理引用表格阅虫,并把它們作為腳注或者獨(dú)立的文檔來(lái)顯示演闭。<cite> 標(biāo)簽的語(yǔ)義已經(jīng)遠(yuǎn)遠(yuǎn)超過(guò)了改變它所包含的文本外觀的作用;它使瀏覽器能夠以各種實(shí)用的方式來(lái)向用戶表達(dá)文檔的內(nèi)容颓帝。

另外米碰,在這個(gè)例子中值得注意的是,這個(gè)引用示例中引用的bootstrap的類是pull-right购城,表示向右對(duì)齊吕座,一般的引用在沒(méi)有聲明```class="pull-right"時(shí)統(tǒng)一向左對(duì)齊

列表

列表部分大致上和html相似,<ol><ul>分別表示有序列表和無(wú)序列表瘪板,列表內(nèi)容前用<li>表示塊級(jí)吴趴,自動(dòng)換行
在這一部分里,比較不同的是<dt><dl><dd>這三個(gè)標(biāo)簽篷帅,<dl>是最外層的包裹史侣,表示定義列表,<dt>代表定義術(shù)語(yǔ)魏身,表示自主定義列表的每一個(gè)主分支點(diǎn)的名字惊橱,<dd>相應(yīng)的表示分支點(diǎn)的內(nèi)容
在列表這一部分的包裝類有.list-inline .dl-horizontal,前一個(gè)類聲明后箭昵,會(huì)將列表變成內(nèi)聯(lián)樣式税朴,后一個(gè)類聲明后會(huì)將列表水平放置,從類名上也可以比較直觀的看出這個(gè)類是針對(duì)自定義列表的家制,因此列表水平放置就是主分支和分支點(diǎn)寫在同一行上
下圖是進(jìn)行嘗試后得到的結(jié)果

7.png

代碼

Bootstrap提供令人兩種方式顯示代碼

  1. 內(nèi)聯(lián)顯示:<code>
  2. 以代碼塊形式顯示:<pre>
    需要注意的是:顯示的代碼中標(biāo)簽前后的<正林、>是需要分別用&lt以及&gt來(lái)表示的
    下圖是我用來(lái)作對(duì)比的一個(gè)圖,一個(gè)用&lt以及&gt來(lái)表示颤殴,一個(gè)直接用<觅廓、>來(lái)表示
    8.png

    9.png

從圖上的結(jié)果比較能清楚的看出來(lái),如果想要添加代碼涵但,必須要用&lt以及&gt來(lái)表示<>杈绸,不然在編譯的時(shí)候帖蔓,計(jì)算機(jī)會(huì)直接把想作為代碼部分顯示的代碼塊也一并當(dāng)做初始代碼進(jìn)行編譯
另外,在<code><pre>之后的空格都會(huì)原封不動(dòng)的顯示出來(lái)

表格

Bootstrap提供了一個(gè)清晰的創(chuàng)建表格的布局
下表列出了Bootstrap支持的一些表格元素


11.png

下表樣式可用于表格中:


12.png

.table樣式如圖:


13.png

.table-striped樣式如圖:


14.png

.table-bordered樣式如圖:


15.png

.table-hover樣式如圖:


16.png

當(dāng)鼠標(biāo)移動(dòng)到某一欄的內(nèi)容時(shí)瞳脓,那一行都會(huì)顯示成灰色

表單

Bootstrap提供了下列類型的表單布局:

  1. 垂直表單(默認(rèn))
    向父<form>元素添加role=“form”
    把標(biāo)簽和控件放在一個(gè)帶class.form-group<div>
    向所有的文本元素<input>塑娇、<textarea> 和 <select> 添加 class ="form-control"

  2. 內(nèi)聯(lián)表單
    內(nèi)聯(lián)表單中所有元素都是內(nèi)聯(lián)的
    如果需要一個(gè)內(nèi)聯(lián)表單內(nèi)的元素都向左對(duì)齊,標(biāo)簽并排劫侧,就在<form>標(biāo)簽內(nèi)添加form-inline類

    17.png

  3. 水平表單
    水平表單的呈現(xiàn)形式和其他表單有所不同埋酬,它是將前面的屬性名稱和后面需要輸入的表單內(nèi)容并成一行
    步驟:
    a. 向父 <form> 元素添加 class .form-horizontal
    b. 把標(biāo)簽和控件放在一個(gè)帶有 class .form-group 的 <div> 中
    c. 向標(biāo)簽添加 class .control-label


    18.png

靜態(tài)控件

如果需要在一個(gè)水平表單內(nèi)的表單標(biāo)簽后放置純文本時(shí),可以在 <p> 上使用 class .form-control-static
當(dāng)輸入框input接收到:focus時(shí)烧栋,會(huì)采用設(shè)立focus時(shí)的樣式
如下圖所示代碼塊

19.png

表示當(dāng)鼠標(biāo)懸停在鏈接上写妥,或者點(diǎn)擊過(guò)的鏈接,顏色都會(huì)被設(shè)置成為#2a6496审姓,同時(shí)耳标,會(huì)呈現(xiàn)一條下劃線
另外,點(diǎn)擊過(guò)的鏈接會(huì)另外呈現(xiàn)出顏色為#333的虛線輪廓

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末邑跪,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子呼猪,更是在濱河造成了極大的恐慌画畅,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,640評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件宋距,死亡現(xiàn)場(chǎng)離奇詭異轴踱,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)谚赎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,254評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門淫僻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)琼稻,“玉大人库正,你說(shuō)我怎么就攤上這事『Γ” “怎么了闸盔?”我有些...
    開(kāi)封第一講書人閱讀 165,011評(píng)論 0 355
  • 文/不壞的土叔 我叫張陵悯辙,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我迎吵,道長(zhǎng)躲撰,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書人閱讀 58,755評(píng)論 1 294
  • 正文 為了忘掉前任击费,我火速辦了婚禮拢蛋,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘蔫巩。我一直安慰自己谆棱,他們只是感情好快压,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,774評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著础锐,像睡著了一般嗓节。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上皆警,一...
    開(kāi)封第一講書人閱讀 51,610評(píng)論 1 305
  • 那天拦宣,我揣著相機(jī)與錄音,去河邊找鬼信姓。 笑死鸵隧,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的意推。 我是一名探鬼主播豆瘫,決...
    沈念sama閱讀 40,352評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼菊值!你這毒婦竟也來(lái)了外驱?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,257評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤腻窒,失蹤者是張志新(化名)和其女友劉穎昵宇,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體儿子,經(jīng)...
    沈念sama閱讀 45,717評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡瓦哎,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,894評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了柔逼。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蒋譬。...
    茶點(diǎn)故事閱讀 40,021評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖愉适,靈堂內(nèi)的尸體忽然破棺而出犯助,到底是詐尸還是另有隱情,我是刑警寧澤维咸,帶...
    沈念sama閱讀 35,735評(píng)論 5 346
  • 正文 年R本政府宣布也切,位于F島的核電站,受9級(jí)特大地震影響腰湾,放射性物質(zhì)發(fā)生泄漏雷恃。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,354評(píng)論 3 330
  • 文/蒙蒙 一费坊、第九天 我趴在偏房一處隱蔽的房頂上張望倒槐。 院中可真熱鬧,春花似錦附井、人聲如沸讨越。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,936評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)把跨。三九已至人弓,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間着逐,已是汗流浹背崔赌。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 33,054評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留耸别,地道東北人健芭。 一個(gè)月前我還...
    沈念sama閱讀 48,224評(píng)論 3 371
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像秀姐,于是被迫代替她去往敵國(guó)和親慈迈。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,974評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • Bootstrap是什么省有? 一套易用痒留、優(yōu)雅、靈活蠢沿、可擴(kuò)展的前端工具集--BootStrap狭瞎。GitHub上介紹 的...
    凜0_0閱讀 10,874評(píng)論 3 184
  • 什么是 Bootstrap? Bootstrap 是一個(gè)用于快速開(kāi)發(fā) Web 應(yīng)用程序和網(wǎng)站的前端框架搏予。Boots...
    亮亮叔家的小筆筆閱讀 964評(píng)論 2 4
  • 瀏覽器與服務(wù)器的基本概念 瀏覽器(安裝在電腦里面的一個(gè)軟件) 作用: ①將網(wǎng)頁(yè)內(nèi)容渲染呈現(xiàn)給用戶查看。 ②讓用戶通...
    云還灬閱讀 1,122評(píng)論 0 0
  • 表單介紹 HTML表單負(fù)責(zé)接收用戶的輸入弧轧,對(duì)輸入進(jìn)行合法格式判斷雪侥,并將數(shù)據(jù)發(fā)送到服務(wù)器。一個(gè)HTML表單必須指定兩...
    Py_Bird閱讀 3,717評(píng)論 0 1
  • 早上鬧鐘一響精绎,他就坐了起來(lái)速缨,睡眼惺忪地對(duì)我說(shuō):“媽媽,我們學(xué)校每天有兩個(gè)固定不變的菜代乃,我很喜歡旬牲!” ...
    飛飛阿仔閱讀 265評(píng)論 0 0