日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

移动端页面不需要在meta加_移动端适配viewport缩放方案

發(fā)布時(shí)間:2023/12/10 编程问答 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 移动端页面不需要在meta加_移动端适配viewport缩放方案 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

1. 前言

設(shè)計(jì)師交付給前端開(kāi)發(fā)一張寬度為750px的視覺(jué)稿,設(shè)計(jì)稿上元素的尺寸、顏色、位置等已做過(guò)標(biāo)注,要求工程師工在適配不同屏幕尺寸的設(shè)備時(shí)采用等比縮放的方案。

采用viewport縮放的方案能又快又好的實(shí)現(xiàn)需求。

2. 原理

在寫HTML、CSS對(duì)設(shè)計(jì)稿進(jìn)行還原時(shí)不關(guān)注屏幕尺寸的差異,而是直接按設(shè)計(jì)稿的標(biāo)注來(lái)開(kāi)發(fā)。比如設(shè)計(jì)稿里標(biāo)注的文字字號(hào)是30px,CSS里就設(shè)置文字字號(hào)30px。

頁(yè)面開(kāi)發(fā)好后,在HTML的head標(biāo)簽里加入 <meta name="viewport" content="width={設(shè)計(jì)稿寬度}, initial-scale={屏幕邏輯像素寬度/設(shè)計(jì)稿寬度}" > 。

舉個(gè)例子。假設(shè)設(shè)計(jì)師交付的設(shè)計(jì)稿寬度是750px,設(shè)計(jì)稿上一個(gè)標(biāo)題字號(hào)標(biāo)注的是32px 、margin是20px。我們以標(biāo)注的大小來(lái)寫CSS。之后需要通過(guò)JavaScript計(jì)算獲取屏幕的寬度(假設(shè)需要適配邏輯像素寬度是428px的屏幕),在HTML的head里添加 <meta name="viewport" content="width=750px, initial-scale=0.57" > 即可(428/759 = 0.57)。

這段代碼的意思是:設(shè)置布局視口(layout viewport)的寬度為750px(此時(shí)頁(yè)面一般會(huì)超出屏幕),再縮放頁(yè)面(initial-scale)使其恰好撐滿屏幕。

3. 適配代碼

<!DOCTYPE html> <html> <head><meta charset="utf-8"><script>const WIDTH = 750const mobileAdapter = () => {let scale = screen.width/WIDTHlet content = `width=${WIDTH}, initial-scale=${scale}, maximum-scale=${scale}, minimum-scale=${scale}`let meta = document.querySelector('meta[name=viewport]')if(!meta) {meta = document.createElement('meta')meta.setAttribute('name', 'viewport')document.head.appendChild(meta)} meta.setAttribute('content', content)}mobileAdapter()window.onorientationchange = mobileAdapter</script> </head> <body>... </body> </html>

優(yōu)點(diǎn)與缺點(diǎn)

  • 優(yōu)點(diǎn): 開(kāi)發(fā)流程很簡(jiǎn)單,工程師只需根據(jù)設(shè)計(jì)稿標(biāo)注還原頁(yè)面,不需要額外計(jì)算。適配范圍廣。
  • 缺點(diǎn): 頁(yè)面整體放大縮小,對(duì)于不想縮放的元素?zé)o法控制。比如邊框在大屏手機(jī)下顯得很粗,在小屏手機(jī)下顯得很細(xì)(下圖所示)。

我們更需要一種既能整體縮放,又能個(gè)性化控制某些元素不縮放的方案。見(jiàn)下篇文章:移動(dòng)端動(dòng)態(tài)REM方案。

下一篇:移動(dòng)端動(dòng)態(tài)REM適配方案?mp.weixin.qq.com

4. 最后

  • 如果本文對(duì)你有幫助,點(diǎn)個(gè)贊給作者一點(diǎn)小小的鼓勵(lì)讓我堅(jiān)持更新
  • 最近的文章為前端劍指offer系列,是面向大廠求職的文章合集,關(guān)注公眾號(hào)「 編程公子 」提前看到文章更新

總結(jié)

以上是生活随笔為你收集整理的移动端页面不需要在meta加_移动端适配viewport缩放方案的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。