HTML5学习笔记

HTML5 中的一些有趣的新特性:

  • 用于绘画的 canvas 元素
  • 用于媒介回放的 video 和 audio 元素
  • 对本地离线存储的更好的支持
  • 新的特殊内容元素,比如 article、footer、header、nav、section
  • 新的表单控件,比如 calendar、date、time、email、url、search
  1. <video>

  2. <audio>

  3. 拖放

    • 设置元素可拖放<img draggable="true" />
    • 设置ondragstart事件 ,设置setData()
      <img id="" src="" draggable="true" ondragstart="drag(event)"/>
      function drag(ev)
      {
         ev.dataTransfer.setData("Text",ev.target.id);//设置被拖动数据的数据类型和值
      }
      
    • 设置放到哪
      <div id="" ondrop="drop(event)" ondragover="allowDrop(event)"></div>
       function allowDrop(ev)
       {
         ev.preventDefault();//取消默认的不能放置
       } 
      
       function drop(ev)
       {
         ev.preventDefault();
         var data=ev.dataTransfer.getData("Text");//获得被拖的数据
         ev.target.appendChild(document.getElementById(data));
       }
      
  4. <canvas>

    • 新建一个canvas元素
      <canvas id="myCanvas" width="200" height="100"></canvas>
    • js获得绘制环境
      <script type="text/javascript">
        var c=document.getElementById("myCanvas");
        var cxt=c.getContext("2d");`//getContext("2d") 对象是内建的HTML5 对象,拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法。
      <script>
      
    • 线条
      cxt.moveTo(10,10);//线条的起点
      cxt.lineTo(150,50);//线条要连接的第一个点
      cxt.lineTo(10,50);//线条要连接的第二个点
      cxt.stroke();//绘制实线
      
    • cxt.beginPath();//开始创建路径
      cxt.arc(70,18,15,0,Math.PI*2,true);//x坐标:70,y坐标:18,r:15,
        //起始角度:0,结束角度:Math.PI*2(圆),逆时针
      cxt.closePath();//创建路径结束
      cxt.fill();//路径实现
      
    • 渐变
       var grd=cxt.createLinearGradient(0,0,175,50);
      grd.addColorStop(0,"#FF0000");
      grd.addColorStop(1,"#00FF00");
      cxt.fillStyle=grd;//填充
      cxt.fillRect(0,0,175,50);//绘制
      
      createLinearGradient 包含四个参数x1,y1,x2,y2
      • 如果x1=x2 并且y1!=y2,渐变色改变的方向则是水平。
        如果y1=y2 并且x1!=x2, 渐变色方向是垂直的。
        如果x1!=x2且y1!=y2,渐变色方向则为对角。
    • 图像
      var img=new Image()
      img.src="flower.png"
      cxt.drawImage(img,0,0);
      
      把图像放到画布上
  5. <svg>

    • Canvas:
      依赖分辨率
      不支持事件处理器
      弱的文本渲染能力
      能够以 .png 或 .jpg 格式保存结果图像
      最适合图像密集型的游戏,其中的许多对象会被频繁重绘
      SVG
      不依赖分辨率
      支持事件处理器
      最适合带有大型渲染区域的应用程序(比如谷歌地图)
      复杂度高会减慢渲染速度(任何过度使用 DOM 的应用都不快)
      不适合游戏应用
  6. Geolocation

    var x=document.getElementById("demo");
    function getLocation()
    {
      if (navigator.geolocation)
      {
        navigator.geolocation.getCurrentPosition(showPosition);
      }
      else
      {
        x.innerHTML="Geolocation is not supported by this browser.";
      }
    }
    function showPosition(position)
    {
      x.innerHTML="Latitude: " + position.coords.latitude + "<br/>Longitude: " + position.coords.longitude;
    }
    
  7. web存储
    localStorage - 没有时间限制的数据存储
    sessionStorage - 针对一个 session 的数据存储

  8. 应用缓存

    • 启动应用缓存
      <!DOCTYPE HTML>
      <html manifest="demo.appcache">
       ...
      </html>
      
    • manifest 文件可分为三个部分:
      • CACHE MANIFEST - 在此标题下列出的文件将在首次下载后进行缓存
      • NETWORK - 在此标题下列出的文件需要与服务器的连接,且不会被缓存
      • FALLBACK - 在此标题下列出的文件规定当页面无法访问时的回退页面(比如 404 页面)
  9. Web Workers

  10. 服务器发送事件

  11. 表单

    • 新增input类型
      • email
      • url
      • number
      • range
      • Date pickers (date, month, week, time, datetime, datetime-local)
      • search
      • color
    • 新增表单元素
      • datalist
        <input type="url" list="url_list" name="link" /><--用list绑定datalist的id!-->
        <datalist id="url_list">
          <option label="Google" value="http://www.google.com" />
        </datalist>
        
      • keygen
        <keygen name="security" />
        keygen 元素是密钥对生成器(key-pair generator)。当提交表单时,会生成两个键,一个是私钥,一个公钥。
        私钥(private key)存储于客户端,公钥(public key)则被发送到服务器。公钥可用于之后验证用户的客户端证书(client certificate)。
      • output
    • 新增表单属性
      • autocomplete
        适用于 <form> 标签,以及以下类型的 <input> 标签:text, search, url, telephone, email, password, datepickers, range 以及 color。
        <form action="demo_form.asp" method="get" autocomplete="on">
      • autofocus
        <input type="text" name="user_name" autofocus="autofocus" />
      • form
        form 属性适用于所有 <input> 标签的类型。
        form 属性必须引用所属表单的 id:
        <form action="demo_form.asp" method="get" id="user_form">
        </form>
        <input type="text" name="lname" form="user_form" />
        
      • 表单重写属性
        适用于以下类型的 <input> 标签:submit 和 image。
        formaction - 重写表单的 action 属性
        formenctype - 重写表单的 enctype 属性
        formmethod - 重写表单的 method 属性
        formnovalidate - 重写表单的 novalidate 属性
        formtarget - 重写表单的 target 属性
      • width和height
        height 和 width 属性只适用于 image 类型的 <input> 标签。
      • list
      • min、max、step
      • multiple 属性
        适用于以下类型的 <input> 标签:email 和 file。
      • novalidate 属性
        novalidate 属性规定在提交表单时不应该验证 form 或 input 域。
        适用于 <form> 以及以下类型的 <input> 标签:text, search, url, telephone, email, password, date pickers, range 以及 color.
        <form action="demo_form.asp" method="get" novalidate="true">
          E-mail: <input type="email" name="user_email" />
          <input type="submit" />
        </form>
        
      • pattern属性
      • placeholder属性
      • required属性
  12. Web Socket
    WebSocket 协议本质上是一个基于 TCP 的协议。
    为了建立一个 WebSocket 连接,客户端浏览器首先要向服务器发起一个 HTTP 请求,这个请求和通常的 HTTP 请求不同,包含了一些附加头信息,其中附加头信息"Upgrade: WebSocket"表明这是一个申请协议升级的 HTTP 请求,服务器端解析这些附加的头信息然后产生应答信息返回给客户端,客户端和服务器端的 WebSocket 连接就建立起来了,双方就可以通过这个连接通道自由的传递信息,并且这个连接会持续存在直到客户端或者服务器端的某一方主动的关闭连接。

    事件 事件处理程序 描述
    open Socket.onopen 连接建立时触发
    message Socket.onmessage 客户端接收服务端数据时触发
    error Socket.onerror 通信发生错误时触发
    close Socket.onclose 连接关闭时触发

    新建var Socket = new WebSocket(url, [protocol] );

  13. 语义元素

h5语义元素
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,490评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,581评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,830评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,957评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,974评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,754评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,464评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,357评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,847评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,995评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,137评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,819评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,482评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,023评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,149评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,409评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,086评论 2 355

推荐阅读更多精彩内容