本文主要是介绍开发移动端web相册这样一案例用到的前置知识。

一、移动端样式

移动端更接近手机原生的方式。

如下是一个angular mobile的demo的例子:

移动端demo做成这样的好处:

  • 在手机端浏览器中打开,接近原生app应用。
  • 打包成Android或者ios的app,以原生app呈现

二、移动端web开发调试工具

因为移动端主要的浏览器内核是webkit,所以可以用chrome开发。可以模拟UA和分辨率。

模拟触摸行为,注意touch和click区别。

也可以开启其他模拟。

三、移动端开发tips

1、兼容性

Android和ios都是webkit内核,firefox os是greasemonkey内核。

2、 其他差异

弃用事件mousedown,mouseup,click。

使用手势操作代替鼠标输入/输出事件

响应式布局

css3代替DOM animation动画效果

(为兼容IE:PC端用setTimeout定时器,定时修改DOm元素的style属性实现动画)

优势:css3使用设备GUP渲染,动用硬件设备的计算能力做展示,效率高。

四、移动端开发框架和库

1、移动端开发框架和PC端对比

PC端:兼容ie,冗余代码,但是计算效率高。

移动端和PC相比:轻  重效率 ,希望在3g网络加载更少的代码,加载更快。

2、移动端开发框架

移动端开发框架:jquery mobile ,angular mobile ,简单的还用不到框架,通过组件做复杂应用非常简单。我们做的页面简单,谈不上完整的app效果,用不到复杂应用框架。

3、移动端开发库

移动端开发库:zepto.js

也可以用纯原生的javascript的API。

zepto也除了提供一些API,也提供了些插件,比如touch和gesture,。

zepto.js库和其他移动端框架区别,可查资料

touch.js独立于zepto.js存在,单独在github库中

五、touch事件

1、touch事件

touchstart---》touchmove---》touchend和touchcancle

当滑动屏幕时,来了个系统事件,比如来了个电话,此时就会进入接电话面板,整个的触摸事件就会被cancle掉,就会触发touchcancle事件。

zepto.js的touch事件,在原生touch事件基础上做了封装,依赖于zepjs的一些插件,touch.js暴露的事件

  • tap事件 触摸
  • singleTap事件 单次触摸和doubleTap事件
  • longTap长按事件
  • swipe,swipeLeft,swipeRight,swipeUp和swipeDown滑动事件。

2、为什么不能用click

  • click事件300ms延迟
  • touch事件支持多点触摸,click不支持
  • 手势操作

六、canvas优化技巧

1、优势:触发物理设备GPU渲染

使用convas代替image标签做图片展示。

通常来讲,Image标签展示一张图片是用浏览器本身来做渲染的。

当一个图片很大的时候,

或者一个网页中有很多张大的图片的时候,

而你的手机性能又不是特别好的情况下,图片展示就会特别卡。

这个卡通常是在滑动图片,滚动条滚动图片的时候,会感觉图片非常卡,因为没有触发物理设备本身的GPU来渲染。

如何触发物理设备GPU渲染?使用Canvas。

2、drawImage API

有一本书《HTML5 Canvas》来介绍canvas,内容太多,下面只介绍一个API。

drawImage API:把一张原本使用Image标签的图片画在Canvas上面。

  • drawImage(image,x,y);在Canvas上绘制图片。
  • drawImage(image,x,y,width,height);在Canvas上缩放并绘制图片。

通常用到drawImage(image,x,y,width,height)。

参数image:image对象,要画的图片。

x,y:要画的图片是从canvas的哪个坐标点开始。

坐标通常是(0,0) 点,使用的也是第四象限的坐标系。

width,height:要画的这张图的宽度和高度是多少,通常不传也可以,不传的话图片有多大画多大。

传入的话就是控制图片的缩放。

七、 Image对象

drawImage第一个参数要传入一Image对象,那什么是Image对象呢?

在手机上加载图片,有一种方式,预加载图片。预加载图片就要用的Image对象了。我们通常看到的是Image标签。

Image标签就可以理解为Image对象。

Image对象的作用:预加载图片和图片按比例缩放。

例子:

当设置一个img对象的src的时候,实际上就是向网络上发送一个请求,来请求这张图片。

var img=new Image();
img.onload=function(){
debugger
}
img.src='https://www.baidu.com/img/bdlogo.gif';

执行的时候进入了img的onload事件,说明请求发送成功了,同时图片加载回来了,才会触发Image对象的onload()方法。

可以看看Image标签加载回来的图片都有些什么属性?

可以在控制台debug的Watch中添加一个this。

通过这种方式加载出来的图片,我们可以获得它的高度,宽度。以及它的自然的宽度和自然的高度。

有了这些信息,可以根据图片大小和当前设备的分辨率动态的调整图片的大小。如果只使用传统的Image标签是没办法做到的。

八、css3动画事件

点击animation了解css3动画知识。

为什么要有动画事件?当一个动画结束后,我想执行一个操作时怎么办?怎么用js做逻辑控制?此时必须用css3的动画事件。

当一个动画结束的时候,我们可以监听一个元素的animationEnd事件来实现。

webkit浏览器需要加webkit前缀。

做动画时, css3动画框架可以用animate.css

引用animate.css,在动画元素上加class animate rotateIn。

本文作者starof,因知识本身在变化,作者也在不断学习成长,文章内容也不定时更新,为避免误导读者,方便追根溯源,请诸位转载注明出处:http://www.cnblogs.com/starof/p/4904929.html有问题欢迎与我讨论,共同进步。

移动端开发demo—移动端web相册(一)的更多相关文章

  1. htm5移动端开发 和 pc端开发

    htm5移动端开发: 移动端开发需要注意的一些事情:http://www.duanliang920.com/learn/web/html5/321.html HTML5移动端手机网站开发流程:http ...

  2. 个人公众号服务端开发Demo

    公众号出来很久了,也可以个人申请.知道公众号的服务端开发其实很简单,接口调用封装,数据存取,不外如是. 人一旦懒了,真的是 “无可救药” 了...现简单描述晚到的公众号HelloWorld 思路 公众 ...

  3. Redis的Windows端开发连接Linux端以及相应的代码实现

    在Windows端开发连接需要进行配置文件的配置: 在redis.conf配置文件中 将protected-mode yes,修改为protected-mode no:不保护redis # By de ...

  4. 01-移动端开发教程-CSS3新特性

    1. 移动端开发课程概述 移动互联网的兴起,让移动端的开发迅速蹿红.对于前端开发者来说,移动端的开发已经占据了他们大部分工作时间.接下来老马带大家一起学习移动端开发的相关前端开发技术. 这边课程内容包 ...

  5. 大前端全栈CSS3移动端开发

    作者声明:本博客中所写的文章,都是博主自学过程的笔记,参考了很多的学习资料,学习资料和笔记会注明出处,所有的内容都以交流学习为主.有不正确的地方,欢迎批评指正 本节课学习视频来源:https://ww ...

  6. 【移动端 Web】怎么循序渐进地开发一个移动端页面

    1. 移动页面开发基础 1.1 像素——什么是像素 像素是 Web 页面布局的基础,那么到底什么才是一个像素呢? 像素:一个像素就是计算机屏幕所能显示一种特定颜色的最小区域.这是像素的概念,实际上,W ...

  7. web开发中移动端适配

    这个话题有些复杂,说起来有些琐碎,因为和移动端适配相关的问题太多了. 1. 概念 1.1 设备像素 设备像素被称为物理像素,它是显示设备中一个最小的物理部件.每个像素可以根据操作系统设置自己的颜色和亮 ...

  8. web移动端开发技巧与注意事项汇总

    一.meta的使用 1.<meta name="viewport" content="width=device-width,initial-scale=1.0, m ...

  9. web移动端开发技巧

    一.meta的使用 1.<meta name="viewport" content="width=device-width,initial-scale=1.0, m ...

随机推荐

  1. Liunx之KVM搭建图形化的WEB

    作者:邓聪聪 我们常在Windowns下使用VMware,当然在Liunx中也有这样的软件供我们使用.生产环境的KVM宿主机越来越多,需要对宿主机的状态进行调控.这里用webvirtmgr进行管理.图 ...

  2. python二叉树练习

    #coding=utf8 node_list=[5,3,6,2,4,None,8,1,None,None,None,7,9] class Node: def __init__(self,item): ...

  3. 001_谈阿里核心业务监控平台SunFire的技术架构

    <1>阿里全球运行指挥中心(GOC)的SunFire出品 <2>在2016年双11全球购物狂欢节中,天猫全天交易额1207亿元,前30分钟每秒交易峰值17.5万笔,每秒支付峰值 ...

  4. Zabbix监控nginx性能的另外一种方式

    Zabbix监控nginx性能的另外一种方式 nginx和php-fpm一样内建了一个状态页,对于想了解nginx的状态以及监控nginx非常有用,为了后续的zabbix监控,我们需要先启用nginx ...

  5. 最新版Kali Linux虚拟机安装Open-vm-tools替代VMware tools

    自从Kali 2.0发布之后,会经常遇到安装vmware tools无法成功,或者提示安装成功了但是仍旧无法进行文件拖拽.复制和剪切的问题. 今天给新电脑装系统,重新下载了最新版,Kali 2017. ...

  6. 使用PHP Manager for IIS时,Windws 10自带IIS注意事项

    1)开启IIS 10:在“控制面板”的“程序和功能”的“启用或关闭Windows功能”内,勾选(启用)“Internet Information Services”,然后确定,进行安装. 2)若要使用 ...

  7. RianbowDesign

    换了很多个名字,最后换成这个. 主要考虑把自己所学的.所经历的都结合到一起,用这种方式来保持热情. 算是一个设计网站,管理咨询,游戏设计,平面logo之类,想最多地攘括到里边.就像自己不确定的主业一样 ...

  8. Oracle12c安装和卸载图文教程

    注:本文来源于:<Oracle12c安装和卸载图文教程> 一.安装 1.去官网下载相应的版本 2.下载好的两个压缩文件压缩到一个文件夹中 3.打开上个步骤的文件夹,运行stepup,显示如 ...

  9. vuejs中使用echarts

    <style scoped> .content { /*自行添加样式即可*/ } #main { /*需要制定具体高度,以px为单位*/ height: 400px; } </sty ...

  10. 第一次Java测试及感触

    周四进行了java测试,感触很深,测试的题目是用Java实现一个ATM机的管理系统.最后3个小时后,我没有完成这次测试,但是我找到了自己的很多不足,明确了自己的问题究竟在哪里. 关于这次测试我不会的最 ...