Bootstrap

本頁使用了標題或全文手工轉換
維基百科,自由的百科全書
Bootstrap
原作者Mark Otto, Jacob Thornton
開發者Bootstrap Core Team
首次發布2011年8月19日,​12年前​(2011-08-19
當前版本
  • 5.3.3 (2024年2月20日;穩定版本)[1]
編輯維基數據鏈接
源代碼庫 編輯維基數據鏈接
編程語言HTMLCSSLESSSassJavaScript
平台排版引擎
類型基於HTMLCSS的設計模板
許可協議MIT許可證(3.1.0版前為Apache許可證 2.0)
網站getbootstrap.com 編輯維基數據

Bootstrap是一組用於網站網絡應用程序開發的開源前端(所謂「前端」,指的是展現給最終用戶的界面。與之對應的「後端」是在服務器上面運行的代碼)框架,包括HTMLCSSJavaScript的框架,提供字體排印、表單、按鈕、導航及其他各種元件及Javascript擴充套件,旨在使動態網頁Web應用的開發更加容易。

Bootstrap是GitHub上面被標記為「Starred」次數排名第四多的項目。Starred次數超過133,000,而分支次數超過了65,000次。[2]

起源[編輯]

Bootstrap原名Twitter Blueprint,由Twitter的Mark Otto和Jacob Thornton編寫,本意是製作一套可以保持一致性的工具和框架。在Bootstrap之前,開發界面需要使用不同的代碼庫,這樣很容易導致不一致的問題,從而增加了維護的負擔。Twitter開發者Mark Otto說:

「我和幾個開發者一起設計建立一個新的內部使用的工具,然後我們發現有機會可以做更多的事。從那之後,我們發現我們設計的工具比別人設計的更強大。幾個月之後,我們做出了Bootstrap的原型,在公司內分享文檔、設計和資源。」[3]

經過一個小組幾個月之後的努力,Twitter的許多開發者把它當作Hack Week(在Twitter開發者中流行的類似於黑客松的一星期)的一部分,開始參與開發。大家把Twitter Blueprint改名為Bootstrap,並且在2011年8月19日將其作為開源項目發布。[4] 此後項目繼續由Mark Otto、Jacob Thornton和一個核心開發小組維護,此外還有眾多來自社區的貢獻者。[5]

在2012年1月31日,Bootstrap 2發布。這一版增加了十二列網格布局和響應式組件,並且對許多組件進行了修改。[6] Bootstrap 3於2013年8月19日發布,開始將移動設備優先作為方針,並且開始使用扁平化設計[6]

2015年4月23日,Mark Otto宣布正在開發Bootstrap 4[7]。Bootstrap 4的第一個alpha版本部署在2015年8月19日[8]

2021年5月5日,Bootstrap 5正式發布。[9]

功能[編輯]

Bootstrap與最新版的Google ChromeFirefoxInternet ExplorerOperaSafari瀏覽器兼容,儘管有些瀏覽器並不是支持所有操作系統。[10]

從2.0版本開始,Bootstrap支持響應式網頁設計(RWD)。頁面布局可以根據顯示網頁的設備(桌面、平板電腦、手機)來進行動態調整。

從3.0版本開始,Bootstrap將移動設備優先作為設計方針,更加強調了響應式設計。

從 4 版本開始,添加SassFlexbox英語CSS Flex Box Layout的支持,更重要的是加入了utilities CSS 的新概念[11]

從 5 版本開始,不支援IE[12],脫離了jQuery的依賴,大大提升原生 JavaScript 及各前端框架的支援,並更加完善了無障礙的相關輔助[13][14]

Bootstrap是開源軟件,可以從GitHub上面找到[15]。開發者被鼓勵參與項目,並且對項目做出自己的貢獻。

結構和功能[編輯]

Example of a webpage using Bootstrap framework
Mozilla Firefox渲染的Bootstrap示例頁面

Bootstrap採用模塊化設計,並且用LESS樣式表語言來實現各種組件和工具。一個名為bootstrap.less的文件包括了這些組件和工具,開發者可以修改這個文件,自行決定項目需要哪些組件。

通過一個基本配置文件可以進行有限的定製,此外也可以進行更加深入的定製。

LESS語言支持變量、函數、運算符、組合選擇器和一個叫做Mixin(混入)的功能。

從Bootstrap 2.0開始,Bootstrap文檔包括一個叫做「自定義」的特別選項,開發者可以根據自己的實際需要來選擇包含的組件和效果,然後生成和下載已經編譯好的包。

網格系統和響應式設計以1170像素寬為基準。此外開發者也可以自定義基準。這兩種情況下,Bootstrap都能提供四種變體:手機豎屏、手機橫屏和平板電腦、PC低分辨率、高分辨率,每個變體都會自動調整網格寬度。

CSS[編輯]

Bootstrap對一系列HTML組件的基本樣式進行了定義,並且為文本、表格和表單元素設計了一套獨特的、現代化的樣式。

可重用組件[編輯]

除了基本HTML元素,Bootstrap還包括了其他常用的界面元素,例如帶有高級功能的按鈕(例如按鈕組合、帶有下拉菜單選項的按鈕、導航欄、水平和垂直標籤組、導航、分頁等等)、標籤、高級排版、縮略圖、警告信息、進度條等。

這些組件都使用CSS的類實現。在頁面中需要將其對應到特定的HTML元素上面。

JavaScript組件[編輯]

通過jQuery,Bootstrap加入了一些JavaScript組件。它們提供了例如對話框、工具提示、輪播等功能。此外還增強了一些用戶界面元素的功能,例如輸入框的自動完成。Bootstrap 2.0支持以下JavaScript插件:Modal(模態對話框)、Dropdown(下拉菜單)、Scrollspy(滾動監聽)、Tab(標籤頁)、Tooltip(工具提示)、Popover(浮動提示)、Alert(警告)、Button(按鈕)、Collapse(摺疊)、Carousel(輪播)、Typeahead(輸入提示)、Affix(附加導航)。

Sass和Less支持[編輯]

Sass 和Less都是CSS預處理器,它們允許開發者使用變量、嵌套、混入等高級功能來更輕鬆地編寫和維護CSS代碼。Sass 代表語法很棒的樣式表。Sass 是 CSS 的擴展,完全兼容所有版本的 CSS,並減少了CSS 的重複,從而節省了時間。Sass 由 Hampton Catlin 設計,由 Natalie Weizenbaum 於 2006 年開發。Less代表精簡樣式表。Less 只對 CSS 語言做了一些方便的補充,因此它是較為容易學習的。

Bootstrap提供了基於Sass和Less的源文件,使開發者能夠使用這些預處理器。使用Sass或Less,開發者可以修改變量、覆蓋默認樣式、添加自定義組件和樣式,以滿足特定項目的需求。這種支持使得Bootstrap更加靈活,開發者可以根據項目的要求自定義Bootstrap的樣式。

Bootstrap 圖標庫[編輯]

Bootstrap v5第一次擁有自己的開源 SVG 圖標庫,旨在與 Bootstrap 組件配合使用,但它們也可以使用到任何項目中。這些圖標是 SVG 格式的,因此它們可以被快速輕鬆地縮放、可以通過多種方式使用、並且可以使用 CSS 設置樣式。

官方主題[編輯]

官方 Bootstrap 主題市場提供了許多高級主題,讓 Bootstrap 提升到了一個新的水平。這些主題是基於 Bootstrap 構建的,並作為他們自己的擴展框架,包含了豐富的新組件和插件、文檔以及構建工具。

參見[編輯]

參考文獻[編輯]

  1. ^ Release 5.3.3. 2024年2月20日 [2024年2月20日]. 
  2. ^ Search · stars:>1. GitHub. [8 Jan 2017]. (原始內容存檔於2015-12-12). 
  3. ^ Otto, Mark. Bootstrap in A List Apart No. 342. Mark Otto. 17 January 2012 [2015-08-18]. (原始內容存檔於2020-05-12). 
  4. ^ Otto, Mark. Bootstrap from Twitter. Developer Blog. Twitter. 19 August 2011 [2015-08-18]. (原始內容存檔於2017-02-23). 
  5. ^ About. Bootstrap. [2015-08-18]. (原始內容存檔於2015-08-19). 
  6. ^ 6.0 6.1 Search · stars:>1. GitHub. [26 June 2015]. (原始內容存檔於2015-12-12). 
  7. ^ Otto, Mark. Bootstrap 3.3.0 released. Bootstrap Blog. [21 August 2015]. (原始內容存檔於2016-07-24). 
  8. ^ Otto, Mark. Bootstrap 4 alpha. Bootstrap Blog. [20 August 2015]. (原始內容存檔於2015-08-21). 
  9. ^ Otto, Mark. Bootstrap 5. Bootstrap Blog. [5 May 2021]. (原始內容存檔於2022-05-20). 
  10. ^ Supported browsers. Bootstrap. [2015-08-18]. (原始內容存檔於2015-08-18). 
  11. ^ Bootstrap 4 alpha. Bootstrap. [2016-05-23]. (原始內容存檔於2015-08-21). 
  12. ^ Browsers and devices. Bootstrap. [2023-07-01]. (原始內容存檔於2023-07-22). 
  13. ^ Bootstrap 5 JavaScript. Bootstrap. [2022-11-22]. (原始內容存檔於2023-10-20). 
  14. ^ Bootstrap 5 Accessibility. Bootstrap. [2022-11-22]. (原始內容存檔於2023-10-05). 
  15. ^ Bootstrap GitHub Repository. twbs/bootstrap. [2016-05-23]. (原始內容存檔於2016-07-04). 

外部連結[編輯]