手機端自適應字體大小和元素寬度自適應


以前在做手機端頁面時候通過媒體查詢的方法定義字體或者寬高。

這樣看設計稿切圖時一切字體大小、內容寬度全靠感覺去定義,media定義好之后,拿起鍵盤就是干。

字體、寬高都用rem來定義,此方法略爽!

@media (min-width:0px){
    html{font-size:12px;}
}
@media (min-width: 320px){
    html{font-size:12px;}
}
@media (min-width: 340px){
    html{font-size:13px;}
}
@media (min-width: 360px){
    html{font-size:14px;}
}
@media (min-width: 380px){
    html{font-size:15px;}
}
@media (min-width: 400px){
    html{font-size:15px;}
}
@media (min-width: 420px){
    html{font-size:16px;}
}

現在找到了一個方法,頁面插入一段js,切圖時看設計稿多寬頁面就定義多大的寬度,字體的大小和內容的寬高就看設計稿的px

比如是24px,那么寫樣式就是1.5rem

這個時候牽扯算法1rem = 16px

<script type="text/javascript">
    function fontSize(){
        var deviceWidth=document.documentElement.clientWidth>768?768:document.documentElement.clientWidth;
        document.documentElement.style.fontSize=(deviceWidth/25)+"px";
    }
    fontSize();
    window.onresize=fontSize;
</script>

插入一段我自己寫的測試例子

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0" />
    <title>自適應字體大小和元素高度</title>
    <style type="text/css">
        *{margin: 0;padding: 0;text-align: center;}
        h1{font-size: 2rem;padding: 2rem;}
        p{font-size: 1rem;padding: 1px;}
        div{width: 5rem;height: 4rem;background-color: #f00;}
    </style>
    <script type="text/javascript" src="http://code.jquery.com/jquery-latest.js"></script>
    <script type="text/javascript">
        function fontSize(){
            var deviceWidth=document.documentElement.clientWidth>768?768:document.documentElement.clientWidth;
            document.documentElement.style.fontSize=(deviceWidth/25)+"px";
        }
        fontSize();
        window.onresize=fontSize;
    </script>
</head>
<body>
    <h1>標題</h1>
    <p>內容</p>
    <div></div>
</body>
</html>

這個方法px准確率高,唯一美不中足的是算起來麻煩,兩種方法看個人習慣了

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM