Bootstrap (front-end framework)
![]() | |
Original author(s) | Mark Otto, Jacob Thornton |
---|---|
Developer(s) | Bootstrap Core Team |
Initial release | August 19, 2011 |
Stable release | 5.3.3[1] ![]() |
Repository | Bootstrap Repository |
Written in | HTML, CSS, Less (v3), Sass (v4) and JavaScript |
Platform | Web platform |
License | MIT License[2] (Apache License 2.0 prior to 3.1.0)[3] |
Website | getbootstrap![]() |
Bootstrap (formerly Twitter Bootstrap) is a free and open-source CSS framework directed at responsive, mobile-first front-end web development. It contains HTML, CSS and (optionally) JavaScript-based design templates for typography, forms, buttons, navigation, and other interface components.
As of May 2023[update], Bootstrap is the 17th most starred project (4th most starred library) on GitHub, with over 164,000 stars.[4] According to W3Techs, Bootstrap is used by 19.2% of all websites.[5]
Features
Bootstrap is an HTML, CSS and JS library that focuses on simplifying the development of informative web pages (as opposed to web applications). The primary purpose of adding it to a web project is to apply Bootstrap's choices of color, size, font and layout to that project. As such, the primary factor is whether the developers in charge find those choices to their liking. Once added to a project, Bootstrap provides basic style definitions for all HTML elements. The result is a uniform appearance for prose, tables and form elements across web browsers. In addition, developers can take advantage of CSS classes defined in Bootstrap to further customize the appearance of their contents. For example, Bootstrap has provisioned for light- and dark-colored tables, page headings, more prominent pull quotes, and text with a highlight.
Bootstrap also comes with several JavaScript components which do not require other libraries like jQuery. They provide additional user interface elements such as dialog boxes, tooltips, progress bars, navigation drop-downs, and carousels. Each Bootstrap component consists of an HTML structure, CSS declarations, and in some cases accompanying JavaScript code. They also extend the functionality of some existing interface elements, including for example an auto-complete function for input fields.

The most prominent components of Bootstrap are its layout components, as they affect an entire web page. The basic layout component is called "Container", as every other element in the page is placed in it. Developers can choose between a fixed-width container and a fluid-width container. While the latter always fills the width with the web page, the former uses one of the five predefined fixed widths, depending on the size of the screen showing the page:[6]
- Smaller than 576 pixels
- 576–768 pixels
- 768–992 pixels
- 992–1200 pixels
- 1200-1400 pixels
- Larger than 1400 pixels
Once a container is in place, other Bootstrap layout components implement a CSS Flexbox layout through defining rows and columns.
A precompiled version of Bootstrap is available in the form of one CSS file and three JavaScript files that can be readily added to any project. The raw form of Bootstrap, however, enables developers to implement further customization and size optimizations. This raw form is modular, meaning that the developer can remove unneeded components, apply a theme and modify the uncompiled Sass files.
History
Early beginnings
Bootstrap, originally named Twitter Blueprint, was developed by Mark Otto and Jacob Thornton at Twitter as a framework to encourage consistency across internal tools. Before Bootstrap, various libraries were used for interface development, which led to inconsistencies and a high maintenance burden. According to Otto:
A super small group of developers and I got together to design and build a new internal tool and saw an opportunity to do something more. Through that process, we saw ourselves build something much more substantial than another internal tool. Months later, we ended up with an early version of Bootstrap as a way to document and share common design patterns and assets within the company.[7]
After a few months of development by a small group, many developers at Twitter began to contribute to the project as a part of Hack Week, a hackathon-style week for the Twitter development team. It was renamed from Twitter Blueprint to Twitter Bootstrap and released as an open-source project on August 19, 2011.[8] It has continued to be maintained by Otto, Thornton, a small group of core developers, and a large community of contributors.[9]
Bootstrap 2
On January 31, 2012, Bootstrap 2 was released, which added built-in support for Glyphicons, several new components, as well as changes to many of the existing components. This version supports responsive web design, meaning the layout of web pages adjusts dynamically, taking into account the characteristics of the device used (whether desktop, tablet, mobile phone).[10] Shortly before the release of Bootstrap 2.1.2, Otto and Thornton left Twitter, but committed to continue to work on Bootstrap as an independent project.[11]
Bootstrap 3
On August 19, 2013, Bootstrap 3 was released. It redesigned components to use flat design and a mobile first approach.[12] Bootstrap 3 features new plugin system with namespaced events. Bootstrap 3 dropped Internet Explorer 7 and Firefox 3.6 support, but there is an optional polyfill for these browsers.[13] Bootstrap 3 was also the first version released under the twbs organization on GitHub instead of the Twitter one.[14]
Bootstrap 3.1 and later
Bootstrap 3.1 was released in January 2014, bringing several enhancements, including the Affix JavaScript plugin and better documentation. Subsequent minor releases in the 3.x series continued to refine the framework with bug fixes and performance improvements.
Bootstrap 4
Otto announced Bootstrap 4 on October 29, 2014.[15] The first alpha version of Bootstrap 4 was released on August 19, 2015.[16] The first beta version was released on August 10, 2017.[17] Otto suspended work on Bootstrap 3 on September 6, 2016, to free up time to work on Bootstrap 4. Bootstrap 4 was finalized on January 18, 2018.[18]
Significant changes include:
- Major rewrite of the code
- Replacing Less with Sass
- Addition of
Reboot
, a collection of element-specific CSS changes in a single file, based onNormalize
- Dropping support for IE8, IE9, and iOS 6
- CSS Flexible Box support
- Adding navigation customization options
- Adding responsive spacing and sizing utilities
- Switching from the pixels unit in CSS to root ems
- Increasing global font size from 14px to 16px for enhanced readability
- Dropping the
panel
,thumbnail
,pager
, andwell
components - Dropping the
Glyphicons
icon font - Huge number[quantify] of utility classes
- Improved form styling, buttons, drop-down menus, media objects and image classes
Bootstrap 4 supports the latest versions of Google Chrome, Firefox, Internet Explorer, Opera, and Safari (except on Windows). It additionally supports back to IE10 and the latest Firefox Extended Support Release (ESR).[19]
Bootstrap 4 went through an extensive development cycle, with multiple alpha and beta releases, introducing features such as cards, a new grid system, and improved utilities. These pre-releases allowed for community feedback and iterative improvements.
Bootstrap 5
After the final release of Bootstrap 4 in 2018, the team began work on Bootstrap 5, which aimed to modernize the framework further. This development included alpha and beta phases starting in June 2020, focusing on removing jQuery, improving the grid system, and enhancing customizability.
Bootstrap 5 was officially released on May 5, 2021.[20][21]
Major changes include:[22]
New Off-Canvas Menu Component: This feature provides a flexible and customizable off-canvas sidebar that can be used for navigation or other purposes.
Removing jQuery Dependency: Bootstrap 5 replaces jQuery with native JavaScript, which reduces the size of the framework and improves performance.
Rewritten Grid System: The grid system has been enhanced to support responsive spacing and allow columns to be placed outside rows, providing more flexibility in layout design.
Migrating Documentation from Jekyll to Hugo: This change improves the speed and scalability of the documentation site.
Dropping Support for Internet Explorer: Bootstrap 5 no longer supports Internet Explorer, allowing the framework to take advantage of modern web technologies without requiring compatibility with older browsers.
New Testing Infrastructure: The testing infrastructure has moved from QUnit to Jasmine, providing a more powerful testing environment.
Custom SVG Icons: A new set of custom SVG icons has been added, providing developers with a wider range of icons to use in their projects.
CSS Custom Properties: The framework now includes CSS custom properties (variables), which makes it easier to customize and extend the default styles.
Improved API: Enhancements to the API provide developers with more powerful and flexible options.
Enhanced Grid System: The grid system has been further refined to support more complex layouts and responsive design needs.
Improved Customization Documentation: The documentation for customizing Bootstrap has been significantly improved, making it easier for developers to tailor the framework to their specific needs.
Updated Forms: Form elements and styles have been updated to provide a more modern and consistent user experience.
RTL (right-to-left) support: Native support for RTL languages has been added, making it easier to create multilingual websites.
Built-in Dark Mode Support: Dark mode support has been integrated into the framework, allowing for easier implementation of dark themes.
See also
Also, several web frameworks support rendering in Bootstrap.[23][24]
References
- ^ "Release 5.3.3". February 20, 2024. Retrieved February 20, 2024.
- ^ "bootstrap/LICENSE". Github.
- ^ "bootstrap/LICENSE (v3.0.3)". Github.
- ^ "Search · stars:>100000". GitHub. Retrieved December 4, 2022.
- ^ "Usage statistics and market share of Bootstrap for websites". w3techs.com. Retrieved January 24, 2023.
- ^ "Bootstrap Containers · Bootstrap v5.0".
- ^ Otto, Mark (January 17, 2012). "Bootstrap in A List Apart No. 342". Mark Otto's blog. Archived from the original on October 28, 2016. Retrieved February 23, 2017.
- ^ Otto, Mark (August 19, 2011). "Bootstrap from Twitter". Developer Blog. Twitter. Archived from the original on February 23, 2017. Retrieved February 23, 2017.
- ^ "About". Bootstrap. August 19, 2011. Retrieved February 23, 2017.
- ^ Otto, Mark (January 31, 2012). "Say hello to Bootstrap 2.0". Developer Blog. Twitter. Archived from the original on February 23, 2017. Retrieved February 23, 2017.
- ^ Otto, Mark (September 29, 2012). "Onward". blog.getbootstrap.com.
- ^ "Bootstrap Blog - Bootstrap 3 released".
- ^ Otto, Mark (August 19, 2013). "Bootstrap 3 released". Archived from the original on October 21, 2016. Retrieved February 23, 2017.
- ^ "Bootstrap 3 plans". December 10, 2012.
- ^ Otto, Mark (October 29, 2014). "Bootstrap 3.3.0 released". Archived from the original on July 24, 2016. Retrieved February 23, 2017.
- ^ Otto, Mark (August 19, 2015). "Bootstrap 4 alpha". Archived from the original on January 23, 2017. Retrieved February 23, 2017.
- ^ Otto, Mark; Thornton, Jacob (August 10, 2017). "Bootstrap 4 Beta". Retrieved August 16, 2017.
- ^ "Bootstrap 4". blog.getbootstrap.com. January 18, 2018. Retrieved February 5, 2021.
- ^ "Supported browsers". Bootstrap. Retrieved February 23, 2017.
- ^ "Release Release v5.0.0 (#33647) · twbs/bootstrap". GitHub. Retrieved May 5, 2021.
- ^ "Bootstrap 5". blog.getbootstrap.com. May 5, 2021.
- ^ "Bootstrap 5 grid by MartijnCuppens · Pull Request #28517 · twbs/bootstrap". GitHub. Retrieved September 29, 2019.
- ^ "Bootstrap-Flask". HelloFlask. Retrieved November 7, 2022.
- ^ "Bootstrap-Django". zelenij. Retrieved November 7, 2022.