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

javascript用rem來做響應(yīng)式開發(fā)

 更新時(shí)間:2018年01月13日 09:25:19   作者:yuezhongbao  
這篇文章主要介紹了javascript用rem來做響應(yīng)式開發(fā),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

電腦版的商城昨晚做完了,今天趕著做手機(jī)端的,提到手機(jī)端的網(wǎng)站第一個(gè)想到的就是要 適應(yīng)不同手機(jī)屏幕的寬度,保證在不同手機(jī)上都能正常顯示給用戶,我之前做這類網(wǎng)站都是無腦引進(jìn)bootstrap的。但前一個(gè)項(xiàng)目做完之后我發(fā)現(xiàn)bootstrap雖好,但里面的各種樣式我利用的很少,最多用到它排版,當(dāng)網(wǎng)站最后上傳的時(shí)候你會(huì)發(fā)現(xiàn),即使壓縮之后,它也會(huì)占用相當(dāng)大的一部分,所以這次我想自己用原生寫,響應(yīng)式開發(fā)(我現(xiàn)在知道的尚淺)目前我了解有

1.百分比法:

顧名思義,頁面的元素的margin,padding,width,height,等等都用%來計(jì)算,CSS中的百分比中的百指的是什么,指的是父元素,所有百分比都是這樣的。子元素寬度50%,那么父元素的寬度就是百,子元 素的padding-left:50%,父元素的寬度是百,子元素的margin-top:20%,那么父元素的高是百。所以body默認(rèn)寬度是屏幕寬度 (PC中指的是瀏覽器寬度)子孫元素按百分比定位(或指定尺寸)就可以了,這只適合布局簡單的頁面,復(fù)雜的頁面實(shí)現(xiàn)很困難。

2.媒體查詢:

這個(gè)是css3中給出的,我們要解決的問題是適應(yīng)手機(jī)屏幕,這個(gè)媒體查詢正是為解決這個(gè)問題而生,媒體查詢的功能就是為不同的媒體設(shè)置不同的css樣 式,這里的“媒體”包括頁面尺寸,設(shè)備屏幕尺寸等,最常用的形式

phone:@media screen and (max-width:767px) {/手機(jī)中樣式/}

pad:@media screen and (max-width:991px)and(min-width:768) {/平板中樣式/}

pc:@media screen and (min-width:992px){/電腦中樣式/}

...(你還可以設(shè)置更多節(jié)點(diǎn))

用媒體查詢的話要保證每個(gè)像素下都有對(duì)應(yīng)的適配效果顯然你要設(shè)置更小的寬度范圍;

3.還有就是css3的單位rem:

rem就是將根節(jié)點(diǎn)html的font-size的值作為整個(gè)頁面的基準(zhǔn)尺寸,例如<html style="font-size:10px">那么1rem=10px;如何做到適配呢?那就要用到j(luò)s在頁面加載時(shí)獲取window的寬度(瀏覽器窗口的寬度)$(window).width();在開發(fā)手機(jī)頁面的時(shí)候,一般我們?cè)O(shè)置最大寬度為640px,因?yàn)?40px可以保證在至今最寬的手機(jī)上顯示時(shí)網(wǎng)頁兩端剛好貼合屏幕,那接下來我就舉一個(gè)小例子。

屏幕放大縮小這三個(gè)div也同樣還在一行等比放大縮小

html

<div class="container">
  <div class="box">1</div>
  <div class="box">2</div>
  <div class="box">3</div>
</div>

css

<style>
  html{font-size: 20px;}
  .container{
    max-width: 640px;
    border:1px solid red;
    margin:0 auto;
    overflow: hidden;
    box-sizing: border-box;
  }
  .box{
    float: left;
    width:10.6rem;
    //我這里設(shè)置html的font-size:20px;最大
寬為640px,即相當(dāng)于640/20=32rem;一行有3個(gè)div,所以每個(gè)div寬10.6rem

你也可以像論壇里面講的那樣設(shè)置html的font-size:62.5%;因?yàn)闉g覽器默認(rèn)像素16px;乘以62.5%之后為整數(shù)10px;方便計(jì)算

    height:10.6rem;
    border:1px solid #000;
    box-sizing: border-box;
  }
</style>

js

<script>
 window.onresize = window.onload = function () {
   var w = $(window).width();
   if(w<640){
     var size = 20*w/640;//640的時(shí)候
對(duì)應(yīng)html的font-size為20,那么寬度為w是對(duì)應(yīng)
的font-size可這么求
     $('html').css('fontSize',size+'px');
   }
 }
</script>

注意這里有一個(gè)小坑,當(dāng)你把這個(gè)小demo拿到谷歌瀏覽器里面驗(yàn)證的時(shí)候,你會(huì)發(fā)現(xiàn)開始這3個(gè)div會(huì)隨著你瀏覽器窗口縮小而縮小,到達(dá)某個(gè)值后就不動(dòng)了,原因是谷歌瀏覽器默認(rèn)支持html的font-size最小值為10px;在小于這個(gè)值就不會(huì)再小了,這是我當(dāng)時(shí)碰到的問題花了快兩個(gè)小時(shí)上網(wǎng)找,一遍遍演示也都沒想明白,最后終于查到這么個(gè)非人為原因.

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

相關(guān)文章

  • JS iFrame加載慢怎么解決

    JS iFrame加載慢怎么解決

    這篇文章主要介紹了JS iFrame加載慢的解決方法,非常實(shí)用,感興趣的朋友一起學(xué)習(xí)吧
    2016-05-05
  • 原生JS實(shí)現(xiàn)特效留言框

    原生JS實(shí)現(xiàn)特效留言框

    這篇文章主要為大家詳細(xì)介紹了原生JS實(shí)現(xiàn)特效留言框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-08-08
  • fullCalendar日歷插件玩法示例解析

    fullCalendar日歷插件玩法示例解析

    這篇文章主要介紹了fullCalendar日歷插件玩法示例解析,包括Fullcalendar安裝,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-01-01
  • 詳解http訪問解析流程原理

    詳解http訪問解析流程原理

    這篇文章主要介紹了詳解http訪問解析流程原理的相關(guān)資料,希望通過本文能幫助到大家,讓大家理解掌握這部分內(nèi)容,需要的朋友可以參考下
    2017-10-10
  • js 關(guān)鍵詞高亮(根據(jù)ID/tag高亮關(guān)鍵字)案例介紹

    js 關(guān)鍵詞高亮(根據(jù)ID/tag高亮關(guān)鍵字)案例介紹

    關(guān)鍵詞高亮在開發(fā)中會(huì)帶來很多的方便,關(guān)鍵詞高亮包括:根據(jù)ID高亮關(guān)鍵字/根據(jù)Tag名高亮關(guān)鍵字等等,感興趣的朋友可以了解下,希望本文對(duì)你有所幫助
    2013-01-01
  • JavaScript Event學(xué)習(xí)補(bǔ)遺 addEventSimple

    JavaScript Event學(xué)習(xí)補(bǔ)遺 addEventSimple

    這里有個(gè)addEventSimple和removeEventSimple函數(shù),有時(shí)候需要不那么顯眼的事件處理程序的時(shí)候我就用這兩個(gè)函數(shù)注冊(cè)。
    2010-02-02
  • Express與NodeJs創(chuàng)建服務(wù)器的兩種方法

    Express與NodeJs創(chuàng)建服務(wù)器的兩種方法

    本文主要介紹了NodeJs創(chuàng)建Web服務(wù)器;Express創(chuàng)建Web服務(wù)器的兩種方法,具有一定的參考價(jià)值,下面跟著小編一起來看下吧
    2017-02-02
  • JavaScript Window 打開新窗口(window.location.href、window.open、window.showModalDialog)

    JavaScript Window 打開新窗口(window.location.href、windo

    本文主要介紹了JavaScript Window 打開新窗口的三種方式,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • bootstrap table插件的分頁與checkbox使用詳解

    bootstrap table插件的分頁與checkbox使用詳解

    這篇文章主要為大家詳細(xì)介紹了bootstrap table插件的分頁與checkbox使用詳解,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • JS實(shí)現(xiàn)簡單省市二級(jí)聯(lián)動(dòng)

    JS實(shí)現(xiàn)簡單省市二級(jí)聯(lián)動(dòng)

    這篇文章主要為大家詳細(xì)介紹了JS實(shí)現(xiàn)簡單的省市二級(jí)聯(lián)動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2019-11-11

最新評(píng)論