六個(gè)環(huán)節(jié)分析地方網(wǎng)站如何留住用戶? |
發(fā)布時(shí)間:2016-10-15 文章來源: 瀏覽次數(shù):2954 |
講到響應(yīng)式布局, 相信大家都有一定的了解,響應(yīng)式布局是今年很流行的一個(gè)設(shè)計(jì)理念,跟著移動互聯(lián)網(wǎng)的盛行,為解決如今各式各樣的瀏覽器分辨率以及不同移動設(shè)備的顯示效果, 設(shè)計(jì)師提出了響應(yīng)式布局的設(shè)計(jì)方案。今天就和大家來講講響應(yīng)式布局這件小事,包含什么是響應(yīng)式布局、響應(yīng)式布局的長處和缺點(diǎn)以及響應(yīng)式布局該怎么設(shè)計(jì)(通 過CSS3 Media Query實(shí)現(xiàn)響應(yīng)布局)。 響應(yīng)式布局這件小事 一、什么是響應(yīng)式布局? 響應(yīng)式布局是Ethan Marcotte在2010年5月份提出的一個(gè)概念,簡而言之,就是一個(gè)網(wǎng)站能夠兼容多個(gè)終端——而不是為每個(gè)終端做一個(gè)特定的版本。這個(gè)概念是為解決移動互聯(lián)網(wǎng)瀏覽而誕生的。 響應(yīng)式布局可認(rèn)為不同終真?zhèn)用戶提供更加恬靜的界面和更好的用戶體驗(yàn),而且跟著目前大屏幕移動設(shè)備的普及,用大勢所趨來形容也不為過。跟著越來越多的設(shè)計(jì)師采用這個(gè)技術(shù),我們不僅看到良多的立異,還看到了一些成形的模式。 二、響應(yīng)式布局有哪些長處和缺點(diǎn)? 長處: 面臨不同分辨率設(shè)備靈活性強(qiáng) 能夠快捷解決多設(shè)備顯示適應(yīng)題目 缺點(diǎn): 兼容各種設(shè)備工作量大,效率低下 代碼累贅,會泛起躲藏?zé)o用的元素,加載時(shí)間加長 實(shí)在這是一種折中性質(zhì)的設(shè)計(jì)解決方案,多方面因素影響而達(dá)不到最佳效果 一定程度上改變了網(wǎng)站原有的布局結(jié)構(gòu),會泛起用戶攪渾的情況 三、響應(yīng)式布局該怎么設(shè)計(jì)? 我們在上面了解了什么是響應(yīng)式布局,那在我們的實(shí)際項(xiàng)目中應(yīng)該怎么去設(shè)計(jì)呢?在以往我們設(shè)計(jì)網(wǎng)站的時(shí)候都會受到不同瀏覽器的兼容性的困擾,現(xiàn)在還要 來個(gè)不同尺寸設(shè)備,我們該怎么淡定下來呢?有需求就會有解決方案,呵呵,說到響應(yīng)式布局,就不得不提起CSS3中的Media Query(媒介查詢),這可是個(gè)好東西,易用、強(qiáng)盛、快捷……Media Query是制作響應(yīng)式布局的一個(gè)利器,使用這個(gè)工具,我們可以非常利便快捷的制造出各種豐碩的實(shí)用性強(qiáng)的界面。接下來就一起來深入的了解Media Query。 1、CSS中的Media Query(媒介查詢)是什么? 通過不同的媒體類型和前提定義樣式表規(guī)則。媒體查詢讓CSS可以更精確作用于不同的媒體類型和統(tǒng)一媒體的不同前提。媒體查詢的大部門媒體特性都接受 min和max用于表達(dá)”大于或即是”和”小與或即是”。如:width會有min-width和max-width媒體查詢可以被用在CSS中的 @media和@import規(guī)則上,也可以被用在HTML和XML中。通過這個(gè)標(biāo)簽屬性,我們可以很利便的在不同的設(shè)備下實(shí)現(xiàn)豐碩的界面,特別是移動設(shè) 備,將會運(yùn)用更加的廣泛。 2、media query能夠獲取哪些值? 設(shè)備的寬和高device-width,device-heigth顯示屏幕/觸覺設(shè)備。 渲染窗口的寬和高width,heigth顯示屏幕/觸覺設(shè)備。 設(shè)備的手持方向,橫向仍是豎向orientation(portrait|lanscape)和打印機(jī)等。 畫面比例aspect-ratio點(diǎn)陣打印機(jī)等。 設(shè)備比例device-aspect-ratio-點(diǎn)陣打印機(jī)等。 對象顏色或顏色列表color,color-index顯示屏幕。 設(shè)備的分辨率resolution。 3、語法結(jié)構(gòu)及用法 @media 設(shè)備名 only (選取前提) not (選取前提) and(設(shè)備選取前提),設(shè)備二{sRules} 示例一:在link中使用@media: <link rel=“stylesheet” type=“text/css” media=“only screen and (max-width: 480px),only screen and (max-device-width: 480px)” href=“link.css”/> 上面使用中only可省略,限定于計(jì)算機(jī)顯示器,第一個(gè)前提max-width是指渲染界面最大寬度,第二個(gè)前提max-device-width是指設(shè)備最大寬度。 示例二:在樣式表中內(nèi)嵌@media: @media (min-device-width:1024px) and (max-width:989px),screen and (max-device-width:480px),(max-device-width:480px) and (orientation:landscape),(min-device-width:480px) and (max-device-width:1024px) and (orientation:portrait) {srules} 在示例二中,設(shè)置了電腦顯示器分辨率(寬度)大于或即是1024px(并且最大可見寬度為989px);屏寬在480px及其以下手持設(shè)備;屏寬在 480px以及橫向(即480尺寸平行于地面)放置的手持設(shè)備;屏寬大于或即是480px小于1024px以及垂直放置設(shè)備的css樣式。 從上面的例子可以看出,字符間以空格相連,選取前提包含在小括號內(nèi),srules為兼容設(shè)置的樣式表,包含在中括號里面。only(限定某種設(shè)備,可省略),and(邏輯與),not(排除某種設(shè)備)為邏輯樞紐字,多種設(shè)備用逗號分隔,這一點(diǎn)繼續(xù)了css基本語法。 4、可用設(shè)備名參數(shù): 5、邏輯樞紐字: 6、可用設(shè)備名參數(shù): 7、測試Media Queries 最后,我們需要對我們剛剛設(shè)計(jì)的Media Queries進(jìn)行測試,想要在不同設(shè)備上測試Media Queries的效果,可以使用一個(gè)瀏覽工具來檢修不同尺寸屏幕下的顯示效果,在這里為大家先容一個(gè)不錯的在線工具 – Responsivator,它可以模擬iPhone等各種不同設(shè)備,并且還可以自定義不同尺寸屏幕的顯示效果,只需要輸入一個(gè)url甚至是本地的一個(gè) url,就可以看到網(wǎng)站在不同尺寸屏幕下的顯示效果。 8、通過Media Queries實(shí)現(xiàn)響應(yīng)式布局設(shè)計(jì) 好了,我們明白了什么是Media Query,那我們一起來運(yùn)用到響應(yīng)式布局的設(shè)計(jì)項(xiàng)目中去。設(shè)計(jì)思路很簡樸,首先先定義在尺度瀏覽器下的固定寬度(如果尺度瀏覽器的分辨率為 1024px,那么我們設(shè)置寬為980px),然后用Media Query來監(jiān)測瀏覽器的尺寸變化,當(dāng)瀏覽器的分辨率小于1024px的時(shí)候,則通過Media Query預(yù)設(shè)的樣式表來將頁面的寬度設(shè)置為百分比顯示,這樣子頁面的結(jié)構(gòu)元素就會根據(jù)瀏覽器的的尺寸來進(jìn)行相對應(yīng)的調(diào)整。同理,當(dāng)瀏覽器的可視區(qū)域改變 到某個(gè)值(如果為650px)的時(shí)候,頁面的結(jié)構(gòu)元素根據(jù)Media Query預(yù)設(shè)的層疊樣式表來進(jìn)行相對應(yīng)的調(diào)整?纯次覀兊睦樱 /* 當(dāng)瀏覽器的可視區(qū)域小于980px */ @media screen and (max-width: 980px) { #wrap {width: 90%; margin:0 auto;} #content {width: 60%;padding: 5%;} #sidebar {width: 30%;} #footer {padding: 8% 5%;margin-bottom: 10px;} } /* 當(dāng)瀏覽器的可視區(qū)域小于650px */ @media screen and (max-width: 650px) { #header {height: auto;} #searchform {position: absolute;top: 5px;right: 0;} #content {width: auto; float: none; margin: 20px 0;} #sidebar {width: 100%; float: none; margin: 0;} } 通過上面我們就可以監(jiān)測瀏覽器的可視區(qū)域變化的是時(shí)候我們的頁面結(jié)構(gòu)元素也會相對應(yīng)的變化,當(dāng)然你可以再多設(shè)置幾個(gè)尺寸的監(jiān)測層疊樣式表,這樣子就可以根據(jù)不同尺寸設(shè)備來進(jìn)行響應(yīng)式的布局。為了更好的顯示效果,我們往往還要格局化一些CSS屬性的初始值: /* 禁用iPhone中Safari的字號自動調(diào)整 */ html { -webkit-text-size-adjust: none; } /* 設(shè)置HTML5元素為塊 */ article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; } /* 設(shè)置圖片視頻等自適應(yīng)調(diào)整 */ img { max-width: 100%; height: auto; width: auto\9; /* ie8 */ } .video embed, .video object, .video iframe { width: 100%; height: auto; } 最后要留意的是在頁面的頭部之間加上下面這句∶ <meta name=“viewport” content=“width=device-width; initial-scale=1.0”> meta viewport這個(gè)屬性是在移動設(shè)備上設(shè)置原始大小顯示和是否縮放的聲明。 參數(shù)設(shè)置∶ width – viewport的寬度 height – viewport的高度 initial-scale – 初始的縮放比例 minimum-scale – 答應(yīng)用戶縮放到的最小比例 maximum-scale – 答應(yīng)用戶縮放到的最大比例 user-scalable – 用戶是否可以手動縮放 最后對于在IE瀏覽器中不支持media query的情況,我們可以使用Media Query Javascript來解決,只需要在頁面頭部引用css3-mediaqueries.js即可。示例: <!--[if lt IE 9]> <script src=“http://css3-mediaqueries-js.googlecode.com/svn/trunk/css3-mediaqueries.js”> </script> <![endif]--> |
|