day45_Bootstrap

Bootstrap簡介

什麼是bootstrap?

概念: 一個前端開發的框架,Bootstrap,來自 Twitter,是目前很受歡迎的前端框架。Bootstrap 是基於 HTML、CSS、JavaScript 的,它簡潔靈活,使得 Web 開發更加快捷。框架:一個半成品軟件,開發人員可以在框架基礎上,在進行開發,簡化編碼。

好處:

  • 定義了很多的css樣式和js插件。我們開發人員直接可以使用這些樣式和插件得到豐富的頁面效果。
  • 響應式佈局:同一套頁面可以兼容不同分辨率的設備。

快速入門

  1. 進入官網https://www.bootcss.com/,下載bootstrap
  2. 進入bootstrap-3.3.7-dist文件夾,複製ccs丶fonts丶js進入到項目中
  3. 創建HTML頁面,引入必要的資源文件(後綴是min的資源比較小,用於引入。後綴不是min的用於閱讀)

創建第一個頁面,引入需要的資源

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <!--設置編碼-->
    <meta charset="utf-8">
    <!--設置IE的支持-->
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <!--設置窗口的寬度等於設備的寬度,縮放比例是1的支持-->
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 上述3個meta標籤*必須*放在最前面,任何其他內容都*必須*跟隨其後! -->
    <title>Bootstrap 101 Template</title>

    <!-- 引入bootstrap.min.cs資源 -->
    <link rel="stylesheet" href="../libs/css/bootstrap.min.css">
    <!--下面2個引入的2個文件是兼容低版本的IE-->
    <script src="//cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script>
    <script src="//cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
    <!-- jQuery (Bootstrap 的所有 JavaScript 插件都依賴 jQuery,所以必須放在前邊) -->
    <script src="../libs/js/bootstrap.min.js"></script>
    <!-- 加載 Bootstrap 的所有 JavaScript 插件。你也可以根據需要只加載單個插件。 -->
    <script src="../libs/js/jquery-3.2.1.min.js"></script>
</head>
<body>
<h1>你好,世界!</h1>


</body>
</html>

響應式佈局

同一套頁面可以兼容不同分辨率的設備就是響應式佈局。

前提:

  • 依賴於柵格系統,將一行平均分成12個格子,可以指定元素佔幾個格子。

實現步驟:

1. 定義容器。相當於之前的table。容器分類:

  • container:兩邊留白
  • container-fluid:每一種設備都是100%寬度

2: 定義行。相當於之前的tr   樣式:row

3:定義元素。指定該元素在不同的設備上,所佔的格子數目樣式:col-設備代號-格子數目

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <!--設置編碼-->
    <meta charset="utf-8">
    <!--設置IE的支持-->
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <!--設置窗口的寬度等於設備的寬度,縮放比例是1的支持-->
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 上述3個meta標籤*必須*放在最前面,任何其他內容都*必須*跟隨其後! -->
    <title>Bootstrap 101 Template</title>

    <!-- 引入bootstrap.min.cs資源 -->
    <link rel="stylesheet" href="../libs/css/bootstrap.min.css">
    <!--下面2個引入的2個文件是兼容低版本的IE-->
    <script src="//cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script>
    <script src="//cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
    <!-- jQuery (Bootstrap 的所有 JavaScript 插件都依賴 jQuery,所以必須放在前邊) -->
    <script src="../libs/js/bootstrap.min.js"></script>
    <!-- 加載 Bootstrap 的所有 JavaScript 插件。你也可以根據需要只加載單個插件。 -->
    <script src="../libs/js/jquery-3.2.1.min.js"></script>

    <style>
        .inner {
            border: 1px solid red;
        }
    </style>
</head>
<body>
<!--1.定義容器-->
<div class="container-fluid">
    <!--2.定義行-->
    <div class="row">
        <!--3.定義元素
                在大顯示器一行12個格子
                在pad上一行6個格子
            -->
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>
        <div class="col-lg-1 col-sm-2 inner">測試數據</div>

    </div>


</div>


</body>
</html>

柵格參數

通過下表可以詳細查看 Bootstrap 的柵格系統是如何在多種屏幕設備上工作的。

 

注意:

  • 一行中如果格子數目超過12,則超出部分自動換行。
  • 柵格類屬性可以向上兼容。柵格類適用於與屏幕寬度大於或等於分界點大小的設備。
  • 如果真實設備寬度小於了設置柵格類屬性的設備代碼的最小值,會一個元素沾滿一整行。

常見的CSS樣式和JS插件

按鈕

爲 <a><button> 或 <input> 元素添加按鈕類(button class)即可使用 Bootstrap 提供的樣式。舉例:

   

圖片

  • 在 Bootstrap 版本 3 中,通過爲圖片添加 .img-responsive 類可以讓圖片支持響應式佈局。
  • 如果需要讓使用了 .img-responsive 類的圖片水平居中,請使用 .center-block 類,不要用 .text-center
  • 通過爲 <img> 元素添加以下相應的類,可以讓圖片呈現不同的形狀。

      

表格

  • 將任何 .table 元素包裹在 .table-responsive 元素內,即可創建響應式表格,其會在小屏幕設備上(小於768px)水平滾動。當屏幕大於 768px 寬度時,水平滾動條消失。 
  • 添加 .table-bordered 類爲表格和其中的每個單元格增加邊框。
  • 通過添加 .table-hover 類可以讓 <tbody> 中的每一行對鼠標懸停狀態作出響應。
  • 通過添加 .table-condensed 類可以讓表格更加緊湊,單元格中的內補(padding)均會減半。

通過這些狀態類可以爲行或單元格設置顏色。

 

表單,組件 樣式 過多 樣式 建議進入官網https://v3.bootcss.com/css/ 查看

綜合案例

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <!--設置編碼-->
    <meta charset="utf-8">
    <!--設置IE的支持-->
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <!--設置窗口的寬度等於設備的寬度,縮放比例是1的支持-->
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 上述3個meta標籤*必須*放在最前面,任何其他內容都*必須*跟隨其後! -->
    <title>Bootstrap 101 Template</title>

    <!-- 引入bootstrap.min.cs資源 -->
    <link rel="stylesheet" href="../libs/css/bootstrap.min.css">
    <!--下面2個引入的2個文件是兼容低版本的IE-->
    <script src="//cdn.bootcss.com/html5shiv/3.7.2/html5shiv.min.js"></script>
    <script src="//cdn.bootcss.com/respond.js/1.4.2/respond.min.js"></script>
    <!-- jQuery (Bootstrap 的所有 JavaScript 插件都依賴 jQuery,所以必須放在前邊) -->
    <script src="../libs/js/bootstrap.min.js"></script>
    <!-- 加載 Bootstrap 的所有 JavaScript 插件。你也可以根據需要只加載單個插件。 -->
    <script src="../libs/js/jquery-3.2.1.min.js"></script>
    <style>
        .paddtop{
            padding-top: 10px;
        }
        .search-btn{
            float: left;
            border:1px solid #ffc900;
            width: 90px;
            height: 35px;
            background-color:#ffc900 ;
            text-align: center;
            line-height: 35px;
            margin-top: 15px;
        }

        .search-input{
            float: left;
            border:2px solid #ffc900;
            width: 400px;
            height: 35px;
            padding-left: 5px;
            margin-top: 15px;
        }
        .jx{
            border-bottom: 2px solid #ffc900;
            padding: 5px;
        }
        .company{
            height: 40px;
            background-color: #ffc900;
            text-align: center;
            line-height:40px ;
            font-size: 8px;
        }
    </style>
</head>
<body>
<!--頁眉部分,語意化標籤-->
<header class="container">
    <!--第一行圖片-->
    <div class="row">
        <!--響應式佈局-->
        <img  class="img-responsive" src="../img/top_banner.jpg" />
    </div>
    <!--第二行分成三部分-->
    <div class="row">
        <!--在pc端,分別佔3丶5 丶4個格子-->
        <div class="col-md-3">
            <img src="../img/logo.jpg">
        </div>
        <div class="col-md-5">
            <input class="search-input" placeholder="請輸入線路名稱">
            <a class="search-btn" href="#">搜索</a>
        </div>
        <!--第三行圖片,響應式佈局-->
        <div class="col-md-4">
            <img src="../img/hotel_tel.png" class="img-responsive">
        </div>
    </div>
    <!--導航條-->
    <div class="row">
        <nav class="navbar navbar-default">
            <div class="container-fluid">
                <!-- Brand and toggle get grouped for better mobile display -->
                <div class="navbar-header">
                    <!-- 定義漢堡按鈕 -->
                    <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" aria-expanded="false">
                        <span class="sr-only">Toggle navigation</span>
                        <span class="icon-bar"></span>
                        <span class="icon-bar"></span>
                        <span class="icon-bar"></span>
                    </button>
                    <a class="navbar-brand" href="#">首頁</a>
                </div>

                <!-- Collect the nav links, forms, and other content for toggling -->
                <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
                    <ul class="nav navbar-nav">
                        <li class="active"><a href="#">Link <span class="sr-only">(current)</span></a></li>
                        <li><a href="#">Link</a></li>
                        <li><a href="#">Link</a></li>
                        <li><a href="#">Link</a></li>
                        <li><a href="#">Link</a></li>
                        <li><a href="#">Link</a></li>

                    </ul>
                </div><!-- /.navbar-collapse -->
            </div><!-- /.container-fluid -->
        </nav>

    </div>

    <!--輪播圖-->
    <div class="row">
        <div id="carousel-example-generic" class="carousel slide" data-ride="carousel">
            <!-- Indicators -->
            <ol class="carousel-indicators">
                <li data-target="#carousel-example-generic" data-slide-to="0" class="active"></li>
                <li data-target="#carousel-example-generic" data-slide-to="1"></li>
                <li data-target="#carousel-example-generic" data-slide-to="2"></li>
            </ol>

            <!-- Wrapper for slides -->
            <div class="carousel-inner" role="listbox">
                <div class="item active">
                    <img src="../img/banner_1.jpg" alt="...">
                </div>
                <div class="item">
                    <img src="../img/banner_2.jpg" alt="...">
                </div>
                <div class="item">
                    <img src="../img/banner_3.jpg" alt="...">
                </div>

            </div>

            <!-- Controls -->
            <a class="left carousel-control" href="#carousel-example-generic" role="button" data-slide="prev">
                <span class="glyphicon glyphicon-chevron-left" aria-hidden="true"></span>
                <span class="sr-only">Previous</span>
            </a>
            <a class="right carousel-control" href="#carousel-example-generic" role="button" data-slide="next">
                <span class="glyphicon glyphicon-chevron-right" aria-hidden="true"></span>
                <span class="sr-only">Next</span>
            </a>
        </div>

    </div>
</header>
<!--主體部分,-->
<div class="container">
    <div class="row jx">
        <img src="../img/icon_5.jpg">
        <span>黑馬精選</span>
    </div>

    <div class="row paddtop">
        <div class="col-md-3">
            <div class="thumbnail">
                <img src="../img/jiangxuan_3.jpg" alt="圖片">
                <p>上海直飛三亞5天4晚自由行(春節預售+親子/蜜月/休閒遊首選+豪華酒店任選+接送機)</p>
                <font color="red">&yen; 699</font>
            </div>
        </div>
        <div class="col-md-3">
            <div class="thumbnail">
                <img src="../img/jiangxuan_3.jpg" alt="圖片">
                <p>上海直飛三亞5天4晚自由行(春節預售+親子/蜜月/休閒遊首選+豪華酒店任選+接送機)</p>
                <font color="red">&yen; 699</font>
            </div>

        </div>
        <div class="col-md-3">

            <div class="thumbnail">
                <img src="../img/jiangxuan_3.jpg" alt="圖片">
                <p>上海直飛三亞5天4晚自由行(春節預售+親子/蜜月/休閒遊首選+豪華酒店任選+接送機)</p>
                <font color="red">&yen; 699</font>
            </div>
        </div>
        <div class="col-md-3">

            <div class="thumbnail">
                <img src="../img/jiangxuan_3.jpg" alt="圖片">
                <p>上海直飛三亞5天4晚自由行(春節預售+親子/蜜月/休閒遊首選+豪華酒店任選+接送機)</p>
                <font color="red">&yen; 699</font>
            </div>
        </div>


    </div>
    <div class="row jx">
        <img src="img/icon_6.jpg">
        <span>國內遊</span>
    </div>
    <div class="row paddtop">
        <div class="col-md-4">
            <img src="../img/guonei_1.jpg">
        </div>
        <div class="col-md-8">
            <div class="row">
                <div class="col-md-4">
                    <div class="thumbnail">
                        <img src="../img/jiangxuan_3.jpg" alt="">
                        <p>上海直飛三亞5天4晚自由行(春節預售+親子/蜜月/休閒遊首選+豪華酒店任選+接送機)</p>
                        <font color="red">&yen; 699</font>
                    </div>
                </div>
                <div class="col-md-4">
                    <div class="thumbnail">
                        <img src="../img/jiangxuan_3.jpg" alt="">
                        <p>上海直飛三亞5天4晚自由行(春節預售+親子/蜜月/休閒遊首選+豪華酒店任選+接送機)</p>
                        <font color="red">&yen; 699</font>
                    </div>

                </div>
                <div class="col-md-4">

                    <div class="thumbnail">
                        <img src="../img/jiangxuan_3.jpg" alt="">
                        <p>上海直飛三亞5天4晚自由行(春節預售+親子/蜜月/休閒遊首選+豪華酒店任選+接送機)</p>
                        <font color="red">&yen; 699</font>
                    </div>
                </div>

            </div>
            <div class="row">
                <div class="col-md-4">
                    <div class="thumbnail">
                        <img src="../img/jiangxuan_3.jpg" alt="">
                        <p>上海直飛三亞5天4晚自由行(春節預售+親子/蜜月/休閒遊首選+豪華酒店任選+接送機)</p>
                        <font color="red">&yen; 699</font>
                    </div>
                </div>
                <div class="col-md-4">
                    <div class="thumbnail">
                        <img src="../img/jiangxuan_3.jpg" alt="">
                        <p>上海直飛三亞5天4晚自由行(春節預售+親子/蜜月/休閒遊首選+豪華酒店任選+接送機)</p>
                        <font color="red">&yen; 699</font>
                    </div>

                </div>
                <div class="col-md-4">

                    <div class="thumbnail">
                        <img src="../img/jiangxuan_3.jpg" alt="">
                        <p>上海直飛三亞5天4晚自由行(春節預售+親子/蜜月/休閒遊首選+豪華酒店任選+接送機)</p>
                        <font color="red">&yen; 699</font>
                    </div>
                </div>


            </div>

        </div>

    </div>
</div>

</div>
<!--頁腳部分,語意化標-->
<!-- 3.頁腳部分-->
<footer class="container-fluid">
    <div class="row">
        <img src="img/footer_service.png" class="img-responsive">
    </div>
    <div class="row company">
        我們一起去科技股份有限公司 版權所有Copyright 2006-2018, All Rights Reserved 蘇ICP備16007882
    </div>

</footer>

</body>
</html>

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章