以前在做手機端頁面時候通過媒體查詢的方法定義字體或者寬高。
這樣看設計稿切圖時一切字體大小、內容寬度全靠感覺去定義,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准確率高,唯一美不中足的是算起來麻煩,兩種方法看個人習慣了