css3 - css將div定位到圖片上的固定位置
問(wèn)題描述
如圖我有個(gè)總的大p,寬度和高度都是不定的,里面的手機(jī)線框是背景圖,用的
background-size:contain
定位的,黑框是我想要操作的p,想讓他能覆蓋手機(jī)模型的屏幕,而且放大縮小都會(huì)剛好限制在手機(jī)屏幕內(nèi),該怎么定位呢,能不能實(shí)現(xiàn)?
問(wèn)題解答
回答1:謝邀,這種東西根本不需要啥背景圖。
寫(xiě)了個(gè)demo,點(diǎn)開(kāi)看css代碼和直接預(yù)覽效果。https://jsfiddle.net/vpgL5535/
回答2:我理解的話(huà),“放大縮小都會(huì)剛好限制在手機(jī)屏幕內(nèi)”指的是寬度適應(yīng),如果是要用圖片背景的話(huà),可以考慮用百分比布局。 參考代碼如下(略去不重要的部分):
<p class='frame-container'> <p class='screen-container'> <!-- content here --> </p></p>
.frame-container{ max-width: 559px; min-height: 753px; padding: 13.77% 14.13% 0; background: url(frame.jpg) no-repeat; background-size: 100% auto; box-sizing: border-box;}.screen-container{ padding: 10px; /* 可選,在屏幕范圍內(nèi)仍然增加一點(diǎn)間距比較美觀 */}
對(duì)應(yīng)的結(jié)果是:

其中的要點(diǎn)是:
background-size: 100% auto;來(lái)使背景圖始終縮放至寬度和外層p一致,并保持寬高比。
padding: 13.77% 14.13% 0;取的分別是手機(jī)模型屏幕區(qū)域到背景圖邊緣的距離,從px值轉(zhuǎn)換為百分比值(比例通過(guò)像素值除以圖片像素寬度得到)
(可選)max-width: 559px;使外層p不至于超出背景圖大小(背景圖尺寸為753 x 559),min-height使內(nèi)容較少的時(shí)候也能看到整個(gè)手機(jī)模型。
回答3:配色挺漂亮,嚯嚯嚯。
這個(gè)黑色線框可以直接寫(xiě)成“手機(jī)的”子元素。放在內(nèi)部用百分比的寬高來(lái)控制一下大小,就能自適應(yīng)了。如:
.phone p { width: 80%; height: 80%; margin: 0 auto; margin-top: 10%;}
相關(guān)文章:
1. 網(wǎng)頁(yè)爬蟲(chóng) - 如何使用使用java抓取信息并制作一個(gè)排名系統(tǒng)?2. php對(duì)mysql提取數(shù)據(jù)那種速度更快3. javascript - immutable配合react提升性能?4. javascript - 在vue項(xiàng)目中遇到的問(wèn)題:DOMException5. 如何設(shè)置一個(gè)無(wú)限循環(huán)并打破它。(Java線程)6. javascript - vue中使用prop傳遞數(shù)據(jù)問(wèn)題7. python小白 自學(xué)看書(shū)遇到看不懂的地方8. shell - mysql更新錯(cuò)誤9. ubuntu如何啟動(dòng)sublime10. mysql - 在log日志中已知用戶(hù)的某一步操作,如何獲取其上一步操作?

網(wǎng)公網(wǎng)安備