<noframes id="7xbfr"><pre id="7xbfr"><output id="7xbfr"></output></pre>

      <big id="7xbfr"><font id="7xbfr"><listing id="7xbfr"></listing></font></big>
        <p id="7xbfr"></p>
        <menuitem id="7xbfr"></menuitem>

          <video id="7xbfr"><mark id="7xbfr"><listing id="7xbfr"></listing></mark></video>
            <form id="7xbfr"></form>

          <delect id="7xbfr"><var id="7xbfr"></var></delect>

          手機端的適配

          時間:2022-03-23 09:01:58 類型:HTML/CSS
          字號:    


          meta 標簽

          <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no">
          <meta name="format-detection" content="telephone=no, email=no">

          方法一: px,vw與rem相結合

                        設計圖 750px, 即 100vw = 750px

                                                    1px     = 0.1333333vw

                                                    1000px = 133.3333vw 

                                                    1rem = 1個html字體的大小

                                                    所以,設計如下樣式,然后所有的設計稿像素 / 1000再加 rem即可

            html{
                      /* 網頁中字體大小最小是12px(0除外) 
                          如果我們設置了一個小于12px的字體,則字體自動設置為12px
                          - 100vw : 一個視口的寬度(即name="viewport" content="width=device-width))
                          - 1vw   : 1%個視口的寬度
                          100vw = 750px(設計圖)
                          0.1333333vw = 1px
                          133.33333   = 1000px
                      */
                      font-size: 133.33333vw;
                  }
                  *{
                      margin:0; padding:0;
                  }
                  .box1{
                      /* -- 1 rem = 1 html字體的大小
                         -- 1 rem = 1000px(設計圖) 
                          按照 750px的設計圖,所有的像素 除以 1000加上rem即可
                          比如: 100px;  寫成 0.1rem
                         */
                      width: 0.1rem;  
                             /* 寬 100 px */
                      height:0.05rem;
                             /* 高 50px */
                      background-color: green;
                  }



          方法二.

          將HTML、body的font-size 設置成100px;

          每次只需將 設計稿的寬度調成640 然后 除以 100

          @media screen and (min-width: 320px) {html{font-size:50px;}}
          @media screen and (min-width: 360px) {html{font-size:56.25px;}}
          @media screen and (min-width: 375px) {html{font-size:58.59375px;}}
          @media screen and (min-width: 400px) {html{font-size:62.5px;}}
          @media screen and (min-width: 414px) {html{font-size:64.6875px;}}
          @media screen and (min-width: 440px) {html{font-size:68.75px;}}
          @media screen and (min-width: 480px) {html{font-size:75px;}}
          @media screen and (min-width: 520px) {html{font-size:81.25px;}}
          @media screen and (min-width: 560px) {html{font-size:87.5px;}}
          @media screen and (min-width: 600px) {html{font-size:93.75px;}}
          @media screen and (min-width: 640px) {html{font-size:100px;}}
          @media screen and (min-width: 680px) {html{font-size:106.25px;}}
          @media screen and (min-width: 720px) {html{font-size:112.5px;}}
          @media screen and (min-width: 760px) {html{font-size:118.75px;}}
          @media screen and (min-width: 800px) {html{font-size:125px;}}
          @media screen and (min-width: 960px) {html{font-size:150px;}}


          方法三: 通過JS實現

          1.核心代碼

          //designWidth:設計稿的實際寬度值,需要根據實際設置
          //maxWidth:制作稿的最大寬度值,需要根據實際設置
          //這段js的最后面有兩個參數記得要設置,一個為設計稿實際寬度,一個為制作稿最大寬度,例如設計稿為750,最大寬度為750,則為(750,750)
          ;(function(designWidth, maxWidth) {
          	var doc = document,
          	win = window,
          	docEl = doc.documentElement,
          	remStyle = document.createElement("style"),
          	tid;
          
          	function refreshRem() {
          		var width = docEl.getBoundingClientRect().width;
          		maxWidth = maxWidth || 540;
          		width>maxWidth && (width=maxWidth);
          		var rem = width * 100 / designWidth;
          		remStyle.innerHTML = 'html{font-size:' + rem + 'px;}';
          	}
          
          	if (docEl.firstElementChild) {
          		docEl.firstElementChild.appendChild(remStyle);
          	} else {
          		var wrap = doc.createElement("div");
          		wrap.appendChild(remStyle);
          		doc.write(wrap.innerHTML);
          		wrap = null;
          	}
          	//要等 wiewport 設置好后才能執行 refreshRem,不然 refreshRem 會執行2次;
          	refreshRem();
          
          	win.addEventListener("resize", function() {
          		clearTimeout(tid); //防止執行兩次
          		tid = setTimeout(refreshRem, 300);
          	}, false);
          
          	win.addEventListener("pageshow", function(e) {
          		if (e.persisted) { // 瀏覽器后退的時候重新計算
          			clearTimeout(tid);
          			tid = setTimeout(refreshRem, 300);
          		}
          	}, false);
          
          	if (doc.readyState === "complete") {
          		doc.body.style.fontSize = "16px";
          	} else {
          		doc.addEventListener("DOMContentLoaded", function(e) {
          			doc.body.style.fontSize = "16px";
          		}, false);
          	}
          })(750, 750);

           2.使用方法

                  1)將上面的代碼引入到你的頁面<script>標簽里面;


                  2)根據設計稿調整后面的參數


                  3)使用1rem=100px轉換你的設計稿的像素,例如設計稿上某個塊是100px*300px,換算成rem則為1rem*3rem。


          黄网站免费 <