Bootstrap入門

来源:https://www.cnblogs.com/smyhvae/archive/2018/02/25/8470657.html
-Advertisement-
Play Games

本文最初發表於 "博客園" ,併在 "GitHub" 上持續更新 前端的系列文章 。歡迎在GitHub上關註我,一起入門和進階前端。 以下是正文。 Bootstrap 介紹 Bootstrap 是非常流行的前端框架。特點是:靈活簡潔、代碼優雅、美觀大方。它是由Twitter的兩名工程師 Mark O ...


本文最初發表於博客園,併在GitHub上持續更新前端的系列文章。歡迎在GitHub上關註我,一起入門和進階前端。

以下是正文。

Bootstrap 介紹

Bootstrap 是非常流行的前端框架。特點是:靈活簡潔、代碼優雅、美觀大方。它是由Twitter的兩名工程師 Mark Otto 和 Jacob Thornton 在2011年開發的。

簡單來說,Bootstrap 讓 Web 開發更簡單、更快捷。使用 Bootstrap 框架並不代表我們再開發時不用自己寫 CSS 樣式,而是不用謝絕大多數常見的樣式。

PS:Amaze UI 這個框架其實跟 Bootstrap 很像。

官網網站

V3版本:

V4版本:

列舉幾個用 Bootstrap 做的網站:

Bootstrap 版本

目前市面上使用的最多的是 3.x.x 版本。各個版本的介紹:

2.3.2版本:

  • 2013年之後,停止維護;

  • 支持更廣泛的瀏覽器

  • 代碼不夠簡潔, 功能不夠多。

3.x.x 版本:

  • 目前最新的穩定版本。

  • 不支持 IE7 和早期的 Firefox

  • 支持 IE8,單效果不好。

2015年8月發佈 4.0.0-alpha 的內部測試版。

版本號的普及:

  • alpha 版:內部測試版。α 是希臘字母的第一個,表示最早的版本,bug很多。主要是給開發和測試人員找 bug 用的。

  • beta 版:公開測試版。 主要是給“部落”用戶和忠實用戶測試用的。bug依然很多,但比 Alpha 版要穩定。這個階段的版本還會不斷增加新功能,如果你是發燒友,可以下載這個版本。

  • rc 版:候選版本(Release Candidate)。該版本不再增加新的功能。類似於最終發行版之前的預覽版(發行的候選版本)。此版本的發佈,預示著最終發行版即將到來。作為普通用戶,如果很著急,也可以下載 rc 版。

  • stable 版:穩定版。在開源軟體中,都有 stable版本,這個是開源軟體的最終發行版,用戶可以放心大膽地使用。

Bootstrap 庫的下載

這裡我們以 Bootstrap V3.3.7 為例。

進入中文官網,下載 用於生產環境的 Bootstrap,如下圖所示:

下載之後,解壓 bootstrap-3.3.7-dist ,有三個文件夾:

將其拷貝到工程文件的lib文件夾下即可。

PS:dist表示編譯之後的文件,這在庫文件中是很常見的。

因為 bootstrap.js依賴jQuery,所以要先引用jquery.js 然後引用bootstrap.js。

Bootstrap 基礎模板的介紹

Bootstrap官網提供了基本模板,如下圖所示:

其完整版代碼 copy 如下:

<!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.0, user-scalable=no">
    <!-- 上述3個meta標簽*必須*放在最前面,任何其他內容都*必須*跟隨其後! -->
    <title>我的網站</title>

    <!-- Bootstrap -->
    <link rel="stylesheet" href="lib/bootstrap/css/bootstrap.css">
    <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
    <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
    <!--[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 (necessary for Bootstrap's JavaScript plugins) -->
    <script src="https://cdn.bootcss.com/jquery/1.12.4/jquery.min.js"></script>
    <!-- Include all compiled plugins (below), or include individual files as needed -->
    <script src="js/bootstrap.min.js"></script>
  </body>
</html>

我們需要對上面的代碼進行解釋。

(1)Compatible

<meta http-equiv="X-UA-Compatible" content="IE=edge">

解釋:設置瀏覽器的相容模式版本。表示如果在IE瀏覽器下則使用最新的標準,渲染當前文檔。

(2)viewport 視口

    <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">

解釋:聲明當前網頁在移動端瀏覽器中展示的相關設置。我們在做移動 web 開發時,就用上面這行代碼設置 viewport。

視口的作用:在移動瀏覽器中,當頁面寬度超出設備,瀏覽器內部虛擬的一個頁面容器,將頁面容器縮放到設備這麼大,然後展示。

需要註意的是:

  • 目前大多數手機瀏覽器的視口(承載頁面的容器)寬度都是980;
  • 視口的寬度可以通過meta標簽設置。
  • 此屬性為移動端頁面視口設置,上方代碼設置的值,表示在移動端頁面的寬度為設備的寬度,並且不縮放(縮放級別為1)
    • width:視口的寬度
    • initial-scale:初始化縮放
    • user-scalable:是否允許用戶自行縮放(值可以寫成yes/no,也可以寫成1/0)
    • minimum-scale:最小縮放。
    • maximum-scale:最大縮放。

PS:如果設置了不允許用戶縮放,那麼最小縮放和最大縮放就沒有意義了。二者是矛盾的。

(3)條件註釋

    <!--[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]-->

條件註釋的作用:當判斷條件滿足時,就會執行註釋中的HTML代碼,不滿足時會當做註釋忽略掉。

上方代碼的條件註釋中,引入了兩個腳本:

  • html5shiv:讓瀏覽器可以識別 HTML5 的新標簽。如header、footer、section等。
  • respond.js:讓低版本瀏覽器可以使用 CSS3 的媒體查詢。

另外,我們還需要引入下麵這個庫:

  • jQuery:Bootstrap框架中的所有 JS 組件都依賴於 jQuery 實現。

我們可以把上面這三個庫文件拷貝到 lib 文件夾中(註意引用的路徑要寫正確)。

使用 Bootstrap 搭建項目

1、工程文件的目錄結構

├─ Demo ·························· 項目所在目錄
└─┬─ /css/ ······················· 我們自己的CSS文件
  ├─ /font/ ······················ 使用到的字體文件
  ├─ /img/ ······················· 使用到的圖片文件
  ├─ /js/ ························ 自己寫的JS腳步
  ├─ /lib/ ······················· 從第三方下載回來的庫【只用不改】
  ├─ /favicon.ico ················ 站點圖標
  └─ /index.html ················· 入口文件

2、下載並引入 Bootstrap 庫文件

見上一段的講解。引入之後,另外還需要引入 html5shiv、respond、jQuery 這三個庫文件。

3、字元集、Viewport設置、瀏覽器相容模式

我們將 Bootstrap 的基礎模板代碼 copy到項目的index.html中,這其中就包括最前面的三個meta標簽:

    <meta charset="utf-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1, user-scalable=no">
    <!-- 上述3個meta標簽*必須*放在最前面,任何其他內容都*必須*跟隨其後! -->

4、favicon(站點圖標)

<link rel="shortcut icon" type="image/x-icon" href="favicon.ico">

5、引入相應的第三方文件

    <!-- 引入 Bootstrap 的核心樣式文件(必須) -->
    <link rel="stylesheet" href="lib/bootstrap/css/bootstrap.css">
    <!-- 引入我們自己寫的 css 樣式文件-->
    <link rel="stylesheet" href="css/my.css">

    ...

    <script src="lib/jquery/jquery.js"></script>
    <script src="lib/bootstrap/js/bootstrap.js"></script>
    <script src="js/my.js"></script>

註意,先引入第三方的文件,再引入我們自己寫的文件。

6、預設字體

在我們預設的樣式表中將預設字體設置為:

body{
  font-family: "Helvetica Neue",
                Helvetica,
                Microsoft Yahei,
                Hiragino Sans GB,
                WenQuanYi Micro Hei,
                sans-serif;
}

7、完成頁面空結構

先劃分好頁面中的大容器,然後在具體看每一個容器中單獨的情況。

完整代碼如下:

<!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, user-scalable=no">
    <title>我的網站</title>
    <!--建議:第三方引用的css庫放在上面,我們自己寫的文件,都放在下麵-->

    <!-- 引入 Bootstrap 的核心樣式文件(必須) -->
    <link rel="stylesheet" href="lib/bootstrap/css/bootstrap.css">
    <!-- 引入我們自己寫的 css 樣式文件-->
    <link rel="stylesheet" href="css/main.css">
    <link rel="shortcut icon" type="image/x-icon" href="favicon.ico">
    <!--[if lt IE 9]>
    <script src="lib/html5shiv/html5shiv.min.js"></script>
    <script src="lib/respond/respond.min.js"></script>
    <![endif]-->
</head>

<body>
<!-- 頭部區域 -->
<header id="header">
</header>
<!-- /頭部區域 -->

<!-- 廣告輪播 -->
<section id="main_ad"></section>
<!-- /廣告輪播 -->

<!-- 特色介紹 -->
<section></section>
<!-- /特色介紹 -->

<!-- 立即預約 -->
<section></section>
<!-- /立即預約 -->

<!-- 產品推薦 -->
<section></section>
<!-- /產品推薦 -->

<!-- 新聞列表 -->
<section></section>
<!-- /新聞列表 -->

<!-- 合作伙伴 -->
<section></section>
<!-- /合作伙伴 -->

<!-- 腳註區域 -->
<footer></footer>
<!-- /腳註區域 -->

<script src="lib/jquery/jquery.js"></script>
<script src="lib/bootstrap/js/bootstrap.js"></script>
<script src="js/main.js"></script>
</body>

</html>

CSS 樣式

全局 CSS 樣式在官網有介紹:

如果需要哪個樣式,直接根據文檔的指引,在相應的元素裡加指定的類名即可。

我們選部分重要的來講一下。

佈局容器:container 類

截圖如下:

作用:用於定義一個固定寬度且居中的版心。只不過,這個版心的寬度具有響應式的效果。

也就是說,在 Bootstrap 中,我們一般用 .container 類來表示版心。

格式舉例:

<div class="topbar">
  <div class="container">
    <!--
      此處的代碼會顯示在一個固定寬度且居中的容器中
      該容器的寬度會跟隨屏幕的變化而變化
    -->
  </div>
</div>

這個 container 類我們自己其實也可以寫,通過媒體查詢即可實現。

柵格參數

柵格系統最主要的操作是:利用 css 的響應式去做一套行列佈局的預置樣式。

柵格參數如下:

我們尤其要記住各個屏幕的尺寸和類首碼

組件

一個按鈕稱之為樣式;兩個按鈕在一起,就可以稱之為組件。

組件在官網有介紹:

我們現在需要關註的不是組件怎麼用,而是裡面有哪些組件,避免重覆造輪子:別人已經做得很好了,不需要我們再重覆。

JS 組件

JS 組件在官網有介紹:

這裡麵包含了很多帶交互的組件。比如輪播圖:

博主提供的下載鏈接

空結構的工程文件的下載地址:(lib文件夾里包含了各種庫和 Bootstrap 中文文檔)

還是那句話:如果需要哪個樣式,直接根據文檔的指引,在相應的元素裡加指定的類名即可。

我的公眾號

想學習代碼之外的軟技能?不妨關註我的微信公眾號:生命團隊(id:vitateam)。

掃一掃,你將發現另一個全新的世界,而這將是一場美麗的意外:


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 資料庫的相關介紹 ...
  • 1. 模式的創建 2. 設置預設值 3. 基本表的撤銷 註:撤銷表時,資料庫中不應該存在依賴於被刪除表的其它表、視圖、索引、存儲過程等對象。 4. 基本表結構的修改 5. 查詢(去除重覆值) 7. 字元串匹配(LIKE) 8. 三值邏輯(AND OR NOT) 9. 輸出排序 10. 輸出列重命名 ...
  • 根據阿裡月報 : MySQL · 引擎特性 · InnoDB 事務鎖系統簡介 MySQL · 引擎特性 · Innodb 鎖子系統淺析 行鎖的入口:rec_lock_rec ...
  • 1,利用Beta測試來邀請測試者。 2,利用新聞發佈。 3,創建Web應用的宣傳網站。 4,使用郵件營銷。 5,創建YouTube視頻教程。 6,提交到蘋果Web應用門戶。 7,提交到其它Web應用門戶網站。 8,利用社交網路的傳播力。 參考資料:《iOS Web應用開發》 ...
  • 需求: 手機app ,當打游戲或者全屏看視頻的時候會發現這時候手機頂部的狀態欄是不顯示的,當我們從手機頂端向下進行滑動或手機底端向上滑動的時候,狀態欄會顯示出來,如果短暫的幾秒時間沒有操作的話,狀態欄會再次隱藏。 實現代碼: 效果: 代碼解釋: 1、 onWindowFocusChanged(boo ...
  • 項目地址https://github.com/979451341/OpenSLAudio OpenSL ES 是基於NDK也就是c語言的底層開發音頻的公開API,通過使用它能夠做到標準化, 高性能,低響應時間的音頻功能實現方法。這次是使用OpenSL ES來做一個音樂播放器,它能夠播放m4a、mp3 ...
  • 基本信息 例子 和協議配合使用的比較多 方法介紹 ...
  • NSData 嘗試這個例子之前,請在Demo工程的info.plist文件中加入App Transport Security Settings鍵值,並加入Allow Arbitrary Loads:YES鍵值對,用來開啟iOS下的非安全連接。 可以這樣用 map函數 如果我們使用NSData的rac ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...