亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

移動(dòng)端布局之動(dòng)態(tài)rem的實(shí)現(xiàn)

  發(fā)布時(shí)間:2019-05-21 15:53:32   作者:胡志武98   我要評(píng)論
這篇文章主要介紹了移動(dòng)端布局之動(dòng)態(tài)rem的實(shí)現(xiàn)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

動(dòng)態(tài)rem

1. 首先我們先介紹當(dāng)下的長(zhǎng)度單位

px 像素

em 一個(gè)M的寬度 / 一個(gè)漢字的寬度 1em == 自身的 font-size

rem 全稱 root em 是根元素(html)的 font-size

vh 全稱 viewport height 100vh == 視口高度

vw 全程 viewport width 100vw == 視口寬度

因?yàn)榫W(wǎng)頁的默認(rèn)font-size: 16px 所以1rem默認(rèn)是 16px chrome 的最小字體像素默認(rèn)是 12px

一個(gè)元素在沒有設(shè)置font-size的情況下會(huì)去繼承父元素的font-size

2. 移動(dòng)端的布局

移動(dòng)端的布局一般就兩種

  • 一是整體縮放
  • 二是百分比布局

 先說整體縮放

整體縮放,其實(shí)就是將pc端的網(wǎng)頁縮小到手機(jī)端屏幕能看到網(wǎng)頁全貌的大小

蘋果手機(jī)剛出來時(shí)就是使用這種布局,蘋果公司研究發(fā)現(xiàn)世界上大多數(shù)的網(wǎng)頁寬度是980px,然而蘋果手機(jī)的寬度像素是320px,所以蘋果手機(jī)的瀏覽器用320像素的屏幕寬度去模擬980px的寬度,實(shí)現(xiàn)了整體縮放

為了看到效果,要將 <meta name="viewport"> 這一部分刪除

 <style>
        div{
            width:980px;
            margin:0 auto;
            background:#f0f0f0;
        }
        ul{
            list-style:none;
        }
        li{
            float:left;
            margin-left:10px;    
        }
        clearfix::after{
            content:"";
            display:block;
            clear:both;
        }
    </style>
</head>
<body>
    <div>
        <ul>
            <li>選項(xiàng)1</li>
            <li>選項(xiàng)2</li>
            <li>選項(xiàng)3</li>
            <li>選項(xiàng)4</li>
            <li>選項(xiàng)5</li>
            <li>選項(xiàng)6</li>
        </ul>
    </div>
</body>

但這種整體縮放的用戶體驗(yàn)并不好,所以pass,我們來講百分比布局

百分比布局

//百分比布局
<style>
        .child{
            background-color:#ccc;
            text-align:center;
            width:40%;
            margin:10px 5%;
            float:left;
        }
        .clearfix::after{
            content:"";
            display:block;
            clear:both;
        }
    </style>
</head>
<body>
    <div class="parent clearfix">
        <div class="child">選項(xiàng)1</div>
        <div class="child">選項(xiàng)2</div>
        <div class="child">選項(xiàng)3</div>
        <div class="child">選項(xiàng)4</div>
    </div>
</body>

可以看到百分比布局能自動(dòng)適應(yīng)屏幕寬度。

但是百分比布局有個(gè)缺點(diǎn),寬度和高度不能做任何關(guān)聯(lián)

可以看上面的gif圖,寬度一直變長(zhǎng),然而高度沒有變化

為了讓選項(xiàng)方塊的高度是寬度的一半,實(shí)現(xiàn)該效果我們需要知道屏幕的寬度,再來確定選項(xiàng)的寬度和高度

這里可以使用vw,但vw的兼容性比較差,我們可以使用rem來代替vw

首先rem是以html的font-size為基準(zhǔn)的,所以我們可以讓html的font-size==pageWidth

<script>
	let pageWidth = window.innerWidth;
    document.write('<style>html{font-size:'+ pageWidth/10 +'px}</style>')
</script>

為了更好的使用rem,這里1rem等于屏幕寬度的10分之1。注意不能做到1rem==屏幕的百分之1。因?yàn)闉g覽器的最小 font-size是12px ;

按如上改動(dòng)代碼

<style>
.child{
            background-color:#ccc;
            text-align:center;
            width:4rem;
            height:2rem;
            margin:10px 0.05rem;
            float:left;
            line-height:2rem;
        }
        .clearfix::after{
            content:"";
            display:block;
            clear:both;

        }
</style>
</head>
<body>
    <div class="parent clearfix">
        <div class="child">選項(xiàng)1</div>
        <div class="child">選項(xiàng)2</div>
        <div class="child">選項(xiàng)3</div>
        <div class="child">選項(xiàng)4</div>
    </div>
</body>

效果入圖

可以看到寬度和高度都能按百分比變化了,但是我們會(huì)發(fā)現(xiàn)一個(gè)很麻煩的東西,設(shè)計(jì)師給我們的設(shè)計(jì)稿,我們卻必須把每個(gè)元素的像素單位換算為rem。這里我們就要scss來換算px了

3.scss動(dòng)態(tài)換算px

@function pxToRem($px){
    @return $px/$designWidth*10+rem;//10是把整個(gè)屏幕分為10rem
}
$designWidth:320;//設(shè)計(jì)稿寬度
.child{
    background-color:#ccc;
    text-align:center;
    width:pxToRem(128);//4rem;
    height:pxToRem(64);//2rem;
    margin: 10px pxToRem(1.6);
    float:left;
    line-height:pxToRem(64);
}
.clearfix::after{
    content:"";
    display:block;
    clear:both;

}

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

相關(guān)文章

最新評(píng)論