| ±³¾°
¿ª·¢Òƶ¯¶ËH5Ò³Ãæ
Ãæ¶Ô²»Í¬·Ö±æÂʵÄÊÖ»ú
Ãæ¶Ô²»Í¬ÆÁÄ»³ß´çµÄÊÖ»ú
ÊÓ¾õ¸å
ÔÚǰ¶Ë¿ª·¢Ö®Ç°£¬ÊÓ¾õMM»á¸øÎÒÃÇÒ»¸öpsdÎļþ£¬³ÆÖ®ÎªÊÓ¾õ¸å¡£
¶ÔÓÚÒÆ¶¯¶Ë¿ª·¢¶øÑÔ£¬ÎªÁË×öµ½Ò³Ãæ¸ßÇåµÄЧ¹û£¬ÊÓ¾õ¸åµÄ¹æ·¶ÍùÍù»á×ñÑÒÔÏÂÁ½µã£º
Ê×ÏÈ£¬Ñ¡È¡Ò»¿îÊÖ»úµÄÆÁÄ»¿í¸ß×÷Ϊ»ù×¼(ÒÔǰÊÇiphone4µÄ320¡Á480£¬ÏÖÔÚ¸ü¶àµÄÊÇiphone6µÄ375¡Á667)¡£
¶ÔÓÚretinaÆÁÄ»(Èç: dpr=2)£¬ÎªÁË´ïµ½¸ßÇåЧ¹û£¬ÊÓ¾õ¸åµÄ»²¼´óС»áÊÇ»ù×¼µÄ2±¶£¬Ò²¾ÍÊÇ˵ÏñËØµã¸öÊýÊÇÔÀ´µÄ4±¶£¨¶Ôiphone6¶øÑÔ£ºÔÏȵÄ375¡Á667£¬¾Í»á±ä³É750¡Á1334£©¡£
ÎÊÌ⣺
¶ÔÓÚdpr=2µÄÊÖ»ú£¬ÎªÊ²Ã´»²¼´óС¡Á2£¬¾Í¿ÉÒÔ½â¾ö¸ßÇåÎÊÌ⣿
¶ÔÓÚ2±¶´óСµÄÊÓ¾õ¸å£¬ÔÚ¾ßÌåµÄcss±àÂëÖÐÈçºÎ»¹Ôÿһ¸öÇø¿éµÄÕæÊµ¿í¸ß(Ò²¾ÍÊDz¼¾ÖÎÊÌâ)?
´ø×ÅÎÊÌ⣬ÍùÏ¿´¡
һЩ¸ÅÄî
ÔÚ½øÐоßÌåµÄ·ÖÎö֮ǰ£¬Ê×ÏȵÃÖªµÀÏÂÃæÕâЩ¹Ø¼üÐÔ»ù±¾¸ÅÄî(ÊõÓï)¡£
ÎïÀíÏñËØ(physical pixel)
Ò»¸öÎïÀíÏñËØÊÇÏÔʾÆ÷(ÊÖ»úÆÁÄ»)ÉÏ×îСµÄÎïÀíÏÔʾµ¥Ôª£¬ÔÚ²Ù×÷ϵͳµÄµ÷¶ÈÏ£¬Ã¿Ò»¸öÉ豸ÏñËØ¶¼ÓÐ×Ô¼ºµÄÑÕɫֵºÍÁÁ¶ÈÖµ¡£
É豸¶ÀÁ¢ÏñËØ(density-independent pixel)
É豸¶ÀÁ¢ÏñËØ(Ò²½ÐÃܶÈÎÞ¹ØÏñËØ)£¬¿ÉÒÔÈÏΪÊǼÆËã»ú×ø±êϵͳÖеÃÒ»¸öµã£¬Õâ¸öµã´ú±íÒ»¸ö¿ÉÒÔÓɳÌÐòʹÓõÄÐéÄâÏñËØ(±ÈÈç:
cssÏñËØ)£¬È»ºóÓÉÏà¹ØÏµÍ³×ª»»ÎªÎïÀíÏñËØ¡£
ËùÒÔ˵£¬ÎïÀíÏñËØºÍÉ豸¶ÀÁ¢ÏñËØÖ®¼ä´æÔÚ×ÅÒ»¶¨µÄ¶ÔÓ¦¹ØÏµ£¬Õâ¾ÍÊǽÓÏÂÀ´ÒªËµµÄÉ豸ÏñËØ±È¡£
É豸ÏñËØ±È(device pixel ratio )
É豸ÏñËØ±È(¼ò³Ædpr)¶¨ÒåÁËÎïÀíÏñËØºÍÉ豸¶ÀÁ¢ÏñËØµÄ¶ÔÓ¦¹ØÏµ£¬ËüµÄÖµ¿ÉÒÔ°´ÈçÏµĹ«Ê½µÄµÃµ½£º
É豸ÏñËØ±È = ÎïÀíÏñËØ / É豸¶ÀÁ¢ÏñËØ // ÔÚijһ·½ÏòÉÏ£¬x·½Ïò»òÕßy·½Ïò |
ÔÚjavascriptÖУ¬¿ÉÒÔͨ¹ýwindow.devicePixelRatio»ñÈ¡µ½µ±Ç°É豸µÄdpr¡£
ÔÚcssÖУ¬¿ÉÒÔͨ¹ý-webkit-device-pixel-ratio£¬-webkit-min-device-pixel-ratioºÍ
-webkit-max-device-pixel-ratio½øÐÐýÌå²éѯ£¬¶Ô²»Í¬dprµÄÉ豸£¬×öһЩÑùʽÊÊÅä(ÕâÀïÖ»Õë¶ÔwebkitÄں˵Ää¯ÀÀÆ÷ºÍwebview)¡£
×ÛºÏÉÏÃæ¼¸¸ö¸ÅÄһÆð¾ÙÀý˵Ã÷Ï£º
ÒÔiphone6ΪÀý£º
É豸¿í¸ßΪ375¡Á667£¬¿ÉÒÔÀí½âΪÉ豸¶ÀÁ¢ÏñËØ(»òcssÏñËØ)¡£
dprΪ2£¬¸ù¾ÝÉÏÃæµÄ¼ÆË㹫ʽ£¬ÆäÎïÀíÏñËØ¾ÍÓ¦¸Ã¡Á2£¬Îª750¡Á1334¡£
ÓÃÒ»ÕÅͼÀ´±íÏÖ£¬¾ÍÊÇÕâÑù(ÔÁÂÎҵĵÁͼ)£º

ÉÏͼÖпÉÒÔ¿´³ö£¬¶ÔÓÚÕâÑùµÄcssÑùʽ£º
ÔÚ²»Í¬µÄÆÁÄ»ÉÏ(ÆÕͨÆÁÄ» vs retinaÆÁÄ»)£¬cssÏñËØËù³ÊÏֵĴóС(ÎïÀí³ß´ç)ÊÇÒ»Öµģ¬²»Í¬µÄÊÇ1¸öcssÏñËØËù¶ÔÓ¦µÄÎïÀíÏñËØ¸öÊýÊDz»Ò»Öµġ£
ÔÚÆÕͨÆÁĻϣ¬1¸öcssÏñËØ ¶ÔÓ¦ 1¸öÎïÀíÏñËØ(1:1)¡£
ÔÚretina ÆÁĻϣ¬1¸öcssÏñËØ¶ÔÓ¦ 4¸öÎïÀíÏñËØ(1:4)¡£
λͼÏñËØ
Ò»¸öλͼÏñËØÊÇÕ¤¸ñͼÏñ(È磺png, jpg, gifµÈ)×îСµÄÊý¾Ýµ¥Ôª¡£Ã¿Ò»¸öλͼÏñËØ¶¼°üº¬×ÅһЩ×ÔÉíµÄÏÔʾÐÅÏ¢(È磺ÏÔʾλÖã¬ÑÕɫֵ£¬Í¸Ã÷¶ÈµÈ)¡£
̸µ½ÕâÀ¾ÍµÃ˵һÏ£¬retinaÏÂͼƬµÄչʾÇé¿ö£¿
ÀíÂÛÉÏ£¬1¸öλͼÏñËØ¶ÔÓ¦ÓÚ1¸öÎïÀíÏñËØ£¬Í¼Æ¬²ÅÄܵõ½ÍêÃÀÇåÎúµÄչʾ¡£
ÔÚÆÕͨÆÁÄ»ÏÂÊÇûÓÐÎÊÌâµÄ£¬µ«ÊÇÔÚretinaÆÁĻϾͻá³öÏÖλͼÏñËØµã²»¹»£¬´Ó¶øµ¼ÖÂͼƬģºýµÄÇé¿ö¡£
ÓÃÒ»ÕÅͼÀ´±íʾ£º

ÈçÉÏͼ£º¶ÔÓÚdpr=2µÄretinaÆÁÄ»¶øÑÔ£¬1¸öλͼÏñËØ¶ÔÓ¦ÓÚ4¸öÎïÀíÏñËØ£¬ÓÉÓÚµ¥¸öλͼÏñËØ²»¿ÉÒÔÔÙ½øÒ»²½·Ö¸î£¬ËùÒÔÖ»Äܾͽüȡɫ£¬´Ó¶øµ¼ÖÂͼƬģºý(×¢ÒâÉÏÊöµÄ¼¸¸öÑÕɫֵ)¡£
ËùÒÔ£¬¶ÔÓÚͼƬ¸ßÇåÎÊÌ⣬±È½ÏºÃµÄ·½°¸¾ÍÊÇÁ½±¶Í¼Æ¬(@2x)¡£
È磺200¡Á300(css pixel)img±êÇ©£¬¾ÍÐèÒªÌṩ400¡Á600µÄͼƬ¡£
Èç´ËÒ»À´£¬Î»Í¼ÏñËØµã¸öÊý¾ÍÊÇÔÀ´µÄ4±¶£¬ÔÚretinaÆÁĻϣ¬Î»Í¼ÏñËØµã¸öÊý¾Í¿ÉÒÔ¸úÎïÀíÏñËØµã¸öÊýÐγÉ
1 : 1µÄ±ÈÀý£¬Í¼Æ¬×ÔÈ»¾ÍÇåÎúÁË(ÕâÒ²½âÊÍÁË֮ǰÁôϵÄÒ»¸öÎÊÌ⣬ΪɶÊÓ¾õ¸åµÄ»²¼´óСҪ¡Á2£¿)¡£
ÕâÀï¾Í»¹ÓÐÁíÒ»¸öÎÊÌ⣬Èç¹ûÆÕͨÆÁĻϣ¬Ò²ÓÃÁËÁ½±¶Í¼Æ¬£¬»áÔõÑùÄØ£¿
ºÜÃ÷ÏÔ£¬ÔÚÆÕͨÆÁĻϣ¬200¡Á300(css pixel)img±êÇ©£¬Ëù¶ÔÓ¦µÄÎïÀíÏñËØ¸öÊý¾ÍÊÇ200¡Á300¸ö£¬¶øÁ½±¶Í¼Æ¬µÄλͼÏñËØ¸öÊýÔòÊÇ200¡Á300*4£¬ËùÒԾͳöÏÖÒ»¸öÎïÀíÏñËØµã¶ÔÓ¦4¸öλͼÏñËØµã£¬ËùÒÔËüµÄȡɫҲֻÄÜͨ¹ýÒ»¶¨µÄËã·¨(ÏÔʾ½á¹û¾ÍÊÇÒ»ÕÅÖ»ÓÐÔͼÏñËØ×ÜÊýËÄ·ÖÖ®Ò»£¬ÎÒÃdzÆÕâ¸ö¹ý³Ì½Ð×ödownsampling)£¬ÈâÑÛ¿´ÉÏÈ¥ËäȻͼƬ²»»áÄ£ºý£¬µ«ÊÇ»á¾õµÃͼƬȱÉÙһЩÈñÀû¶È£¬»òÕßÊÇÓеãÉ«²î(µ«»¹ÊÇ¿ÉÒÔ½ÓÊܵÄ)¡£
ÓÃÒ»ÕÅͼƬÀ´±íʾ£º

Õë¶ÔÉÏÃæµÄÁ½¸öÎÊÌ⣬ÎÒ×öÁËÒ»¸ödemo(ÄÚÍø·ÃÎÊ)¿ñ´ÁÕâÀï¡£

demoÖУ¬100¡Á100µÄͼƬ£¬·Ö±ð·ÅÔÚ100¡Á100£¬50¡Á50£¬25¡Á25µÄimgÈÝÆ÷ÖУ¬ÔÚretinaÆÁĻϵÄÏÔʾЧ¹û¡£
ÌõÐÎͼ£¬Í¨¹ý·Å´ó¾µÆäʵ¿ÉÒÔ¿´³ö±ß½çÏñËØµãȡֵµÄ²»Í¬£º
ͼ1£¬¾Í½üȡɫ£¬É«Öµ½éÓÚºì°×Ö®¼ä£¬Æ«µ£¬Í¼Æ¬¿´ÉÏÈ¥»áÄ£ºý(¿ÉÒÔÀí½âΪͼƬÀÉì)¡£
ͼ2£¬Ã»Óоͽüȡɫ£¬É«ÖµÒªÃ´ÊǺ죬ҪôÊǰף¬Í¼Æ¬¿´ÉÏÈ¥ºÜÇåÎú¡£
ͼ3£¬¾Í½üȡɫ£¬É«Öµ½éÓÚºì°×Ö®¼ä£¬Æ«ÖØ£¬Í¼Æ¬¿´ÉÏÈ¥ÓÐÉ«²î£¬È±ÉÙÈñÀû¶È(¿ÉÒÔÀí½âΪͼƬ¼·Ñ¹)¡£
°®×Öͼ£¬¿ÉÒÔͨ¹ý¿´ÎÄ×Ö¡±°®¡±À´Çø·ÖͼƬģºý»¹ÊÇÇåÎú¡£
¼¸¸öÎÊÌâ
ÕâÀï˵һÏ£¬Òƶ¯¶ËH5¿ª·¢£¬ÔÚ²»Í¬·Ö±æÂÊ£¬²»Í¬ÆÁÄ»ÊÖ»úÏ»áÓöµ½µÄ¼¸¸ö¾µäÎÊÌâ¡£
retinaÏ£¬Í¼Æ¬¸ßÇåÎÊÌâ
Õâ¸öÎÊÌâÉÏÃæÒѾ½éÉܹý½â¾ö·½°¸ÁË£ºÁ½±¶Í¼Æ¬(@2x)£¬È»ºóͼƬÈÝÆ÷ËõС50%¡£
È磺ͼƬ´óС£¬400¡Á600;
1.img±êÇ©
width: 200px; height: 300px; |
2.±³¾°Í¼Æ¬
width: 200px; height: 300px; background-image: url(image@2x.jpg); background-size: 200px 300px; // »òÕß: background-size: contain; |
ÕâÑùµÄȱµã£¬ºÜÃ÷ÏÔ£¬ÆÕͨÆÁĻϣº
ͬÑùÏÂÔØÁË@2xµÄͼƬ£¬Ôì³É×ÊÔ´ÀË·Ñ¡£
ͼƬÓÉÓÚdownsampling£¬»áʧȥÁËһЩÈñÀû¶È(»òÊÇÉ«²î)¡£
ËùÒÔ×îºÃµÄ½â¾ö°ì·¨ÊÇ£º²»Í¬µÄdprÏ£¬¼ÓÔØ²»Í¬µÄ³ß´çµÄͼƬ¡£
²»¹ÜÊÇͨ¹ýcssýÌå²éѯ£¬»¹ÊÇͨ¹ýjavascriptÌõ¼þÅж϶¼ÊÇ¿ÉÒԵġ£
ÄÇôÎÊÌâÀ´ÁË£¬ÕâÑùµÄ»°£¬²»¾ÍÊÇҪ׼±¸Á½Ì×ͼƬÁËÂ(@1x ºÍ@2x)
ÎÒÏ룬×öµÄºÃµÄ¹«Ë¾£¬¶¼»áÓÐÕâôһ¸öͼƬ·þÎñÆ÷£¬Í¨¹ýurl»ñÈ¡²ÎÊý£¬È»ºó¿ÉÒÔ¿ØÖÆÍ¼Æ¬ÖÊÁ¿£¬Ò²¿ÉÒÔ½«Í¼Æ¬²Ã¼ô³É²»Í¬µÄ³ß´ç¡£
ËùÒÔÎÒÃÇÖ»ÐèÉÏ´«´óͼ(@2x)£¬ÆäÓàСͼ¶¼½»¸øÍ¼Æ¬·þÎñÆ÷´¦Àí£¬ÎÒÃÇÖ»Òª¸ºÔðÆ´½Óurl¼´¿É¡£
È磬ÕâÑùÒ»ÕÅÔͼ£º
https://img.alicdn.com/tps/TB1AGMmIpXXXXafXpXXXXXXXXXX.jpg // Ôͼ |
¿ÉÒÔÀàËÆÕâÑù£¬½øÐÐͼƬ²Ã¼ô£º
// 200¡Á200 https://img.alicdn.com/tps/TB1AGMmIpXXXXafXpXXXXXXXXXX.jpg_200x200.jpg
// 100¡Á100
https://img.alicdn.com/tps/TB1AGMmIpXXXXafXpXXXXXXXXXX.jpg_100x100.jpg |
(ps: µ±È»²Ã¼ôÖ»ÊǶÔÔͼµÄµÈ±È²Ã¼ô£¬µÃ±£Ö¤Í¼Æ¬µÄÇåÎúÂï~)
retinaÏ£¬border: 1pxÎÊÌâ
Õâ´ó¸ÅÊÇÉè¼ÆÊ¦×îÃô¸Ð£¬×î¹ØÐĵÄÎÊÌâÁË¡£
Ê×ÏȵÃ˵һÏ£¬ÎªÊ²Ã´´æÔÚretinaÏ£¬border: 1pxÕâһ˵£¿
ÎÒÃÇÕý³£µÄдcss£¬ÏñÕâÑùborder: 1px;£¬ÔÚretinaÆÁĻϣ¬»áÓÐʲôÎÊÌâÂð£¿
ÏÈÀ´£¬À´¿´¿´ÏÂÃæµÄͼ£º

ÉÏÃæÁ½ÕÅͼ·Ö±ðÊÇÔÚiphone3gs(dpr=1)ºÍiphone5(dpr=2)ÏÂÃæµÄ²âÊÔЧ¹û£¬¶Ô±ÈÀ´¿´£¬¶ÔÓÚ1pxµÄborderµÄչʾ£¬ËüÃÇÊÇÒ»Öµģ¬²¢ÎÞÇø±ð¡£
ÄÇôretinaÏÔʾÆÁµÄÓÅÊÆÔÚÄÄÀÉè¼ÆÊ¦ÎªºÎ¾õµÃ¸ßÇåÆÁÏÂ(ÓÒͼ)Õâ¸öÏßÌõ´ÖÄØ£¿Ã÷Ã÷ºÍ×óÓÒÒ»ÑùµÄ~
»¹ÊÇͨ¹ýÒ»ÕÅͼÀ´½âÊÍ(ÔÁÂÎÒÔٴεÁͼ)£º

ÉÏͼÖУ¬¶ÔÓÚÒ»Ìõ1px¿íµÄÖ±Ïߣ¬ËüÃÇÔÚÆÁÄ»ÉϵÄÎïÀí³ß´ç(»ÒÉ«ÇøÓò)µÄÈ·ÊÇÏàͬµÄ£¬²»Í¬µÄÆäʵÊÇÆÁÄ»ÉÏ×îСµÄÎïÀíÏÔʾµ¥Ôª£¬¼´ÎïÀíÏñËØ£¬ËùÒÔ¶ÔÓÚÒ»ÌõÖ±Ïߣ¬iphone5ËüÄÜÏÔʾµÄ×îС¿í¶ÈÆäʵÊÇͼÖеĺìÏßȦ³öÀ´µÄ»ÒÉ«ÇøÓò£¬ÓÃcssÀ´±íʾ£¬ÀíÂÛÉÏ˵ÊÇ0.5px¡£
ËùÒÔ£¬Éè¼ÆÊ¦ÏëÒªµÄretinaÏÂborder: 1px;£¬Æäʵ¾ÍÊÇ1ÎïÀíÏñËØ¿í£¬¶ÔÓÚcss¶øÑÔ£¬¿ÉÒÔÈÏΪÊÇborder:
0.5px;£¬ÕâÊÇretinaÏÂ(dpr=2)ÏÂÄÜÏÔʾµÄ×îСµ¥Î»¡£
È»¶ø£¬ÎÞÄβ¢²»ÊÇËùÓÐÊÖ»úä¯ÀÀÆ÷¶¼ÄÜʶ±ðborder: 0.5px;£¬ios7ÒÔÏ£¬androidµÈÆäËûϵͳÀ0.5px»á±»µ±³ÉΪ0px´¦Àí£¬ÄÇôÈçºÎʵÏÖÕâ0.5pxÄØ£¿
×î¼òµ¥µÄÒ»¸ö×ö·¨¾ÍÊÇÕâÑù(ÔªËØscale)£º
.scale{ position: relative; } .scale:after{ content:""; position: absolute; bottom:0px; left:0px; right:0px; border-bottom:1px solid #ddd; -webkit-transform:scaleY(.5); -webkit-transform-origin:0 0; } |
ÎÒÃÇÕÕ³£Ð´border-bottom: 1px solid #ddd;£¬È»ºóͨ¹ýtransform:
scaleY(.5)ËõС0.5±¶À´´ïµ½0.5pxµÄЧ¹û£¬µ«ÊÇÕâÑùhackʵÔÚÊDz»¹»Í¨ÓÃ(È磺Բ½ÇµÈ)£¬Ð´ÆðÀ´Ò²Âé·³¡£
µ±È»»¹ÓÐÆäËûºÃ¶àhack·½·¨£¬ÍøÉ϶¼¿ÉÒÔËÑË÷µ½£¬µ«ÊǸ÷ÓÐÀû±×£¬ÕâÀï±È½ÏÍÆ¼öµÄ»¹ÊÇÒ³ÃæscaleµÄ·½°¸£¬ÊDZȽÏͨÓõ쬼¸ºõÂú×ãËùÓг¡¾°¡£
¶ÔÓÚiphone5(dpr=2)£¬Ìí¼ÓÈçϵÄmeta±êÇ©£¬ÉèÖÃviewport(scale
0.5)£º
<meta name="viewport" content="width=640,initial-scale=0.5,maximum-scale=0.5, minimum-scale=0.5,user-scalable=no"> |
ÕâÑù£¬Ò³ÃæÖеÄËùÓеÄborder: 1px¶¼½«ËõС0.5£¬´Ó¶ø´ïµ½border: 0.5px;µÄЧ¹û¡£
ÓÐÈ˵£ÐÄÒ³Ãæscaleºó»áÓ°ÏìÐÔÄÜ£¬@Ãͬѧ×ö¹ýÐÔÄܲâÊÔ£¬¼ûÕâÀï(ÄÚÍøµØÖ·)¡£
¿´Ò»ÏÂʵÏÖºóµÄЧ¹ûͼ¶Ô±È(ÓÒͼΪÓÅ»¯¹ýµÄ)£º

È»¶ø£¬Ò³Ãæscale£¬±ØÈ»»á´øÀ´Ò»Ð©ÎÊÌ⣺
×ÖÌå´óС»á±»Ëõ·Å
Ò³Ãæ²¼¾Ö»á±»Ëõ·Å(Èç: divµÄ¿í¸ßµÈ)
ÕâÁ½¸öÎÊÌâºóÃæ½²µ½¡
¶àÆÁÊÊÅä²¼¾ÖÎÊÌâ
ÒÆ¶¯¶Ë²¼¾Ö£¬ÎªÁËÊÊÅä¸÷ÖÖ´óÆÁÊÖ»ú£¬Ä¿Ç°×îºÃÓõķ½°¸Äª¹ýÓÚʹÓÃÏà¶Ôµ¥Î»rem¡£
»ùÓÚremµÄÔÀí£¬ÎÒÃÇÒª×öµÄ¾ÍÊÇ: Õë¶Ô²»Í¬ÊÖ»úÆÁÄ»³ß´çºÍdpr¶¯Ì¬µÄ¸Ä±ä¸ù½ÚµãhtmlµÄfont-size´óС(»ù×¼Öµ)¡£
ÕâÀïÎÒÃÇÌáÈ¡ÁËÒ»¸ö¹«Ê½(rem±íʾ»ù×¼Öµ)
rem = document.documentElement.clientWidth * dpr / 10 |
˵Ã÷£º
³ËÒÔdpr£¬ÊÇÒòÎªÒ³ÃæÓпÉÄÜΪÁËʵÏÖ1px borderÒ³Ãæ»áËõ·Å(scale) 1/dpr ±¶(Èç¹ûûÓУ¬dpr=1),¡£
³ýÒÔ10£¬ÊÇΪÁËÈ¡Õû£¬·½±ã¼ÆËã(ÀíÂÛÉÏ¿ÉÒÔÊÇÈκÎÖµ)
ËùÒÔ¾ÍÏñÏÂÃæÕâÑù£¬htmlµÄfont-size¿ÉÄܻ᣺
iphone3gs: 320px / 10 = 32px
iphone4/5: 320px * 2 / 10 = 64px
iphone6: 375px * 2 / 10 = 75px
¶ÔÓÚ¶¯Ì¬¸Ä±ä¸ù½ÚµãhtmlµÄfont-size£¬ÎÒÃÇ¿ÉÒÔͨ¹ýcss×ö£¬Ò²¿ÉÒÔͨ¹ýjavascript×ö¡£
css·½Ê½£¬¿ÉÒÔͨ¹ýÉ豸¿í¶ÈÀ´Ã½Ìå²éѯÀ´¸Ä±ähtmlµÄfont-size£º
html{font-size: 32px;} //iphone 6 @media (min-device-width : 375px) { html{font-size: 64px;} } // iphone6 plus @media (min-device-width : 414px) { html{font-size: 75px;} } */ |
ȱµã£ºÍ¨¹ýÉ豸¿í¶È·¶Î§Çø¼äÕâÑùµÄýÌå²éѯÀ´¶¯Ì¬¸Ä±ärem»ù×¼Öµ£¬Æäʵ²»¹»¾«È·£¬±ÈÈ磺¿í¶ÈΪ360px
ºÍ ¿í¶ÈΪ320pxµÄÊÖ»ú£¬ÒòΪÆÁ¿íÔÚͬһ·¶Î§Çø¼äÄÚ(<375px)£¬ËùÒԻᱻͬµÈ¶Ô´ý(rem»ù×¼ÖµÏàͬ)£¬¶øÊÂʵÉÏËûÃÇµÄÆÁÄ»¿í¶È²¢²»ÏàµÈ£¬ËüÃǵIJ¼¾ÖÒ²Ó¦¸ÃÓÐËù²»Í¬¡£×îÖÕ£¬½áÂÛ¾ÍÊÇ£ºÕâÑùµÄ×ö·¨£¬Ã»ÓÐ×öµ½×ã¹»µÄ¾«È·£¬µ«Êǹ»Óá£
javascript·½Ê½£¬Í¨¹ýÉÏÃæµÄ¹«Ê½£¬¼ÆËã³ö»ù×¼Öµrem£¬È»ºóдÈëÑùʽ£¬´ó¸ÅÈçÏÂ(´úÂë²Î¿¼×ÔkimiµÄm-baseÄ£¿é)
var dpr, rem, scale; var docEl = document.documentElement; var fontEl = document.createElement('style'); var metaEl = document.querySelector('meta[name="viewport"]');
dpr = window.devicePixelRatio || 1;
rem = docEl.clientWidth * dpr / 10;
scale = 1 / dpr;
// ÉèÖÃviewport£¬½øÐÐËõ·Å£¬´ïµ½¸ßÇåЧ¹û
metaEl.setAttribute('content', 'width=' + dpr
* docEl.clientWidth + ',initial-scale=' + scale
+ ',maximum-scale=' + scale + ', minimum-scale='
+ scale + ',user-scalable=no');
// ÉèÖÃdata-dprÊôÐÔ£¬Áô×÷µÄcss hackÖ®ÓÃ
docEl.setAttribute('data-dpr', dpr);
// ¶¯Ì¬Ð´ÈëÑùʽ
docEl.firstElementChild.appendChild(fontEl);
fontEl.innerHTML = 'html{font-size:' + rem + 'px!important;}';
// ¸øjsµ÷Óõģ¬Ä³Ò»dprÏÂremºÍpxÖ®¼äµÄת»»º¯Êý
window.rem2px = function(v) {
v = parseFloat(v);
return v * rem;
};
window.px2rem = function(v) {
v = parseFloat(v);
return v / rem;
};
window.dpr = dpr;
window.rem = rem; |
ÕâÖÖ·½Ê½£¬¿ÉÒÔ¾«È·µØËã³ö²»Í¬ÆÁÄ»ËùÓ¦ÓеÄrem»ù×¼Öµ£¬È±µã¾ÍÊÇÒª¼ÓÔØÕâôһ¶Îjs´úÂ룬µ«¸öÈ˾õµÃÊÇÕâÊÇĿǰ×îºÃµÄ·½°¸ÁË¡£
ÒòΪÕâ¸ö·½°¸Í¬Ê±½â¾öÁËÈý¸öÎÊÌ⣺
border: 1pxÎÊÌâ
ͼƬ¸ßÇåÎÊÌâ
ÆÁÄ»ÊÊÅä²¼¾ÖÎÊÌâ
˵µ½²¼¾Ö£¬×ÔÈ»¾ÍµÃ»Ø´ðÒ»ÏÂ×î³õµÄÁôϵÄÄǸöÎÊÌ⣺ÈçºÎÔÚcss±àÂëÖл¹ÔÊÓ¾õ¸åµÄÕæÊµ¿í¸ß£¿
ǰÌáÌõ¼þ£º
Äõ½µÄÊÇÒ»¸öÕë¶Ôiphone6µÄ¸ßÇåÊÓ¾õ¸å 750¡Á1334
²ÉÓÃÉÏÊöµÄ¸ßÇå·½°¸(js´úÂë)¡£
Èç¹ûÓÐÒ»¸öÇø¿é£¬ÔÚpsdÎļþÖÐÁ¿³ö£º¿í¸ß750¡Á300pxµÄdiv£¬ÄÇôÈçºÎת»»³Éremµ¥Î»ÄØ£¿
¹«Ê½ÈçÏ£º
¶ÔÓÚÒ»¸öiphone6µÄÊÓ¾õ¸å£¬ËüµÄ»ù×¼Öµ¾ÍÊÇ75(֮ǰÓÐÌáµ½);
ËùÒÔ£¬ÔÚÈ·¶¨ÁËÊÓ¾õ¸å(¼´È·¶¨ÁË»ù×¼Öµ)ºó£¬Í¨³£ÎÒÃÇ»áÓÃlessдһ¸ömixin£¬ÏñÕâÑù£º
// ÀýÈç: .px2rem(height, 80); .px2rem(@name, @px){ @{name}: @px / 75 * 1rem; } |
ËùÒÔ£¬¶ÔÓÚ¿í¸ß750¡Á300pxµÄdiv£¬ÎÒÃÇÓÃless¾ÍÕâÑùд£º
.px2rem(width, 750); .px2rem(height, 300); |
ת»»³Éhtml£¬¾ÍÊÇÕâÑù£º
width: 10rem; // -> 750px height: 4rem; // -> 300px |
×îºóÒòΪdprΪ2£¬Ò³ÃæscaleÁË0.5£¬ËùÒÔÔÚÊÖ»úÆÁÄ»ÉÏÏÔʾµÄÕæÊµ¿í¸ßÓ¦¸ÃÊÇ375¡Á150px£¬¾Í¸Õ¸ÕºÃ¡£
ÌÈÈôÒ³Ãæ²¢Ã»ÓÐscale 0.5£¬ÎÒÃǵĴúÂë¾ÍµÃÕâÑù£º
.px2rem(width, 375); .px2rem(height, 150); |
ÕâÑùµÄ¿í¸ß£¬ÎÒÃÇÍùÍùÊÇÕâÑùµÃÀ´µÄ£º
½«750¡Á1334µÄÊÓ¾õ¸åת³É375¡Á667µÄ´óСºó£¬ÔÙÈ¥Á¿Õâ¸öÇø¿éµÄ´óС(¸Ð¾õºÃɵ)¡£
ÔÚ750¡Á1334Á¿µÃÇø¿é¿í¸ßÊÇ750¡Á300pxºó£¬ÔÙ¿ÚËã³ýÒÔ2(¸Ð¾õºÃÂé·³)¡£
×îºó¸ø³öÒ»ÕÅûÓв¼¾ÖÊÊÅä(ÉÏͼ)ºÍÓÃrem²¼¾ÖÊÊÅä(ÏÂͼ)µÄ¶Ô±Èͼ£º

enter image description here
(ÉÏÃæµÄÊÖ»ú·Ö±ðÊÇ£ºiphone3gs, iphone5, iphone6)
ºÜÃ÷ÏÔ¿ÉÒÔ¿´³ö£¬remÊÊÅäµÄ¸÷¸öÇø¿éµÄ¿í¸ß¶¼»áËæ×ÅÊÖ»úÆÁ¿í¶ø¸Ä±ä£¬×î×îÃ÷ÏԵĿÉÒÔ¿´Ò»ÏÂͼƬÁбíÄDz¿·Ö£¬×îºóÒ»ÕÅͼÊÓ¾õ¸åÒªÇóÖ»³öÏÖÒ»µãµã£¬rem²¼¾ÖÔÚÈÎºÎÆÁĻ϶¼ÏÔʾµÄºÜºÃ¡£
×ÖÌå´óСÎÊÌâ
¼ÈÈ»ÉÏÃæµÄ·½°¸»áʹµÃÒ³ÃæËõ·Å(scale)£¬¶ÔÓÚÒ³ÃæÇø¿éµÄ¿í¸ß£¬ÎÒÃÇ¿ÉÒÔÒÀÀµ¸ßÇåÊÓ¾õ¸å£¬ÒòΪÊÓ¾õ¸å±¾À´¾Í¡Á2ÁË£¬ÎÒÃÇÖ±½ÓÁ¿¾Í¿ÉÒÔÁË£¬ÄÇô¶ÔÓÚ×ÖÌå¸ÃÈçºÎ´¦ÀíÄØ£¿
¶ÔÓÚ×ÖÌåËõ·ÅÎÊÌ⣬Éè¼ÆÊ¦Ô±¾µÄÒªÇóÊÇÕâÑùµÄ£ºÈκÎÊÖ»úÆÁÄ»ÉÏ×ÖÌå´óС¶¼ÒªÍ³Ò»£¬ËùÒÔÎÒÃÇÕë¶Ô²»Í¬µÄ·Ö±æÂÊ(dpr²»Í¬)£¬»á×öÈçÏ´¦Àí£º
font-size: 16px; [data-dpr="2"] input { font-size: 32px; } |
(×¢Ò⣬×ÖÌå²»¿ÉÒÔÓÃrem£¬Îó²îÌ«´óÁË£¬ÇÒ²»ÄÜÂú×ãÈÎºÎÆÁÄ»ÏÂ×ÖÌå´óСÏàͬ)
ΪÁË·½±ã£¬ÎÒÃÇÒ²»áÓÃlessдһ¸ömixin£º
.px2px(@name, @px){ @{name}: round(@px / 2) * 1px; [data-dpr="2"] & { @{name}: @px * 1px; } // for mx3 [data-dpr="2.5"] & { @{name}: round(@px * 2.5 / 2) * 1px; } // for СÃ×note [data-dpr="2.75"] & { @{name}: round(@px * 2.75 / 2) * 1px; } [data-dpr="3"] & { @{name}: round(@px / 2 * 3) * 1px } // for ÈýÐÇnote4 [data-dpr="4"] & { @{name}: @px * 2px; } } |
(×¢Ò⣺htmlµÄdata-dprÊôÐÔ¾ÍÊÇ֮ǰjs·½°¸ÀïÃæÓÐÌáµ½µÄ£¬ÕâÀï¾ÍÓÐÓô¦ÁË)
¸ù¾Ý¾ÑéºÍ²âÊÔ£¬»¹ÊÇ»á³öÏÖÕâÐ©ÆæÆæÝâÝâµÄdpr£¬ÕâÀï×öÁËͳһ¼æÈÝ~
ÓõÄʱºò£¬¾ÍÏñÕâÑù£º
µ±È»¶ÔÓÚÆäËûcssÊôÐÔ£¬Èç¹ûÒ²ÒªÇó²»Í¬dpr϶¼±£³ÖÒ»ÖµĻ°£¬Ò²¿ÉÒÔÕâÑù²Ù×÷£¬È磺
.px2px(padding, 20); .px2px(right, 8); |
|