iphone劉海屏頁(yè)面適配方法
1. 下面是實(shí)現(xiàn)iphonex 劉海屏前端頁(yè)面適配的一個(gè)插值算法小案例
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> <style> body, ul { margin: 0; } ul { padding-left: 10px; } li { list-style: none; } .phone { position: relative; width: 600px; height: 300px; border: 10px solid #000; border-radius: 30px; margin: 100px auto 0; } .content, .content ul { width: 100%; height: 100%; } .content { overflow-x: hidden; overflow-y: scroll; } .camera { position: absolute; top: 60px; left: 0; width: 26px; height: 180px; background-color: black; border-radius: 0 30px 30px 0; } li + li { border-top: 1px solid #ccc; } li { font-size: 16px; padding: 5px; } *::-webkit-scrollbar { padding-left: 100px; } </style> </head> <body> <div class="phone"> <div class="content"> <ul> <li>SweeTango</li> <li>Pacific Rose</li> <li>SnapDragon</li> <li>Envy</li> <li>Koru (Plumac)</li> <li>Pink Lady (Cripps Pink)</li> <li>HoneYcrisp</li> <li>Hoyal Gala</li> <li>Macoun</li> <li>SweeTango</li> <li>Pacific Rose</li> <li>SnapDragon</li> <li>Envy</li> <li>Koru (Plumac)</li> <li>Pink Lady (Cripps Pink)</li> <li>HoneYcrisp</li> <li>Hoyal Gala</li> <li>Macoun</li> <li>Macoun</li> <li>SweeTango</li> <li>Pacific Rose</li> <li>SnapDragon</li> <li>Envy</li> <li>Koru (Plumac)</li> <li>Pink Lady (Cripps Pink)</li> <li>HoneYcrisp</li> <li>Hoyal Gala</li> <li>Macoun</li> <div class="camera"></div> </ul> </div> </div> <script> ~~function () { var thresh = 20; var maxoffset = 50; var aLi = document.querySelectorAll('li'); var oCamera = document.querySelector('.camera'); var oContent = document.querySelector('.content') var camPs = oCamera.getBoundingClientRect(); ~~function () { oContent.onscroll = arguments.callee; for (var item of aLi) { var itemRect = item.getBoundingClientRect(); var dtf = itemRect.bottom - camPs.top var dtb = itemRect.bottom - camPs.bottom if (Math.abs(dtf) < 20) { item.style.transform = 'translateX(' + lerp(0, 30, cal(dtf, 20)) + "px)"; } else if (dtf > 20 && dtb < -20) { item.style.transform = 'translateX(' + 30 + "px)"; } else if (Math.abs(dtb) <20) { item.style.transform = 'translateX(' + lerp(30, 0, cal(dtb, 20)) + "px)"; } else { //全部移除攝像頭區(qū)域 item.style.transform = 'translateX(' + 0 + "px)"; } } }() }() /** * @param 插值算法 * @param p1 初始化狀態(tài) * @param p2 結(jié)束狀態(tài) * @param t 時(shí)間函數(shù) (0-100%) * * 返回p1 到 p2 之間的值 */ function lerp(p1, p2, t) { return (p2 - p1) * t + p1 } function cal(dis, thr) { return (dis + thr) / (thr * 2) } </script> </body> </html>
以上所述是小編給大家介紹的iphone劉海屏頁(yè)面適配方法詳解整合,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 解決vue移動(dòng)端適配問題
- vue 移動(dòng)端適配方案詳解
- vue移動(dòng)端html5頁(yè)面根據(jù)屏幕適配的四種解決方法
- vue使用rem實(shí)現(xiàn) 移動(dòng)端屏幕適配
- vue做移動(dòng)端適配最佳解決方案(親測(cè)有效)
- vue項(xiàng)目中使用lib-flexible解決移動(dòng)端適配的問題解決
- 詳解vue移動(dòng)端項(xiàng)目的適配(以mint-ui為例)
- vue項(xiàng)目中公用footer組件底部位置的適配問題
- 詳解基于mpvue的小程序markdown適配解決方案
- 詳解vue2.0 不同屏幕適配及px與rem轉(zhuǎn)換問題
相關(guān)文章
vscode中eslint配置保存自動(dòng)修復(fù)代碼示例詳解
vscode根據(jù)eslint保存?動(dòng)修復(fù)配置,下面這篇文章主要給大家介紹了關(guān)于vscode中eslint配置保存自動(dòng)修復(fù)代碼的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-12-12Vue3?封裝?Element?Plus?Menu?無限級(jí)菜單組件功能的詳細(xì)代碼
本文分別使用?SFC(模板方式)和?tsx?方式對(duì)?Element?Plus?*el-menu*?組件進(jìn)行二次封裝,實(shí)現(xiàn)配置化的菜單,有了配置化的菜單,后續(xù)便可以根據(jù)路由動(dòng)態(tài)渲染菜單,對(duì)Vue3?無限級(jí)菜單組件相關(guān)知識(shí)感興趣的朋友一起看看吧2022-09-09vue elementUI table表格數(shù)據(jù) 滾動(dòng)懶加載的實(shí)現(xiàn)方法
這篇文章主要介紹了vue elementUI table表格數(shù)據(jù)滾動(dòng)懶加載的實(shí)現(xiàn)方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-04-04vue項(xiàng)目關(guān)閉eslint校驗(yàn)
eslint是一個(gè)JavaScript的校驗(yàn)插件,通常用來校驗(yàn)語法或代碼的書寫風(fēng)格。這篇文章主要介紹了vue項(xiàng)目關(guān)閉eslint校驗(yàn),需要的朋友可以參考下2018-03-03vue中使用loadsh的debounce防抖函數(shù)問題
這篇文章主要介紹了vue中使用loadsh的debounce防抖函數(shù)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-11-11