HTML5重点内容总结

html-css016

HTML5重点内容总结,第1张

一、 HTML5新增的标签

(1)header nav main  footer  section article hgroup  figure figcaption  aside 

    video  audio canvas

                (2)如何让新标签兼容低版本浏览器:  html5shiv.js

二、 HTML5新增的表单控件

    一、表单控件的新属性

            <input type="text"  placeholder=""  required  autofocus  pattern="abc" >

    二、新增的表单控件

    (1)<input type="email">

    (2)<input type="url">

      (3)数字控件:  type="number"

      (4)  滑动组件:  type="range"

      (5)  拾色器:      type="color"

      (6)  日期控件:    type="date"

三、本地存储

    1、 三种本地存储 :  cookie webStorage(localStorage  sessionStorage)

    2、localStorage的API

      (1)写入:  localStorage.setItem(键,值)  //值只能是字符串

        localStorage.user = "123" localStorage["user"] = "123"

      (2)读取  var user = localStorage.getItem("user")

                  var user = localStorage.user

        (3)删除:  localStorage.removeItem("user")    localStorage.clear()

        (4)修改:  localStorage.setItem("user","890")

    3、sessionStorage的API

sessionStorage.setItem(键,值)

        sessionStorage.getItem(键)

        sessionStorage.removeItem(键)

sessionStorage.clear()

    **********重点**********

      4、cookie webStorage(localStorage  sessionStorage)三者的区别

四、离线存储

    (1) *.manifest  (*.appcache) 

          index.html  <html manifest="*.manifest">

    (2) 理解离线存储的更新方式

五、移动端的布局思路:

1、设备像素比(倍率)  逻辑像素尺寸 (360px  320px  375px  414px)

            window.devicePixelRatio

        2、 <meta name="viewport" content="width=device-width,maximum-

scale=1.0,minimum-scale=1.0,initial-scale=1.0,user-scalable=no"">

3、使用rem单位

六、地理定位

if (navigator.geolocation){ 

            navigator.geolocation.getCurrentPosition(success,error,{

                timeout: 5000

            })

            function success(pos){

                纬度:  pos.coords.latitute

                经度:  pos.coords.longtitude

            }

        }

        navigator.geolocation.watchPosition(success)

七、地理定位和百度地图API的结合

八、视频,音频  <video autoplay="autoplay" controls="controls" loop="loop" poster=""

preload="preload">  <audio>

九、移动端事件: 

(1) ontouchstart  ontouchmove  ontouchend

(2) 如何判断是否为移动端:  if ("ontouchstart" in document){}

        (3) 移动端事件的事件对象及常用属性

          e.touches[0].clientX  e.touches[0].clientY  e.touches[0].target

        (4) 移动端常见问题及解决方案:

a、 click事件 300ms的延迟:  <1>zepto的tap事件  (2) fastclick.js

b、 zepto的tap事件有点透问题 :  (1) fastclick.js

        (5) zepto的touch模块:  tap  singleTap  doubleTap  longTap 

                swipeLeft  swipeRight  swipeUp  swipeDown

十、swiper.js的使用  (参考官网)

十一、 canvas

(1)  <canvas width="600" id="can"></canvas>    300*150

        (2)  var can = document.getElementById("can")

      var cxt = can.getContext("2d")

  cxt.beginPath()

  cxt.moveTo(100,200)

  cxt.lineTo(200,400)

              cxt.strokeStyle = '#f00'

  cxt.stroke()

                  cxt.clearRect(0,0,200,300)

                  context.globalCompositeOperation="destination-out"  (了解)

学习html可以参考一下的方式:

1. HTML5教程主要学习HTML标签、属性和事件:

参考:http://www.w3school.com.cn/html5/index.asp

2. CSS教程:

主要学习使用CSS来控制网页的样式和布局。

参考:http://www.w3school.com.cn/css/index.asp,需加上一本讲解CSS3的书。

3. JavaScript教程

做HTML5开发,主要使用JS语言。所以要学习JS语言。必要时还要学习一些JS库,方便开发。

JS教程:http://www.w3school.com.cn/js/index.asp

JQuery教程:http://www.w3school.com.cn/jquery/index.asp

4. HTML5其它的核心技术

以上只是基础,做HTML5开发,可能会用到下面的技术。

(1)、WebWorker :

可以在浏览器中运行多个JS脚本。可以用于需要后台执行某种耗时工作的场合。API可以参考:http://www.w3.org/TR/workers/

(2)、WebSocket:

浏览器可以与服务器间双向通信。Socket方式能够大大提高浏览器与服务器间的通信效率。可以用于浏览器与服务器间通信频繁的场合,比如实时聊天。API可以参考:http://www.w3.org/TR/websockets/

(3)Canvas2D

浏览器中画图。可以用于游戏开发等等场合。详细API可以参考:http://www.w3.org/TR/2dcontext/教程可以看:https://developer.mozilla.org/cn/Canvas_tutorial