一、函数库 underscoreJS

_.template

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

二、rem布局

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

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

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

三大手机系统的字体:

  • iOS 系统

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

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

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

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

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

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

  • rem配置参考:

  1. html {font-size:10px}
  2. @media screen and (min-width:480px) and (max-width:639px) {
  3. html {
  4. font-size: 15px
  5. }
  6. }
  7. @media screen and (min-width:640px) and (max-width:719px) {
  8. html {
  9. font-size: 20px
  10. }
  11. }
  12. @media screen and (min-width:720px) and (max-width:749px) {
  13. html {
  14. font-size: 22.5px
  15. }
  16. }
  17. @media screen and (min-width:750px) and (max-width:799px) {
  18. html {
  19. font-size: 23.5px
  20. }
  21. }
  22. @media screen and (min-width:800px) and (max-width:959px) {
  23. html {
  24. font-size: 25px
  25. }
  26. }
  27. @media screen and (min-width:960px) and (max-width:1079px) {
  28. html {
  29. font-size: 30px
  30. }
  31. }
  32. @media screen and (min-width:1080px) {
  33. html {
  34. font-size: 32px
  35. }
  36. }

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。

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

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

  1. .css{font-size:20px}

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

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

  1. html {
  2. -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  3. }

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

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

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

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

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

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

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

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

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

  1. .css{-webkit-appearance:none;}

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

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

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

  1. iOS可以Android不行。

如何禁止文本缩放?

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

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

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

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

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

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

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

  1. <html>
  2. <head>
  3. <meta charset="utf-8">
  4. <meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" name="viewport">
  5. <meta content="yes" name="apple-mobile-web-app-capable">
  6. <meta content="black" name="apple-mobile-web-app-status-bar-style">
  7. <meta content="telephone=no" name="format-detection">
  8. <meta content="email=no" name="format-detection">
  9. <style type="text/css">
  10. a{-webkit-tap-highlight-color: rgba(0,0,0,0);}
  11. .btn-blue{display:block;height:42px;line-height:42px;text-align:center;border-radius:4px;font-size:18px;color:#FFFFFF;background-color: #4185F3;}
  12. .btn-blue:active{background-color: #357AE8;}
  13. </style>
  14. </head>
  15. <body>
  16.  
  17. <div class="btn-blue">按钮</div>
  18.  
  19. <script type="text/javascript">
  20. document.addEventListener("touchstart", function(){}, true)
  21. </script>
  22. </body>
  23. </html>
  24. 兼容性ios5+、部分android 4+、winphone 8

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

  1. <html>
  2. <head>
  3. <meta charset="utf-8">
  4. <meta content="width=device-width,initial-scale=1.0,maximum-scale=1.0,user-scalable=no" name="viewport">
  5. <meta content="yes" name="apple-mobile-web-app-capable">
  6. <meta content="black" name="apple-mobile-web-app-status-bar-style">
  7. <meta content="telephone=no" name="format-detection">
  8. <meta content="email=no" name="format-detection">
  9. <style type="text/css">
  10. a{-webkit-tap-highlight-color: rgba(0,0,0,0);}
  11. .btn-blue{display:block;height:42px;line-height:42px;text-align:center;border-radius:4px;font-size:18px;color:#FFFFFF;background-color: #4185F3;}
  12. .btn-blue-on{background-color: #357AE8;}
  13. </style>
  14. </head>
  15. <body>
  16.  
  17. <div class="btn-blue">按钮</div>
  18.  
  19. <script type="text/javascript">
  20. var btnBlue = document.querySelector(".btn-blue");
  21. btnBlue.ontouchstart = function(){
  22. this.className = "btn-blue btn-blue-on"
  23. }
  24. btnBlue.ontouchend = function(){
  25. this.className = "btn-blue"
  26. }
  27. </script>
  28. </body>
  29. </html>

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

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

  1. window.onorientationchange = function(){
  2. switch(window.orientation){
  3. case -90:
  4. case 90:
  5. alert("横屏:" + window.orientation);
  6. case 0:
  7. case 180:
  8. alert("竖屏:" + window.orientation);
  9. break;
  10. }
  11. }

样式:

  1. //竖屏时使用的样式
  2. @media all and (orientation:portrait) {
  3. .css{}
  4. }
  5.  
  6. //横屏时使用的样式
  7. @media all and (orientation:landscape) {
  8. .css{}
  9. }

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

  • 摇一摇功能:

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

  • 手机拍照和上传图片:

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

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

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

开启硬件加速:

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

android上去掉语音输入按钮:

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

13、如何禁止百度转码?

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

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

  1. <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. 20155233 2016-2017-2 《Java程序设计》第10周学习总结

    20155233 2016-2017-2 <Java程序设计>第10周学习总结 学习目标 了解计算机网络基础 掌握Java Socket编程 理解混合密码系统 掌握Java 密码技术相关A ...

  2. 在windows上搭建redis集群(redis-cluster)(转载)

    一 所需软件:Redis.Ruby语言运行环境.Redis的Ruby驱动redis-xxxx.gem.创建Redis集群的工具redis-trib.rb 二 安装配置redis  redis下载地址 ...

  3. Python:静态方法、类方法、实例方法

    1. 静态方法@staticmethod (1)无需自身对象的self参数和自身类的cls参数,可直接通过 类名.方法名 进行调用 (2)Python中并不是真正意义上的静态方法,因为类定义本身就是个 ...

  4. spring源码-aop源码-5.1

    一.aop的源码部分还是有点复杂的,但是为了更好的理解,我这里会省去很多不必要的逻辑实现过程.主要方向还是更好的理解整体代码的实现过程. 二.说明重点:aop的过程主要过程有两点:第一点,发现正确和适 ...

  5. Python运维三十六式:用Python写一个简单的监控系统

    市面上有很多开源的监控系统:Cacti.Nagios.Zabbix.感觉都不符合我的需求,为什么不自己做一个呢? 用Python两个小时徒手撸了一个简易的监控系统,给大家分享一下,希望能对大家有所启发 ...

  6. Maven学习(十二)-----Maven POM

    Maven POM POM代表项目对象模型.它是 Maven 中工作的基本单位,这是一个 XML 文件.它始终保存在该项目基本目录中的 pom.xml 文件.POM 包含的项目是使用 Maven 来构 ...

  7. Python中的装饰器的使用及固定模式

    装饰器的使用: 在不想修改函数的调用方式,但是想给函数添加内容的功能的时候使用     为什么使用装饰器: 软件实体应该是可扩展,而不可修改的.也就是说,对扩展是开放的,而对修改是封闭的. 因此,引出 ...

  8. 视觉SLAM中的深度估计问题

    一.研究背景 视觉SLAM需要获取世界坐标系中点的深度. 世界坐标系到像素坐标系的转换为(深度即Z): 深度的获取一共分两种方式: a)主动式 RGB-D相机按照原理又分为结构光测距.ToF相机 To ...

  9. pytest使用笔记(三)——pytest+allure+jenkins配置使用

    按照pytest使用笔记(二)把pytest+allure配置好后,现在在jenkins配置好,先实现手动构建(立个小目标) 一,安装jenkins插件 首页->系统管理->插件管理,从“ ...

  10. Phaser3跟随自定义路径移动的赛车 -- iFIERO游戏教程

      racingcar 在线预览:http://www.ifiero.com/uploads/phaser/pathrotate/代码: var config = { type: Phaser.AUT ...