一、函数库 underscoreJS

_.template

<ol class="carousel-indicators">
<!--渲染的HTML字符串-->
</ol>
<div class="carousel-inner" role="listbox">
<!--渲染的HTML字符串-->
</div>
/*取到模版当中的字符串*/
var pointTemplateStr = $('#point_template').html();
var imageTemplateStr = $('#image_template').html();
/*转化成模版函数*/
var pointTemplate = _.template(pointTemplateStr);
var imageTemplate = _.template(imageTemplateStr);
/*传入数据 解析成 html 字符*/
var pointHtml = pointTemplate({model:data});
var imageHtml = imageTemplate({model:data,isMobile:isMobile});//我们只需要再加一个属性
/*把html字符串渲染在页面当中*/
$('.carousel-indicators').html(pointHtml);
$('.carousel-inner').html(imageHtml);
<!--点模版-->
<script type="text/template" id="point_template">
<%_.each(model,function(obj,i){%>
<li data-target="#carousel-example-generic" data-slide-to="<%=i%>" class="<%=(i==0?'active':'')%>"></li>
<%})%>
</script>
<!--图片模版-->
<script type="text/template" id="image_template">
<%_.each(model,function(obj,i){%>
<div class="item <%=(i==0?'active':'')%>">
<% if(isMobile){ %>
<a href="#" class="m_imgBox">
<img src="<%=obj.img%>" alt=""/>
</a>
<%} else {%>
<a href="#" class="pc_imgBox" style="background-image:url(<%=obj.bac%>)"></a>
<%}%>
</div>
<%})%>
</script>

二、rem布局

准备编辑这段时发现简书上已经有作者写了关于rem布局的介绍,并且他的设置比我所用的更加简洁,贴上地址供大家学习参考。
手机端页面自适应解决方案—rem布局进阶版(附源码示例)

三、移动web开发中的常见问题

1、移动端如何定义字体font-family?

三大手机系统的字体:

  • iOS 系统

    • 默认中文字体是Heiti SC
    • 默认英文字体是Helvetica
    • 默认数字字体是HelveticaNeue
    • 无微软雅黑字体
  • Android 系统
    • 默认中文字体是Droidsansfallback
    • 默认英文和数字字体是Droid Sans
    • 无微软雅黑字体
  • Winphone 系统
    • 默认中文字体是Dengxian(方正等线体)
    • 默认英文和数字字体是Segoeod
    • 无微软雅黑字体

各个手机系统有自己的默认字体,且都不支持微软雅黑,如无特殊需求,手机端无需定义中文字体,使用系统默认英文字体和数字字体可使用Helvetica,三种系统都支持。

/* 移动端定义字体的代码 */
body{
font-family:Helvetica;
}

2、移动端字体单位font-size选择px还是rem?

  • 对于只需要适配手机设备,使用px即可。

  • 对于需要适配各种移动设备,使用rem,例如只需要适配iPhoneiPad等分辨率差别比较挺大的设备。

  • rem配置参考:

html {font-size:10px}
@media screen and (min-width:480px) and (max-width:639px) {
html {
font-size: 15px
}
}
@media screen and (min-width:640px) and (max-width:719px) {
html {
font-size: 20px
}
}
@media screen and (min-width:720px) and (max-width:749px) {
html {
font-size: 22.5px
}
}
@media screen and (min-width:750px) and (max-width:799px) {
html {
font-size: 23.5px
}
}
@media screen and (min-width:800px) and (max-width:959px) {
html {
font-size: 25px
}
}
@media screen and (min-width:960px) and (max-width:1079px) {
html {
font-size: 30px
}
}
@media screen and (min-width:1080px) {
html {
font-size: 32px
}
}

4、移动端touch事件(区分webkit和winphone)有哪些?

当用户手指放在移动设备在屏幕上滑动会触发的touch事件:

  • 以下支持webkit

    • touchstart——当手指触碰屏幕时候发生。不管当前有多少只手指。
    • touchmove——当手指在屏幕上滑动时连续触发。通常我们再滑屏页面,会调用event``preventDefault()可以阻止默认情况的发生:阻止页面滚动。
    • touchend——当手指离开屏幕时触发。
    • touchcancel——系统停止跟踪触摸时候会触发。例如在触摸过程中突然页面alert()一个提示框,此时会触发该事件,这个事件比较少用。
  • 以下支持winphone 8
    • MSPointerDown——当手指触碰屏幕时候发生。不管当前有多少只手指。
    • MSPointerMove——当手指在屏幕上滑动时连续触发。通常我们再滑屏页面,会调用csshtml{-ms-touch-action:none;}可以阻止默认情况的发生:阻止页面滚动。
    • MSPointerUp——当手指离开屏幕时触发。

5、如何解决移动端click屏幕产生200-300ms的延迟响应问题?

移动设备上的web网页是有300ms延迟的,往往会造成按钮点击延迟甚至是点击失效。

解决方案

  • fastclick可以解决在手机上点击事件的300ms延迟。
  • zeptotouch模块,tap事件也是为了解决在click的延迟问题。

触摸事件的响应顺序

  1. ontouchstart
  2. ontouchmove
  3. ontouchend
  4. onclick

解决300ms延迟的问题,也可以通过绑定ontouchstart事件,加快对事件的响应。

6、 什么是Retina 显示屏,带来了什么问题?

retina:一种具备超高像素密度的液晶屏,同样大小的屏幕上显示的像素点由1个变为多个,如在同样带下的屏幕上,苹果设备的retina显示屏中,像素点1个变为4个。

在高清显示屏中的位图被放大,图片会变得模糊,因此移动端的视觉稿通常会设计为传统PC的2倍

那么,前端的应对方案是:

设计稿切出来的图片长宽保证为偶数,并使用backgroud-size把图片缩小为原来的1/2。

//例如图片宽高为:200px*200px,那么写法如下
.css{width:100px;height:100px;background-size:100px 100px;}

其它元素的取值为原来的1/2,例如视觉稿40px的字体,使用样式的写法为20px。

.css{font-size:20px}

7、移动端如何取消touch高亮效果?

在做移动端页面时,会发现所有a标签在触发点击时或者所有设置了伪类:active的元素,默认都会在激活状态时,显示高亮框,如果不想要这个高亮,那么你可以通过css以下方法来进行全局的禁止:

html {
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

ios用户点击一个链接,会出现一个半透明灰色遮罩, 如果想要禁用,可设置-webkit-tap-highlight-coloralpha值为0,也就是属性值的最后一位设置为0就可以去除半透明灰色遮罩。

a,button,input,textarea{-webkit-tap-highlight-color: rgba(0,0,0,0;)}

android用户点击一个链接,会出现一个边框或者半透明灰色遮罩, 不同生产商定义出来额效果不一样,可设置-webkit-tap-highlight-coloralpha值为0去除部分机器自带的效果。

a,button,input,textarea{
-webkit-tap-highlight-color: rgba(0,0,0,0);
-webkit-user-modify:read-write-plaintext-only;
}
  • -webkit-user-modify有个副作用,就是输入法不再能够输入多个字符。

    另外,有些机型去除不了,如小米2。对于此类问题还有个办法,不使用a或者input标签,直接用div标签。

  • winphone系统ainput标签被点击时产生的半透明灰色背景怎么去掉?

<meta name="msapplication-tap-highlight" content="no">

8、关于webkit表单的几个问题

  • webkit表单元素的默认外观怎么重置?

.css{-webkit-appearance:none;}

webkit表单输入框placeholder的颜色值能改变么?

input::-webkit-input-placeholder{color:#AAAAAA;}
input:focus::-webkit-input-placeholder{color:#EEE}

webkit表单输入框placeholder的文字能换行么?

iOS可以Android不行。

如何禁止文本缩放?

当移动设备横竖屏切换时,文本的大小会重新计算,进行相应的缩放,当我们不需要这种情况时,可以选择禁止:

html {
-webkit-text-size-adjust: 100%;
}
  • 需要注意的是,PC端的该属性已经被移除,该属性在移动端要生效,必须设置meta viewport

9、如何在移动端禁止用户选中内容?

如果你不想用户可以选中页面中的内容,那么你可以在css中禁掉:

.user-select-none {
-webkit-user-select: none; /* Chrome all / Safari all */
-moz-user-select: none; /* Firefox all (移动端不需要) */
-ms-user-select: none; /* IE 10+ */
}

10、如何模拟按钮的hover效果?

移动端触摸按钮的效果,可明示用户有些事情正要发生,是一个比较好体验,但是移动设备中并没有鼠标指针,使用csshover并不能满足我们的需求,还好国外有个激活cssactive效果,代码如下:

<html>
<head>
<meta charset="utf-8">
<meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" 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 type="text/css">
a{-webkit-tap-highlight-color: rgba(0,0,0,0);}
.btn-blue{display:block;height:42px;line-height:42px;text-align:center;border-radius:4px;font-size:18px;color:#FFFFFF;background-color: #4185F3;}
.btn-blue:active{background-color: #357AE8;}
</style>
</head>
<body> <div class="btn-blue">按钮</div> <script type="text/javascript">
document.addEventListener("touchstart", function(){}, true)
</script>
</body>
</html>
兼容性ios5+、部分android 4+、winphone 8

要做到全兼容的办法,可通过绑定ontouchstartontouchend来控制按钮的类名。

<html>
<head>
<meta charset="utf-8">
<meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" 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 type="text/css">
a{-webkit-tap-highlight-color: rgba(0,0,0,0);}
.btn-blue{display:block;height:42px;line-height:42px;text-align:center;border-radius:4px;font-size:18px;color:#FFFFFF;background-color: #4185F3;}
.btn-blue-on{background-color: #357AE8;}
</style>
</head>
<body> <div class="btn-blue">按钮</div> <script type="text/javascript">
var btnBlue = document.querySelector(".btn-blue");
btnBlue.ontouchstart = function(){
this.className = "btn-blue btn-blue-on"
}
btnBlue.ontouchend = function(){
this.className = "btn-blue"
}
</script>
</body>
</html>

11、屏幕旋转的事件和样式

  • 事件:window.orientation,取值:正负90表示横屏模式0和180表现为竖屏模式

window.onorientationchange = function(){
switch(window.orientation){
case -90:
case 90:
alert("横屏:" + window.orientation);
case 0:
case 180:
alert("竖屏:" + window.orientation);
break;
}
}

样式:

//竖屏时使用的样式
@media all and (orientation:portrait) {
.css{}
} //横屏时使用的样式
@media all and (orientation:landscape) {
.css{}
}

12、移动端常见的一些功能

  • 摇一摇功能:

    HTML5 deviceMotion:封装了运动传感器数据的事件,可以获取手机运动状态下的运动加速度等数据。

  • 手机拍照和上传图片:

<input type="file">的accept 属性
<!-- 选择照片 -->
<input type=file accept="image/*">
<!-- 选择视频 -->
<input type=file accept="video/*">
  • 使用总结:

    1. iOS有拍照、录像、选取本地图片功能。
    2. 部分android只有选取本地图片功能。
    3. winphone不支持。
    4. input控件默认外观丑陋。
  • 消除transition闪屏:

.css{
/*设置内嵌的元素在 3D 空间如何呈现:保留 3D*/
-webkit-transform-style: preserve-3d;
/*(设置进行转换的元素的背面在面对用户时是否可见:隐藏)*/
-webkit-backface-visibility: hidden;
}

开启硬件加速:

  1. 解决页面闪白。
  2. 保证动画流畅。
.css {
-webkit-transform: translate3d(0, 0, 0);
-moz-transform: translate3d(0, 0, 0);
-ms-transform: translate3d(0, 0, 0);
transform: translate3d(0, 0, 0);
}

android上去掉语音输入按钮:

input::-webkit-input-speech-button {display: none}

13、如何禁止百度转码?

<meta http-equiv="Cache-Control" content="no-siteapp" />

14、怎样默认优先使用最新版本IE和Chrome?

<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />

第123天:移动web开发中的常见问题的更多相关文章

  1. WEB开发中的字符集和编码

    html,body,div,span,applet,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,a,abbr,acronym,address,bi ...

  2. web开发中目录路径问题的解决

    web开发当中,目录路径的书写是再常用不过了,一般情况下不会出什么问题,但是有些时候出现了问题却一直感到奇怪,所以这里记录一下,彻底解决web开发中路径的问题,开发分为前端和服务端,那么就从这两个方面 ...

  3. 【初码干货】使用阿里云对Web开发中的资源文件进行CDN加速的深入研究和实践

    提示:阅读本文需提前了解的相关知识 1.阿里云(https://www.aliyun.com) 2.阿里云CDN(https://www.aliyun.com/product/cdn) 3.阿里云OS ...

  4. Web 开发中很实用的10个效果【附源码下载】

    在工作中,我们可能会用到各种交互效果.而这些效果在平常翻看文章的时候碰到很多,但是一时半会又想不起来在哪,所以养成知识整理的习惯是很有必要的.这篇文章给大家推荐10个在 Web 开发中很有用的效果,记 ...

  5. Web 开发中很实用的10个效果

    在工作中,我们可能会用到各种交互效果.而这些效果在平常翻看文章的时候碰到很多,但是一时半会又想不起来在哪,所以养成知识整理的习惯是很有必要的.这篇文章给大家推荐10个在 Web 开发中很有用的效果,记 ...

  6. Web开发中管理ipad屏幕的方向变化

    Web开发中,我们会遇到在手机垂直或水平视角时展示不同状态的情况.下面我来总结一下检测移动设备方向变化的一些方法. 1 使用javascript 直接看代码: <script type=&quo ...

  7. 今日推荐:10款在 Web 开发中很有用的占位图片服务

    设计网站时,将要使用的图像在一开始通常还不存在,这个时候布局是最重要的.然而,图像的尺寸通常是预先设置,实用一些占位图像可以帮助我们更好地预览和分析布局. 如今,有免费的占位图片自动生成工具可以使用, ...

  8. Web 开发中应用 HTML5 技术的10个实例教程

    HTML5 作为下一代网站开发技术,无论你是一个 Web 开发人员或者想探索新的平台的游戏开发者,都值得去研究.借助尖端功能,技术和 API,HTML5 允许你创建响应性.创新性.互动性以及令人惊叹的 ...

  9. Redis在WEB开发中的应用与实践

    Redis在WEB开发中的应用与实践 一.Redis概述: Redis是一个功能强大.性能高效的开源数据结构服务器,Redis最典型的应用是NoSQL.但事实上Redis除了作为NoSQL数据库使用之 ...

随机推荐

  1. 20145226夏艺华 《Java程序设计》第10周学习总结

    教材学习内容总结 学习目标 了解计算机网络基础 掌握Java Socket编程 网络编程 网络编程就是在两个或两个以上的设备(例如计算机)之间传输数据.程序员所作的事情就是把数据发送到指定的位置,或者 ...

  2. 20145226夏艺华 EXP5 MSF基础应用

    实践目标 · 掌握metasploit的基本应用方式. · 具体需要完成 (1)ms08_067; (2)ms11_050: (3)Adobe (4)成功应用任何一个辅助模块. 报告 本次实验一共用到 ...

  3. Mysql本地安装多实例后启动遇到的问题

    一.本文紧接上一篇[win10-MySql免安装版-安装/多实例] 在上一篇文章里,安装Mysql解压版后,复制多份到本地,实现了多实例的安装 在后续启动其它实例的时候会遇到一些问题,以下就是自己遇到 ...

  4. 【BZOJ4362】isn

    [BZOJ4362]isn 题面 bzoj 题解 设\(f[i][j]\)表示当前在\(i\),长度为\(j\)的最长不降子序列有多少个 这个可以用树状数组\(n^2logn\)求出 设\(g[i]\ ...

  5. idea热部署时 编写Controller会接收不到参数

    因为我是热部署启动服务器后才编写的request和getparameter 所以可能接收不到 重启一下服务器即可

  6. PL/SQL编辑数据"这些查询结果不可更新,请包括ROWID或使用SELECT...FOR UPDATE获得可更新结果"处理

    只要有人用了: select t.* from 表名  t where 字段=xxx  for update 而不是: select t.rowid,t.* from 表名  t where 字段=x ...

  7. 前端--初识jQuery

    jQuery 一.jQuery介绍 1.jQuery是一个轻量级.兼容多浏览器的js库. 2.jQuery使用户能够更方便地处理HTML Document,Events,实现动画效果,方便的进行Aja ...

  8. uvaoj 156Ananagrams(map和vector组合使用)

    https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...

  9. Appium+python HTML测试报告(2)——一份报告模板(转)

    (原文:https://www.cnblogs.com/fancy0158/p/10055003.html) 适用于python3: 下载地址: 英文:https://pan.baidu.com/s/ ...

  10. Unity利用Share SDK实现QQ、微信及微博第三方登录及定制内容分享(附代码)

    最近因为公司的项目需要添加一些实用性的功能,需要添加第三方登录及分享,采用的是Mob的SDK,可以先到其官网下载对应的SDK 点击这里,为了方便后期进行数据统计和分析,所以可以先添加一个应用,添加成功 ...