ios如何播放html5(Html5移动端适配IphoneX等机型的方法)
ios如何播放html5
Html5移动端适配IphoneX等机型的方法先来看下iPhone X机型的样子
上图中,Iphonex机型在头部和底部新增了这两个区域,所以我们需要针对这类机型做些适配,方便我们的webapp的展示
h5做成的移动端页面,常见布局为头部+躯干+底部三栏模式,头部和顶部都是固定定位,躯干可里的内容可以滚动,暂定的布局如下:
<li class="page"> <header></header> <main></main> <footer></footer> </li>
但如果没采用IphoneX机型的新的css属性,而直接采用position: fixed;top:0等常规写法,就会出现头部的导航栏被手机自带的状态栏(显示电量信号等等)遮挡的情况,底部的导航栏被IphoneX自带的呼吸灯(图中手机底部的白条)遮挡的情况,给用户的操作和体验带来困扰,目前针对这类问题,根据自己做过的项目,整理了一下几种解决方案
我使用的是vue框架,在index.html页面,我们需要添加
<meta name="viewport" content="width=device-width,viewport-fit=cover">
然后,在公共的app.vue页面,我们每个组件的展示,都是在这里被router-view替换,所以可以在这里处理一下公共的头部顶栏,具体的布局如下:
<template> <li id="app"> <li class="placeholder_top" :style="{position:fixpositiona?'absolute':'fixed'}"></li> <router-view class="routerview"></router-view> </li> </template>
上面的布局中,我们给class为placeholder_top的li写下如下:
.placeholder_top { position: fixed; top: 0; left: 0; width: 10rem; background-color: #303030; height: constant(safe-area-inset-top); height: env(safe-area-inset-top); z-index: 999; }
这样的话,我们后续,单独的组件,就不用再处理这个顶部栏的问题,那下面,我们就可以处理下前面提到的头部问题,一般头部,我们大多都会封装成公共组件,所以在这里,因为受到我们在app.vue页面插入的那个元素的影响,我们的头部的css写法,也需要略微改动下,头部组件页面布局如下:
<template> <header> <li class="title" :style="{position:fixposition?'absolute':'fixed'}"> 导航内容 </li> <li class="placeholder"></li> </header> </template>
页面的css为:
header{ background-color: #303030; .title{ position: fixed; top:0; top: constant(safe-area-inset-top); top: env(safe-area-inset-top); left: 0; height:88px; z-index: 999; } .placeholder{ height: 88px; width: 10rem; } }
这样写,这个头部导航栏就会位居于手机状态栏之下了,不会影响到视窗,并且能兼容安卓和ios机型(这类兼容问题,还涉及到ios的系统问题,不过本文暂未涉及)
下面再来看下main区域的处理,因为上面header组件已经处理好了,所以main直接如下布局:
main { padding-top: constant(safe-area-inset-top); padding-top: env(safe-area-inset-top); padding-bottom: calc(88px + constant(safe-area-inset-bottom)); padding-bottom: calc(88px + env(safe-area-inset-bottom));
ps:这里说明一下,下面的两行,是用在当前页面没有底部导航栏的情况
padding-bottom: constant(safe-area-inset-bottom); padding-bottom: env(safe-area-inset-bottom); },
main里面布局好了,直接写内容就可以了,
然后在看下底部的footer布局
<template> <footer> <li class="foot" :style="{position:fixposition?'absolute':'fixed'}"> 底部内容 </li> </footer> </template>
底部内容的css如下:
footer{ position: fixed; bottom: 0; left: 0; width: 10rem; height: calc(88px + constant(safe-area-inset-bottom)); height: calc(88px + env(safe-area-inset-bottom)); background-color: #303030; .foot{ position: absolute; top:0; left: 0; width: 10rem; height: 88px; } }
这样写,底部导航foot里的内容,就不会被手机自带的呼吸灯所遮挡
所以可以总结一下,我们在这种webapp适配中,可能需要采用的css写法如下:
position: fixed; top: constant(safe-area-inset-top); top: env(safe-area-inset-top); bottom: constant(safe-area-inset-bottom); bottom: env(safe-area-inset-bottom); top: calc(1rem + constant(safe-area-inset-top)); top: calc(1rem + env(safe-area-inset-top)); bottom: calc(1rem + constant(safe-area-inset-bottom)); bottom: calc(1rem + env(safe-area-inset-bottom));
ps:在上面的写法中,有写到:style="{position:fixposition?'absolute':'fixed'}",这个是为了解决用户点击输入框,弹出软键盘时,这类固定元素的定位不准的问题,感兴趣的可以研究下,本文暂不讨论
这里可以根据实际需求来采用不同的写法,大体布局逻辑建议不要偏差太大,这样写是为了统一处理,方便维护,另外如果有真机测试,发现布局兼容导致的样式问题,可以采用真机调试方法,用pc端浏览器调试webapp,审查元素,那样基本能解决大部分样式问题,关于真机调试,下回写
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持开心学习网。
- HTML5 播放 RTSP 视频的实例代码(HTML5 播放 RTSP 视频的实例代码)
- html5视频播放代码详解(HTML5基于flash实现播放RTMP协议视频的示例代码)
- html5+css3动画效果图(纯DOM+CSS3实现简单的小风车动画)
- html5开发的app(浅谈Html5页面打开app的一些思考)
- html5怎么设置红色(详解HTML5如何使用可选样式表为网站或应用添加黑暗模式)
- html5app开发用什么平台(Html5与App的通讯方式详解)
- h5抽奖的弹框制作(html5实现九宫格抽奖可固定抽中某项奖品)
- html5的语法变化(详解HTML5.2版本带来的修改)
- html5 data属性
- html5可以做语音聊天吗(基于Html5实现的语音搜索功能)
- html元素和属性的区别(HTML5 HTMLCollection和NodeList的区别详解)
- html5播放代码(html5 video全屏播放/自动播放的实现示例)
- html5的新特性
- html5表格设计(Html5饼图绘制实现统计图的方法)
- html5video怎么优化(HTML5 video循环播放多个视频的方法步骤)
- html5定位地理位置(html5 制作地图当前定位箭头的方法示例)
- 寒假余额不满24小时,不如来一场说走就走的亲子阅读之旅(寒假余额不满24小时)
- 省委书记出席的交流会,十位县委书记同场发言,代表公文材料的高水平(省委书记出席的交流会)
- 《刘老根3》热播,去世15年的她却再次被 伤害(去世15年的她却再次被)
- 十二星座爱情支配欲指数(十二星座爱情支配欲指数)
- 虐待儿童是发泄支配欲的愚蠢行为(虐待儿童是发泄支配欲的愚蠢行为)
- 你或许不知道你隐藏的支配欲望(你或许不知道你隐藏的支配欲望)
热门推荐
- ExecuteNonQuery()返回值
- dede调用tag标签(dedecms tag标签实现随机颜色和字体大小)
- dedecms频道封面不能修改内容(dedecms按栏目名首字母/数字排序输出的实现方法)
- mysql存储过程声明(MySQL存储过程的深入讲解in、out、inout)
- docker的postgres镜像包(Docker中运行PostgreSQL并推荐几款连接工具)
- laravel命令控制器怎么设置(Laravel获取当前请求的控制器和方法以及中间件的例子)
- mysql怎么创建联合索引(mysql的联合索引复合索引的实现)
- 什么是mime编码(Mime类型与文件后缀对照表)
- 火狐和IE的window.event的区别
- 如何解决AJAX 的缓存
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9