欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

第一次接觸神奇的Bootstrap

 更新時間:2016年10月14日 11:35:01   作者:葉超Luka  
第一次接觸神奇的Bootstrap,Bootstrap提供了用戶友好、擴(kuò)瀏覽器的解決方案,具有一定的參考價值,感興趣的小伙伴們可以參考一下

作為Web前端開發(fā)框架,Bootstrap為大多數(shù)標(biāo)準(zhǔn)的UI設(shè)計常見提供了用戶友好、擴(kuò)瀏覽器的解決方案。

1.下載Bootstrap

打開官方網(wǎng)址http://getbootstrap.com/ 進(jìn)行下載。

2.準(zhǔn)備項目模板文件夾

接下來,我們?yōu)榈谝粋€項目創(chuàng)建一個文件夾以及一些基本的文件。謂詞我們還要用到HTML5樣板文件 HTML5 Boilerplate(H5BP),然后把Bootstrap的有用文件復(fù)制過去。

2.1 下載H5BP

訪問網(wǎng)站鏈接地址:https://html5boilerplate.com/ ,下載B5BP。

解壓后,修改文件夾名為Bootstrap_First,其目錄結(jié)構(gòu)如下:

2.2然后刪除和更新下必要的樣板文件

刪除下列至于H5BP相關(guān)的文件夾和文件:

□ 因為稍后要使用LESS創(chuàng)建自己的CSS文件,所以先刪除css文件夾。

□ doc 文件夾及其中內(nèi)容

2.3 理解樣板中的.htaccess文件

這個文件中的內(nèi)容不一定全部都用,這取決于主機設(shè)置和站點需求。這個文件的一個主要用途是保證站點性能最優(yōu)。

2.4 更新必要的樣板文件

樣板中的下列文件提供了項目的標(biāo)準(zhǔn)信息,根據(jù)需要可以更新它們、直接使用它們或者就放那不管。

□humans.txt:這個文件記載貢獻(xiàn)者,H5BP、Bootstrap的,還有其他貢獻(xiàn)者。

□LICENSE.txt:在H5BP許可前面,加上你基于該許可構(gòu)建的網(wǎng)站的許可信息,在H5BP許可后,加上Bootstrap以及其他站點中用到的重要的庫的許可信息。

2.5 更新站點桌面和觸摸設(shè)備圖標(biāo)

不要忘了用自己項目的圖標(biāo)替換 Boilerplate 默認(rèn)的圖標(biāo)文件。

3.加入Bootstrap文件

3.1 字體

從Bootstrap的主文件夾中,把fonts文件夾復(fù)制粘貼到Bootstrap_First文件夾中。這個文件夾里包含著Bootstrap附帶的重要的Glyphicon字體。

保險起見,再在fonts文件夾中放一個跨域友好的.htaccess文件:

復(fù)制代碼 代碼如下:
<FilesMatch "\.(ttf|otf|eot|woff)$"><IfModule mod_headers.c>Header set Access-Control-Allow-Origin "*"</IfModule></FilesMatch>

其目的是保證即使站點根目錄下沒有放H5BP的.htaccess文件,也不會出現(xiàn)字體問題。

3.2 JavaScript

接下來就是加入Bootstrap的JavaScript文件。H5BP的文件夾中已經(jīng)包含了幾個JavaScript文件如下:

在js文件夾里新建文件夾bootsreap,然后把Bootstrap的js文件夾中的腳本都復(fù)制過來。下面的截圖顯示了Bootstrap隨帶的插件。每個插件一個文件:

把這些插件文件集中保存到新建的js/bootstrap 文件夾,便于優(yōu)化網(wǎng)站性能,即可以按需選用插件、排除其他文件并縮減文件大小。

在開發(fā)期間,保持所有Bootstrap的插件都可用也是一個辦法。這樣,如果想添加個折疊、提示或者傳送帶效果,都可以信手拈來。

H5BP采用的方法是把所有插件代碼復(fù)制到一個 plugins.js模板文件中。這是結(jié)束開發(fā)之后的最佳做法,因為這樣可以減少HTTP請求,加快站點速度。(換句話說,一個80K的文件,比加載4個20K的文件速度更快。)

打開Bootstrap文件夾中包含分發(fā)文件的dist文件夾。在這個文件夾中的js文件夾里,包含著 bootstrap.js 和 bootstrap.min.js,它們就是包含 Bootstrap所有插件代碼的大文件。

把bootstrap.min.js 的所有代碼復(fù)制到plugins.js 里。

然后把Bootstrap文件夾里的less文件夾也復(fù)制到項目文件夾中。

4.構(gòu)造HTML模板

打開項目中的 index.html 文件進(jìn)行編輯。這個示例標(biāo)記文件來自H5BP,體現(xiàn)了一些最佳實踐和建議方案。我們就以這個為基礎(chǔ),把它整合到Bootstrap的工作流中。

瀏覽一下整個文件,其中有幾個有意思的地方,H5BP文檔中都有詳細(xì)說明,目前的5.3.0版本的鏈接地址為:https://github.com/h5bp/html5-boilerplate/blob/5.3.0/dist/doc/extend.md 。下面也簡單介紹下,按次序來:

□ HTML5 文檔類型聲明:

復(fù)制代碼 代碼如下:
<!doctype html>

□ 接下來是幾個meta標(biāo)簽

 ■ 用于指定字符集的:

復(fù)制代碼 代碼如下:
<meta charset="utf-8">

 ■ 告訴IE使用最新版的渲染引擎

復(fù)制代碼 代碼如下:
<meta http-equiv="x-ua-compatible" content="ie=edge">

 ■ 預(yù)留給描述站點用的:

復(fù)制代碼 代碼如下:
<meta name="description" content="">

 ■ 針對移動瀏覽器的視口標(biāo)簽

復(fù)制代碼 代碼如下:
<meta name="viewport" content="width=device-width, initial-scale=1">

□ 接下來是兩個樣式表的鏈接

復(fù)制代碼 代碼如下:
<link rel="stylesheet" href="css/normalize.css"><link rel="stylesheet" href="css/main.css">

□ 再下面就是加載Modernizr腳本的script標(biāo)簽。這個腳本回味IE8提供HTML5“墊片腳本”,以便它能識別HTML5的分區(qū)元素:

復(fù)制代碼 代碼如下:
<script src="js/vendor/modernizr-2.8.3.min.js"></script>

□ 接下來是IE條件注釋,包含推薦用戶把舊版本IE升級到新版本的消息:

<!--[if lt IE 8]>
<p class="browserupgrade">You are using an <strong>outdated</strong> browse. ...
<![endif]-->

□ 緊接著是一段文本

□ 隨后是托管在谷歌服務(wù)器上的jQuery鏈接,以及一個本地jQuery的后備鏈接:

復(fù)制代碼 代碼如下:
<script src="https://code.jquery.com/jquery-1.12.0.min.js"></script><script>window.jQuery || document.write('<script src="js/vendor/jquery-1.12.0.min.js"><\/script>')</script>

□ 下面就是plugins.js 和main.js的鏈接,別分保存JavaScript插件代碼和我們編寫的代碼:

復(fù)制代碼 代碼如下:
<script src="js/plugins.js"></script><script src="js/main.js"></script>

□ 谷歌的Analytics 腳本:

<!-- Google Analytics: change UA-XXXXX-X to be your site's ID. -->
<script>
 (function(b,o,i,l,e,r){b.GoogleAnalyticsObject=l;b[l]||(b[l]=
 function(){(b[l].q=b[l].q||[]).push(arguments)});b[l].l=+new Date;
 e=o.createElement(i);r=o.getElementsByTagName(i)[0];
 e.src='https://www.google-analytics.com/analytics.js';
 r.parentNode.insertBefore(e,r)}(window,document,'script','ga'));
 ga('create','UA-XXXXX-X','auto');ga('send','pageview');
</script>

對此次的任務(wù)而言,我們需要對這個模板中的元素進(jìn)行如下操作:

(1) 設(shè)定我們站點的標(biāo)題,針對舊版本瀏覽器用戶更新現(xiàn)有的IE條件注釋;

(2) 基于LESS文件編譯Bootstrap的CSS,添加基本的頁面內(nèi)容;

(3) 整合Bootstrap的JavaScript插件,確保響應(yīng)式的導(dǎo)航條(navbar)正常響應(yīng)。

做完這幾件事后,我們就可以開始設(shè)計自己的網(wǎng)站了。

5.設(shè)定站點標(biāo)題

復(fù)制代碼 代碼如下:
<title>初識 Bootstrap</title>

5.1 調(diào)整過時的瀏覽器消息

模板中的消息針對老瀏覽器用戶。

<!--[if lt IE 8]>
<p class="browserupgrade">You are using an <strong>outdated</strong> browser. Please <a href="
http://browsehappy.com/">
upgrade your browser</a> to improve your experience.</p>
<![endif]-->

其中包含的鏈接http://browsehappy.com/ ,該網(wǎng)站是一個推薦瀏覽器升級的站點。

5.2 設(shè)置主結(jié)構(gòu)元素

下面開始準(zhǔn)備頁面內(nèi)容,目前還只有一個段落。我們可以稍微添加一些內(nèi)容:

□包含Logo的導(dǎo)航的頁頭區(qū);

□包含頁面內(nèi)容的內(nèi)容區(qū);

□包含版權(quán)和社交媒體鏈接的頁腳區(qū)。

添加這些內(nèi)容,都會基于最新的HTML最佳實踐來做,而且會考慮ARIA(Accessible Rich Internet Applications,可訪問富因特網(wǎng)應(yīng)用)的role屬性(即banner、navigation、main和contentinfo 這幾個角色)。HTML5后來又增加了 <main cole="main></main> 元素,目的是專門為頁面或分區(qū)中的主內(nèi)容提供一個專用的元素。要了解更多信息,可以參照鏈接:https://www.sitepoint.com/how-to-use-aria-effectively-with-html5/

找到下面的代碼:

<!-- Add your site or application content here -->
<p>Hello world! This is HTML5 Boilerplate.</p>

修改為:

<header role="banner">
<nav role="navigation">
</nav>
</header>

<main role="main">
<h1>Main Heading</h1>
<p>Content specific to this page goes here.</p>
</main>

<footer role="contentinfo">
<p><small>Copyright &copy; Luka Ye</small></p>
</footer>

這就是我們頁面的基本結(jié)構(gòu)和內(nèi)容。

6.導(dǎo)航條

我們先把Bootstrap特有的元素設(shè)置好,那就是導(dǎo)航條。

作為起點,我們可以暫時就使用 Bootstrap基本的導(dǎo)航條。為此,從Bootstrap文檔中拿來它的導(dǎo)航條代碼,然后做出如下調(diào)整:

□添加了 navbar-static-top 類,因為我們希望導(dǎo)航條能夠定位到窗口頂部,但能夠隨頁面滾動而滾動。

□把項目名稱連接到 index.html;

□把原來的父div標(biāo)簽改成了語義化的HTML5 nav 標(biāo)簽。

調(diào)整后,其header元素如下:

<header role="banner">
<nav role="navigation" class="navbar nav-static-top navbar-default">
<div class="container">
<div class="navbar-header">
<a class="navbar-brand" href="index.html">初識 Bootstrap</a>
</div>
<ul class="nav navbar-nav">
<li class="active"><a href="index.html">Home</a></li>
<li><a href="#">Link</a></li>
<li><a href="#">Link</a></li>
</ul>
</div>
</nav>
</header>

保存結(jié)果,其導(dǎo)航條的顯示效果如下:

內(nèi)容有了。現(xiàn)在,我們特別需要自己的樣式表。先來變異并鏈接Bootstrap默認(rèn)的樣式表。

7.編譯和鏈接默認(rèn)的Bootstrap CSS

7.1 編譯Bootstrap CSS

找到less/bootstrap.less 并打開它,這個文件導(dǎo)入了less文件夾中所有其他文件。編譯后,這個文件會生成完整的bootstrap.css樣式表。而這就是我們第一步要做的。

PS:LESS的文檔地址為http://lesscss.org/

如果一切沒有編譯過LESS文件,需要下載和安裝它的編譯器。

□ Window 用戶,下載和安裝這個編譯器:

■ WinLess(免費桌面應(yīng)用),地址為 http://winless.org

□ Mac 用戶可以選擇下載:

■ Crunch 應(yīng)用(免費),地址為 http://crunchapp.net/

■ CodeKit(收費),地址為 http://incident57.com/codekit/

下載了選擇的LESS編譯器之后,安裝,打開。然后就可以按照下面的步驟來做了。

(1) 在根目錄創(chuàng)建css文件夾。

(2) 使用下列的一種把主文件(css、fonts、img、js和 less文件夾的父文件夾)添加到編譯器:

■ 把文件夾拖到編譯器窗口中;

■ 在編譯器窗口中找到 Add folder 按鈕,點擊選擇主文件夾。

(3) 然后再編譯器窗口中可以看到加載的LESS文件,找到less/bootstrap.lesss文件

(4) 右鍵單擊less/bootstrap.less 文件,選擇 Select output file,找到剛創(chuàng)建的css文件夾,此時輸出文件名應(yīng)該自動會變成bootstrap.css,單擊“保存”。

(5) 選擇輸出路徑和文件名,點擊Compile。

(6) css文件夾中會出現(xiàn)編譯生成的 bootstrap.css文件。

(7) 編譯成功后,唯一要注意的是這個文件名是否與index.html中鏈接的文件名相同。

(8) 在 index.html 中,刪除指向 css/normalize.css 的樣式表鏈接,因為這個樣式表已經(jīng)包含在 Bootstrap中了。

(9) 復(fù)制一份bootstrap.css,重命名為main.css。

(10) 瀏覽器打開index.html文件,可以看到起默認(rèn)的導(dǎo)航樣式如下,從排版和布局上有所增強,這說明CSS已經(jīng)生效。

7.2 完成響應(yīng)式導(dǎo)航條

為了在 Bootstrap 響應(yīng)式導(dǎo)航條基礎(chǔ)上完成我們的導(dǎo)航條,還得再增加兩個新元素,以及相應(yīng)的類和data屬性。相關(guān)的用法可以參考 Bootstrap的Components 文檔,在Navbar選項卡下:http://getbootstrap.com/components/#navbar

先按照下列步驟添加額外的標(biāo)記。

(1) 搜索到 <div>,在一個元素中添加一個navbar-toggle按鈕,用于展開和收起響應(yīng)式導(dǎo)航條。下面就是這個按鈕的全部標(biāo)記:

<div class="navbar-header">
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="index.html">初識 Bootstrap</a>
</div>

簡單解釋下以上代碼:

■ 按鈕中的navbar-toggle 類用于應(yīng)用CSS樣式;

■ 后面的數(shù)據(jù)屬性 data-toggle 和 data-target 是Bootstrap 的JavaScript 插件要用的,分部表示預(yù)期行為和預(yù)期目標(biāo)(即 collapse 和類名為 navbar-collapse 的元素,這個元素后面會添加)

■ 類名為 icon-bar 的span 元素是CSS用來創(chuàng)建按鈕中的三道杠按鈕用的。

(2) 接下來把導(dǎo)航項包裝在一個收起的div中,即用帶有適當(dāng) Bootstrap類的div把<ul>包裝起來:

<div class="navbar-collapse collapse">
<ul class="nav navbar-nav">
<li class="active"><a href="index.html">Home</a></li>
<li><a href="#">Link</a></li>
<li><a href="#">Link</a></li>
</ul>
</div>

在前面兩步中,我們把代碼分分隔成兩部分,而且都位于 <div>中。

好了,在任何一個現(xiàn)代瀏覽器(IE9 或Firefox、Chrome、Safari等的最新版本)中,拖動窗口縮小到小于980像素。其顯示效果如下:

7.3 排除故障

如果一切順利,那么說明你已經(jīng)成功地把LESS編譯成CSS,而且也成功地包含了Bootstrap的JavaScript插件。如果不順利,那就要仔細(xì)檢查下咯。

7.4 支持IE8

要支持IE8,需要一段JavaScript代碼讓瀏覽器能響應(yīng)媒體查詢。這段代碼就是Scott Jehl的 respond.js “膩子腳本”。

Bootstrap自身的文檔推薦這樣做以兼容IE8。相關(guān)信息可以參考這里:http://getbootstrap.com/getting-started/#browsers

為了針對IE8 應(yīng)用這段腳本,需要針對IE8的條件注釋:

<!--[if lt IE 9]>
...
<![endif]-->

另外,根據(jù)Andy Clarke的建議,為了不讓并不需要這個腳本的Windows 移動設(shè)備加載該腳本,還應(yīng)該排除IE移動版瀏覽器,具體參見他的在線代碼塊 320andup,地址是:https://github.com/malarkey/320andup/ 。

Clarke建議的條件注釋如下:

<!--[if (lt IE 9) & (!IEMobile)]>
...
<![endif]-->

有了條件注釋,下面就是在站點模板文件中添加膩子腳本了,步驟如下:

(1) 打開https://github.com/scottjehl/Respond ,下載源代碼。

(2) 解壓縮,找到名為respond.min.js 的壓縮版。

(3) 把它復(fù)制到項目文件夾中的 js/vendor 目錄下,與jQuery 和 Modernizr放到一塊。

(4) 然后,把下面幾行加載 respond.js 文件代碼添加到 index.html 中,包括針對IE的條件注釋,就加載 Modernizr的代碼下面:

復(fù)制代碼 代碼如下:
<!-- Modernizr --><script src="js/vendor/modernizr-2.8.3.min.js"></script><!-- Respond.js for IE 8 or less only --><!--[if (lt IE 9) & (!IEMobile)]><script src="js/vendor/respond.min.js"></script><![endif]-->

(5) 好了,這樣IE8 就可以支持媒體查詢響應(yīng)視口大小變化了。

PS:如果你想測試添加膩子腳本的結(jié)果,但又沒有IE8 瀏覽器,可以使用一個在線服務(wù),叫Browsershots,地址是:http://browsershots.org/ ,這是免費的。還有一個收費的,叫BrowserStack,地址是: https://www.browserstack.com/(試用免費)。

如果大家還想深入學(xué)習(xí),可以點擊這里進(jìn)行學(xué)習(xí),再為大家附兩個精彩的專題:Bootstrap學(xué)習(xí)教程 Bootstrap實戰(zhàn)教程

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 利用javascript打開模態(tài)對話框(示例代碼)

    利用javascript打開模態(tài)對話框(示例代碼)

    本篇文章主要是對利用javascript打開模態(tài)對話框的示例代碼進(jìn)行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助
    2014-01-01
  • JavaScript實現(xiàn)的XML與JSON互轉(zhuǎn)功能詳解

    JavaScript實現(xiàn)的XML與JSON互轉(zhuǎn)功能詳解

    這篇文章主要介紹了JavaScript實現(xiàn)的XML與JSON互轉(zhuǎn)功能,結(jié)合實例形式分析了基于javascript的xml與json相關(guān)轉(zhuǎn)換功能實現(xiàn)技巧,需要的朋友可以參考下
    2017-02-02
  • JavaScript控制各種瀏覽器全屏模式的方法、屬性和事件介紹

    JavaScript控制各種瀏覽器全屏模式的方法、屬性和事件介紹

    瀏覽器全屏模式的啟動函數(shù)requestFullscreen仍然需要附帶各瀏覽器的js方言前綴,相信下面這段代碼需要你花大量的搜索才能湊齊:
    2014-04-04
  • ejs v9 javascript模板系統(tǒng)

    ejs v9 javascript模板系統(tǒng)

    我的模板系統(tǒng)升一下級, 繼續(xù)在新公司里面用。 現(xiàn)在幾在互聯(lián)網(wǎng)公司沒有不用javascript模板了, 什么TX, 百度, 新浪, 360什么的, 最后瀑布流的流行, 里面又有許多用到模板
    2012-03-03
  • layui的layer.confirm如何獲取按鈕焦點

    layui的layer.confirm如何獲取按鈕焦點

    因為ayer.confirm的按鈕并非采用button,而是a標(biāo)簽,所以獲取按鈕焦點獲取不到,要采用別的方法,下面介紹在ie11中和ie8中不同的寫法,對layui layer.confirm獲取按鈕焦點相關(guān)知識感興趣的朋友一起看看吧
    2023-11-11
  • JavaScript 中使用 Generator的方法

    JavaScript 中使用 Generator的方法

    Generator 是一種非常強力的語法,但它的使用并不廣泛。這篇文章主要介紹了如何在 JavaScript 中使用 Generator,需要的朋友可以參考下
    2017-12-12
  • js字符串操作函數(shù)總結(jié)及使用方法示例

    js字符串操作函數(shù)總結(jié)及使用方法示例

    這篇文章主要介紹了js字符串操作函數(shù)toString、split、length、indexOf、lastIndexOf、replace、replaceAll、charAt、charCodeAt、contact、slice、substring、substr、match、exec、search、trim、includes
    2023-08-08
  • nest.js 使用express需要提供多個靜態(tài)目錄的操作方法

    nest.js 使用express需要提供多個靜態(tài)目錄的操作方法

    這篇文章主要介紹了nest.js 使用express需要提供多個靜態(tài)目錄的操作,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • JS SetInterval 代碼實現(xiàn)頁面輪詢

    JS SetInterval 代碼實現(xiàn)頁面輪詢

    setInterval 是一個實現(xiàn)定時調(diào)用的函數(shù),可按照指定的周期(以毫秒計)來調(diào)用函數(shù)或計算表達(dá)式。下面通過本文給大家分享JS SetInterval 代碼實現(xiàn)頁面輪詢,感興趣的朋友一起看看吧
    2017-08-08
  • JavaScript 中如何實現(xiàn)并發(fā)控制

    JavaScript 中如何實現(xiàn)并發(fā)控制

    在日常開發(fā)過程中,你可能會遇到并發(fā)控制的場景,比如控制請求并發(fā)數(shù)。那么在 JavaScript 中如何實現(xiàn)并發(fā)控制呢?在回答這個問題之前,我們來簡單介紹一下并發(fā)控制。
    2021-05-05

最新評論