H5常用代码:适配方案1
在工作中接到H5项目,第一件想到的事就应该是屏幕适配问题,解决了屏幕适配,接下来的事才能真正开始。从此篇博客开始会连续记录下我经常用到的一些适配方案。
对于传统的PC项目,直接在移动端打开也都是会以视口980来自动缩放以显示主内容在屏幕内,既然有这么个特性,那自然适配也就可以通过通过控制视口来达到适配的目地。
以下是我工作中经常用到的第一种移动端适配方案:
<!DOCTYPE html>
<html>
<head>
<title>适配方案1</title>
<meta charset="utf-8">
<meta content="width=640,user-scalable=no,target-densitydpi=device-dpi" name="viewport">
<meta content="yes" name="apple-mobile-web-app-capable">
<meta content="black" name="apple-mobile-web-app-status-bar-style">
<meta content="telephone=no" name="format-detection">
<meta content="email=no" name="format-detection">
<style>
body{
margin:0;
}
.wrap{
width:640px;
overflow:hidden;
line-height:36px;
font-size:24px;
}
.aside_left,.aside_right{
width:320px;
height:160px;
float:left;
color:white;
line-height:160px;
font-size:30px;
text-align:center;
}
.aside_con{
width:640px;
height:160px;
background:blue;
color:white;
line-height:160px;
font-size:30px;
text-align:center;
}
.aside_left{
background:red;
}
.aside_right{
background:green;
} </style>
</head>
<body>
<div id="wrap" class="wrap"> <!--示范结构 S-->
<div class="aside_con">
<div class="aside_left">示范块内容0</div>
<div class="aside_right">示范块内容1</div>
</div>
<div class="aside_con">整条示范内容2</div>
<!--示范结构 E--> </div>
</body>
</html>
适配说明:
1:它使用了viewport视口的特性,手机会保证内容在一个视口内显示,把视口设计成你设计稿的宽度,如当你设计稿是640的时候你就按640PX宽来布局,如果是750的你就按750PX来布局,里面全用像素单位,回归到了PC的像素单位时代
2:主要的适合用在一些移动端的活动宣传页,要求上线快,下的也快的那些页面,即保证了速度也保证了开发成本,用来做功能页也是问题不大的
3:有一定的兼容风险,如果只是在微信里用的,这种适配方式就是你的菜,如果要兼容安卓低版本的一些手机原生浏览器,那这种适配方式不太适合。
我有遇到的一个场景是:公司的宣传页不但要放在微信里宣传,而且还要内嵌放到安卓APP里宣传,而安卓APP是调用手机的默认浏览器的,
虽然target-densitydpi=device-dpi是来解决安卓低版本兼容的,但是还是会有一些小差距,并不能保证内容在一屏宽度内,而且浏览器还能手动缩放,
当时不得已修改方案,考虑到修改的大小,后面使用适配方案2来解决的
以上代码归属于我的github常用H5代码整理项目(详见其中adaptationMode/mode1/index.html):https://github.com/xw5/mobile-code/
如果要做整屏切换效果,需要做一些CSS配合
代码如下:
<!DOCTYPE html>
<html>
<head>
<title>适配方案1全屏</title>
<meta charset="utf-8">
<meta content="width=640,user-scalable=no,target-densitydpi=device-dpi" name="viewport">
<meta content="yes" name="apple-mobile-web-app-capable">
<meta content="black" name="apple-mobile-web-app-status-bar-style">
<meta content="telephone=no" name="format-detection">
<meta content="email=no" name="format-detection">
<style>
/* 整屏适配必须需要的样式 S*/
html,body{
width:100%;
height:100%;
overflow:hidden;
}
.wrap{
width:640px;
height:100%;
overflow:hidden;
background:url(bg.jpg) no-repeat center 0;
-webkit-background-size:cover;
background-size:cover;
}
/*整屏适配必须需要的样式 E*/
*{
margin:0;
padding:0;
}
.wrap{
line-height:36px;
font-size:24px;
color:#fff;
}
.aside_left,.aside_right{
width:320px;
height:160px;
float:left;
color:white;
line-height:160px;
font-size:30px;
text-align:center;
}
.aside_con{
width:640px;
height:160px;
background:blue;
color:white;
line-height:160px;
font-size:30px;
text-align:center;
}
.aside_left{
background:red;
}
.aside_right{
background:green;
}
</style>
</head>
<body>
<div id="wrap" class="wrap"> <!--示范结构 S-->
<div class="aside_con">
<div class="aside_left">示范块内容0</div>
<div class="aside_right">示范块内容1</div>
</div>
<!--示范结构 E--> </div>
</body>
</html>
整屏适配说明:
此处是常用的专题页整屏适配,整屏的话需要设置html,body{width:100%;height:100%;oveflow:hidden;}去掉X&Y方向滚动条,同时通过把背景大小设置为background-size:cover;来保证背景占满整屏,同时使用background-position:center 0;来保证背景居中,左右裁剪,背景本身是装饰裁剪也无大碍的,此适配的需要把主内容尽可能的居中,以避免被裁剪掉
以上代码归属于我的github常用H5代码整理项目(详见其中adaptationMode/mode1/fullscreen.html):https://github.com/xw5/mobile-code/
欢迎clone,欢迎star,一起学习,一起进步!
H5常用代码:适配方案1的更多相关文章
- 手淘H5移动端适配方案flexible源码分析
移动端适配一直是一个值得探讨的问题,在业余时间我找了一些页面,查看了一些厂商对于移动端H5页面的适配方案,看到了几个典型的例子,今天就来记录一下我看到的第一个典型的例子,也是我们公司目前普通H5项目正 ...
- H5 端 rem 适配方案与 viewport 适配
H5 端 rem 适配方案与 viewport 适配 rem rem 是 CSS3 新增的一个相对单位(root em,根 em) 只根据当前页面 HTML 页面的 font-size 设置,如果根目 ...
- H5常用代码:适配方案5
此方案跟方案4是同一原理,也是通过REM实现的,能单独归类出一个方案,是因为它有一定的实用价值,当你遇到追求完美,追求到一像素的UI或者产品时,那此方案将解决你的困境. 方案5主要是用来解决一像素边框 ...
- H5常用代码:适配方案4
前面有分享了4种适配方案,但始终是通过手动缩放或者视口缩放来实现,用来做一些专题页,或者功能相对简单的项目来说也是完全能应付的,但整体来说感觉还是一种缩放,说不上是真正的适配,言外之意就是即将分享真正 ...
- H5常用代码:适配方案3
在H5项目中有一种常见的宣传页,就是那种整屏整屏的,带着炫丽进场动画的移动宣传页,不仅是一种欣赏也起到了很大宣传作用. 对于这种整屏的适配,前面通过视口的兼容处理也是可以做到的,但是在窄屏下会在上下有 ...
- H5常用代码:适配方案2
前面的通过视口做适配的方案由于安卓低版本原生浏览器的存在,在许多场合不尽如人意,会在低版本安卓上出现,不缩放,手动缩放未禁止的问题. 于是出现了第二种适配方案,既然通过视口缩放可以兼容,那为什么不直接 ...
- 最佳移动端h5自适应rem适配方案
一.利用lib-flexible.postcss-plugin-px2rem插件 进行移动端rem适配. 1.第一 引入lib-flexible . 安装lib-flexible: npm i lib ...
- h5 移动端适配方案思考
基础概念 CSS像素(CSS pixels) 这个是浏览器使用的抽象单位,用来精确度量网页上的内容.平时经常写的width:100px;height:100px;都是与设备无关的. 设备独立像素(de ...
- H5常用代码:页面框架
万变不离其宗,道法自然! 虽然H5的小项目一波又一波,但有一个东东基本没什么变化,那就是整个页面的框架结构. 我所常用的H5常用页面框架如下: <!DOCTYPE html> <ht ...
随机推荐
- Android支付之支付宝封装类
今天介绍下在android中如何集成支付宝支付到自己的APP中去.让APP能够拥有方便,快捷的支付功能. 我们在做Android支付的时候肯定会用到支付宝支付,根据官方给出的demo做起来非常费劲,所 ...
- python第十二天-----RabbitMQ
有一位小伙伴说让我去A站写博客可能会有很多人喜欢,真是搞不懂,北方哪里有卖萌?北方默认状态就是这么萌的!再者说了,这明明就是很专注于技术的博客嘛,能不能严肃点!知不知道什么叫帧? 学习到了数据库的相关 ...
- model is null
在action实现页面跳转过程中,可以实现页面的跳转,但页面无内容,无渲染,在控制台输出视图名,会报出url路径+"model is null" 这是在导包的错,正确的为: imp ...
- Selenium2+python自动化26-js处理内嵌div滚动条
前言 前面有篇专门用js解决了浏览器滚动条的问题,生活总是多姿多彩,有的滚动条就在页面上,这时候又得仰仗js大哥来解决啦. 一.内嵌滚动条 1.下面这张图就是内嵌div带有滚动条的样子,记住它的长相.
- CSS从大图片上截取小图标的操作以及三角形的画法
#name{ background:url(images/name.png) no-repeat 2px 2px; background-position: -2px -70px;//其中这个是定位图 ...
- Oracle 10g -- 修改DB的编码
修改DB的原因是:因为我的DB不支持中文,所以每当我向数据库表中插入一条数据的时候,中文就都变了类似于“?(是反问号)”的乱码,为了能顺利插入成功,故做了此次修改; 系统:windows XP 英文版 ...
- [刘阳Java]_Java技术有哪些学习重点_第1讲
纵观网上有很多非常好的对Java技术的总结,这里我个人谈谈对Java技术学习有哪些重点内容[浮浅之见] Java环境搭建 Java基础语法 Java面向对象编程 Java异常 Java IO流 Jav ...
- JVM调优-Java垃圾回收之分代回收
为什么要进行分代回收? JVM使用分代回收测试,是因为:不同的对象,生命周期是不一样的.因此不同生命周期的对象采用不同的收集方式. 可以提高垃圾回收的效率. Java程序运行过程中,会产生大量的对象, ...
- 【随笔】ARP和RARP
ARP协议是什么? ARP协议是"Address Resolution Protocol"(地址解析协议)的缩写.在局域网中,网络中实际传输的是"帧",帧里面是 ...
- TableView刷新指定的cell 或section
//一个section刷新 NSIndexSet *indexSet=[[NSIndexSet alloc]initWithIndex:]; [tableview reloadSections:ind ...