viewport meta æ è®°
æ¬æä»ç»å¦ä½ä½¿ç¨ "viewport" <meta> æ è®°æ¥æ§å¶è§å£ç大å°åå½¢ç¶ã
èæ¯
æµè§å¨çè§å£æ¯ä¸ä¸ªå¨å ¶ä¸æ¥ç Web å 容ççªå£åºåãè¿é叏䏿¸²æç页é¢å¤§å°ä¸åï¼å¨è¿ç§æ åµä¸ï¼æµè§å¨ä¸ºç¨æ·æä¾æ»å¨æ¡ä»¥æ»å¨åè®¿é®ææå 容ã
å¨ç§»å¨è®¾å¤åå ¶ä»çªå±è®¾å¤ä¸ï¼æäºå 容卿¯æ®éå±å¹æ´å®½çèæçªå£æè§å£ä¸æ¸²æé¡µé¢ï¼ç¶åç¼©å°æ¸²æçç»æï¼ä»¥ä¾¿å¯ä»¥ä¸æ¬¡çå°ææå 容ãç¶åï¼ç¨æ·å¯ä»¥éè¿å¹³ç§»å缩æ¾ä»¥æ¥ç页é¢çä¸ååºåãä¾å¦ï¼å¦æç§»å¨å±å¹ç宽度为 640pxï¼å页é¢å¯è½ä¼ä½¿ç¨ 980px çèæè§å£æ¸²æï¼ç¶å页é¢å°ç¼©å°ä»¥éåº 640px ç空é´ã
è¿æ¯å ä¸ºå¹¶éææé¡µé¢é½é对移å¨è®¾å¤è¿è¡äºä¼åï¼å¹¶ä¸å¨ä»¥è¾å°çè§å£å®½åº¦æ¸²ææ¶ä¼è¢«æªæï¼æè³å°çèµ·æ¥å¾ç³ç³ï¼ãèæè§å£åæ¯ä¸ç§ä½¿éç§»å¨è®¾å¤ä¼å页é¢å¨çªå±è®¾å¤ä¸çèµ·æ¥æ´å¥½çä¸ä¸ªæ¹æ³ã
使¯ï¼æ¤æºå¶ä¸å¤ªéç¨äºä½¿ç¨åªä½æ¥è¯¢é对çªå±å¹è¿è¡ä¼åç页é¢ãä¾å¦ï¼å¦æèæè§å£ä¸º 980pxï¼é£ä¹å¨ 640px æ 480px ææ´ä½æ¶å¯å¨çåªä½æ¥è¯¢å°ä¸ä¼è¢«ä½¿ç¨ï¼ä»èéå¶äºè¿äºååºå¼è®¾è®¡æ¹æ³çæææ§ãviewport meta æ ç¾å¯ç¼è§£æ¤ç±»å±å¹å é¨è¾çªçç»ç«¯ä¸çèæè§å£é®é¢ã
è§å£åºç¡ç¥è¯
å ¸åçé对移å¨é¡µé¢ä¼åä¸è¬å¦ä¸æç¤ºï¼
<meta name="viewport" content="width=device-width, initial-scale=1" />
å¹¶éææç设å¤é½æçç¸åç宽度ï¼ä½ åºè¯¥ç¡®ä¿å³ä½¿å±å¹å¤§å°ææ¹åæå¾å¤§å·®å¼ï¼é¡µé¢ä¹è½å¤æ£å¸¸å·¥ä½ã
"viewport" <meta> æ ç¾çåºæ¬å±æ§å¦ä¸æç¤ºï¼
width-
æ§å¶è§å£çï¼æå°ï¼åç´ å®½åº¦ï¼åè§è§å£å®½åº¦åå±å¹å®½åº¦ï¼ãè¿å¯ä»¥è®¾ç½®ä¸º 1 å° 10000 ä¹é´çæ£æ´æ°åç´ å¼ï¼å¦
width=600ï¼ï¼ä¹å¯ä»¥è®¾ç½®ä¸ºç¹æ®å¼device-widthï¼è¡¨ç¤ºè®¾å¤å±å¹çç©ç尺寸ï¼ä»¥ CSS åç´ ä¸ºåä½ï¼ãæ¤å¼å³å®äºvwåä½çå¼ã height-
æ§å¶è§å£çï¼æå°ï¼åç´ é«åº¦ï¼åè§è§å£å®½åº¦åå±å¹å®½åº¦ï¼ãè¿å¯ä»¥è®¾ç½®ä¸º 1 å° 10000 ä¹é´çæ£æ´æ°åç´ å¼ï¼å¦
height=400ï¼ï¼ä¹å¯ä»¥è®¾ç½®ä¸ºç¹æ®å¼device-heightï¼è¡¨ç¤ºè®¾å¤å±å¹çç©ç尺寸ï¼ä»¥ CSS åç´ ä¸ºåä½ï¼ãæ¤å¼å³å®äºvhåä½çå¼ã initial-scale-
æ§å¶é¡µé¢é¦æ¬¡å è½½æ¶æ¾ç¤ºç缩æ¾åæ°ãæå°å¼æ¯
0.1ãæå¤§å¼æ¯10ãé»è®¤å¼ä¸º1ãè´å¼ä¼è¢«å¿½ç¥ã minimum-scale-
æ§å¶é¡µé¢å 许缩å°çåæ°ãæå°å¼æ¯
0.1ãæå¤§å¼æ¯10ãé»è®¤å¼ä¸º1ãè´å¼ä¼è¢«å¿½ç¥ã maximum-scale-
æ§å¶é¡µé¢å 许æ¾å¤§çåæ°ã设置ä¸ä¸ªä½äº
3çå¼å°ä¸å ·å¤æ éç¢è®¿é®æ§ãæå°å¼æ¯0.1ãæå¤§å¼æ¯10ãé»è®¤å¼ä¸º1ãè´å¼ä¼è¢«å¿½ç¥ã user-scalable-
æ§å¶æ¯å¦å 许页é¢ä¸çæ¾å¤§åç¼©å°æä½ãææå¼ä¸º
0ã1ãyesænoãé»è®¤å¼ä¸º1ï¼ä¸yesç¸åãå°å¼è®¾ç½®ä¸º0ï¼å³ä¸noç¸åï¼å°è¿å Web å 容æ éç¢æåï¼WCAGï¼ã interactive-widget-
æå®äº¤äºå¼ UI ç»ä»¶ï¼å¦èæé®çï¼å¯¹é¡µé¢è§å£çå½±åãææå¼ï¼
resizes-visualãresizes-contentæoverlays-contentãé»è®¤å¼ï¼resizes-visualã viewport-fit-
å®ä¹ç½é¡µçå¯è§åºåãå®å¯ä»¥æ¯ä»¥ä¸å ³é®åä¹ä¸ï¼
autoãcontainæcoverãautoï¼ä¸å½±ååå§å¸å±è§å£ï¼æ´ä¸ªç½é¡µé½æ¯å¯è§çãcontainï¼è§å£è¢«ç¼©æ¾ï¼ä»¥éé æ¾ç¤ºåºåå å¯å æ¥çæå¤§ç©å½¢ãcoverï¼è§å£è¢«ç¼©æ¾ä»¥å¡«å è®¾å¤æ¾ç¤ºåºåã强ç建议使ç¨å®å ¨åºåå åç§»åéï¼ä»¥ç¡®ä¿éè¦å 容ä¸ä¼è¶ åºæ¾ç¤ºåºåã
è¦åï¼ä½¿ç¨ user-scalable=no ä¼ç»æè§è§éç¢çç¨æ·é ææ éç¢é®é¢ï¼å¦å¼±è§åãWCAG è¦æ±è³å°æ 2 åç缩æ¾ï¼ç¶èï¼æä½³åæ³æ¯å¯ç¨ 5 åç缩æ¾ã
å±å¹å¯åº¦
å±å¹å辨çå·²ç»ä¸åå°äººç¼æ æ³è¾¨å«å个åç´ çç¨åº¦äºãä¾å¦ï¼æºè½ææºçå±å¹é常å¾å°ï¼ä½å辨çå´é«è¾¾ 1920-1080 åç´ ï¼â400dpiï¼ãæ£å ä¸ºå¦æ¤ï¼è®¸å¤æµè§å¨å¯ä»¥éè¿ä¸ºæ¯ä¸ª CSSâåç´ â转æ¢å¤ä¸ªç¡¬ä»¶åç´ ï¼ä»¥è¾å°çç©ç尺寸æ¾ç¤ºå ¶é¡µé¢ãæåï¼è¿å¨è®¸å¤è§¦æ¸ä¼åçç½ç«ä¸é æäºå¯ç¨æ§åå¯è¯»æ§é®é¢ã
å¨é« dpi å±å¹ä¸ï¼åå§æ
åµä¸º initial-scale=1 ç页é¢å°è¢«æµè§å¨æææ¾å¤§ãå®ä»¬çææ¬å°æ¯å¹³æ»åæ¸
æ°çï¼ä½å®ä»¬çä½å¾å¾åå¯è½æ æ³å©ç¨å
¨å±å¹å辨çã为äºå¨è¿äºå±å¹ä¸è·å¾æ´æ¸
æ°çå¾åï¼ç½ç«å¼å人åå¯è½å¸æä»¥é«äºå
¶æç»å°ºå¯¸çæ¯ä¾è®¾è®¡å¾åââææ´ä¸ªå¸å±ï¼ç¶åä½¿ç¨ CSS æè§å£å±æ§å°å
¶ç¼©å°ã
é»è®¤çåç´ æ¯åå³äºæ¾ç¤ºå¨çå¯åº¦ãå¨å¯åº¦å°äº 200dpi çæ¾ç¤ºå¨ä¸ï¼æ¯çæ¯ 1.0ãå¨å¯åº¦ä»äº 200 å 300dpi ä¹é´çæ¾ç¤ºå¨ä¸ï¼æ¯çæ¯ 1.5ã对äºå¯åº¦è¶ è¿ 300dpi çæ¾ç¤ºå¨ï¼æ¯çæ¯æ´æ°åºçº¿ï¼å±å¹å¯åº¦/150dpiï¼ã注æï¼åªæå½è§å£æ¯ä¾çäº 1 æ¶ï¼é»è®¤æ¯ä¾ææ¯ççãå¦åï¼CSS åç´ å设å¤åç´ ä¹é´çå ³ç³»åå³äºå½åç缩æ¾çº§å«ã
è§å£å®½åº¦åå±å¹å®½åº¦
页é¢å¯ä»¥å°å
¶è§å£è®¾ç½®ä¸ºç¹å®å°ºå¯¸ãä¾å¦ï¼"width=320, initial-scale=1" çå®ä¹å¯ä»¥ç¨æ¥ç²¾ç¡®å°éåºçºµå模å¼ä¸çå°åææºæ¾ç¤ºå±ã彿µè§å¨ä»¥è¾å¤§ç尺寸渲æé¡µé¢æ¶ï¼è¿å¯è½å¯¼è´é®é¢ã为äºè§£å³è¿ä¸ªé®é¢ï¼å¦ææå¿
è¦ï¼æµè§å¨ä¼æ©å¤§è§å£å®½åº¦ï¼ä»¥ä¾¿æè¦æ±çæ¯ä¾å¡«å
å±å¹ãè¿å¨å¤§å±å¹è®¾å¤ä¸ç¹å«æç¨ã
对äºè®¾ç½®äºåå§ææå¤§æ¯ä¾ç页é¢ï¼è¿æå³çå®½åº¦å±æ§å®é ä¸è½¬å为æå°è§å£å®½åº¦ãä¾å¦ï¼å¦æä½ çå¸å±éè¦è³å° 500 åç´ ç宽度ï¼é£ä¹ä½ å¯ä»¥ä½¿ç¨ä»¥ä¸æ è®°ãå½å±å¹çå®½åº¦è¶ è¿ 500 åç´ æ¶ï¼æµè§å¨å°æ©å¤§è§å£ï¼è䏿¯æ¾å¤§ï¼ä»¥éåºå±å¹ã
<meta name="viewport" content="width=500, initial-scale=1" />
å
¶ä»å¯ç¨ç屿§æ minimum-scaleãmaximum-scale å user-scalableãè¿äºå±æ§ä¼å½±ååå§æ¯ä¾å宽度ï¼ä»¥åéå¶ç¼©æ¾çº§å«çååã
交äºå¼ UI ç»ä»¶ææ
æµè§å¨ç交äºå¼ UI ç»ä»¶å¯ä»¥å½±å页é¢è§å£ç大å°ãæå¸¸è§çè¿ç§ UI ç»ä»¶æ¯èæé®çãè¦æ§å¶æµè§å¨åºè¯¥ä½¿ç¨åªç§è°æ´å¤§å°çè¡ä¸ºï¼å¯ä»¥è®¾ç½® interactive-widget 屿§ã
å 许çå¼ä¸ºï¼
resizes-visual-
å¯è§è§å£ä¼è¢«äº¤äºå¼ç»ä»¶è°æ´å¤§å°ã
resizes-content-
è§å£ä¼è¢«äº¤äºå¼ç»ä»¶è°æ´å¤§å°ã
overlays-content-
è§å£åå¯è§è§å£é½ä¸ä¼è¢«äº¤äºå¼ç»ä»¶è°æ´å¤§å°ã
å½è§å£ç大å°è¢«è°æ´æ¶ï¼åå§å¸å±åå å«åç大å°ä¹ä¼è¢«è°æ´ï¼ä»èå½±åè§å£åä½çè®¡ç®æå¾ç大å°ã
ç§»å¨åå¹³æ¿çµè设å¤ç常è§è§å£å¤§å°
å¦æä½ æ³ç¥éå类移å¨åå¹³æ¿è®¾å¤é½æåªäºè§å£å®½åº¦ï¼è¿éæä¸ä¸ªå ¨é¢çç§»å¨åå¹³æ¿è§å£å°ºå¯¸å表ã宿ä¾çä¿¡æ¯å æ¬çºµå忍ªåçè§å£å®½åº¦ï¼ä»¥åç©çå±å¹å°ºå¯¸ãæä½ç³»ç»å设å¤çåç´ å¯åº¦ã
è§è
| è§è |
|---|
| CSS Viewport Module Level 1> # viewport-meta> |