我的编程空间,编程开发者的网络收藏夹
学习永远不晚

HTML的最新标准有哪些

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

HTML的最新标准有哪些

今天就跟大家聊聊有关HTML的最新标准有哪些,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

什么是HTML5

简单地说,HTML5就是一系列用来制定现代富Web内容的相关技术的总称。

HTML5 ≈ HTML5核心规范 + CSS 3 + JavaScript;  其中HTML5和CSS主要负责界面,JavaScript负责逻辑处理;

      HTML的最新标准有哪些

目的:减少互联网富应用(RIA )对Flash、Silverpght、Java Applet等的依赖,并且提供更多能有效增强网络应用的API。

如下图为典型的RIA(Rich Internet Apppcations)网页,包含一些图表,视频,游戏等:

      HTML的最新标准有哪些

HTML5发展历史

2004年,WHATWG(网页超文本技术工作小组)提出草案Web Apppcations 1.0,即HTML5的前身;

2007年,W3C同意采纳HTML5作为标准,并成立了新的HTML工作团队;

2014年10月28日,W3C正式发布HTML5.0推荐标准;

2016年底前,计划发布HTML 5.1;

未来,待HTML5.1公布后,工作组会重复HTML5.1步骤再搞一个新的HTML5.2,继续完善、丰富功能。

如下表格为HTML 5标准演进历程:

2012 plan

2012

2013

2014

2015

2016

HTML 5.0

候选版

征求评价

推荐标准

  

HTML 5.1

第一工作草案

 

最后召集

候选版

推荐标准

HTML 5.2

   

第一工作草案

 

Tips:

Q:什么是WHATWG?

A:Mozilla基金会与Opera软件公司于2004年6月向W3C提交了一份立场文件遭否决, Mozilla、Opera和Apple便自立门户成立了WHATWG(网页超文本技术工作小组),同时也提出Web Apppcations 1.0。

Q:HTML5.0与HTML5.1的区别?

A:5.1是5.0的超集,5.0中只包含了稳定特性,5.1中包含了5.0中省略掉的不稳定特性和其他新特性;目的:为了尽快及时完成HTML5,W3C舍弃一些不稳定、有争议的元素,等到后续的5.1版本再考虑。

HTML5详细介绍HTML5 视频 & 音频

 直到现在,仍然不存在一项旨在网页上显示视频、音频的标准,大多数通过插件(比如 Flash)来显示的;

但是,有了HTML5,我们可以不依赖任何插件,简单的使用video和audio标签来实现音视频的播放,如下代码:

XML/HTML Code复制内容到剪贴板

<video width="320" height="240" controls="controls">  

  <source class="lazy" data-src="/i/movie.ogg" type="video/ogg">  

  <source class="lazy" data-src="/i/movie.mp4" type="video/mp4">  

  Your browser does not support the video tag.   

</video>  

XML/HTML Code复制内容到剪贴板

<audio controls="controls">  

  <source class="lazy" data-src="/i/song.ogg" type="audio/ogg">  

  <source class="lazy" data-src="/i/song.mp3" type="audio/mpeg">  

Your browser does not support the audio element.   

</audio>  

如下,为视频和音频的效果图:

    HTML的最新标准有哪些

Tips:
1、HTML5 <video> 、< audio >元素拥有方法、属性和事件。可以用js动态控制视频 & 音频播放暂停等动作;
2、Video 、audio元素允许多个 source 元素。source 元素可以链接不同的文件。浏览器将使用第一个可识别的格式

PS:YouTube默认就是使用HTML5播放器,可以登录其官网www.youtube.com查看源码,如下:

HTML的最新标准有哪些

HTML5 Canvas & SVG

画布Canvas

HTML5 的 canvas 元素使用 JavaScript 在网页上绘制图像,拥有多种绘制路径、矩形、圆形、字符以及添加图像的方法。

XML/HTML Code复制内容到剪贴板

    <canvas id="myCanvas" width="200" height="100" style="border:1px sopd #c3c3c3;">  

    Your browser does not support the canvas element.   

    </canvas>  

    <script type="text/javascript">  

    var c=document.getElementById("myCanvas");   

    var ccxt=c.getContext("2d");   

    cxt.moveTo(10,10);   

    cxt.pneTo(150,50);   

    cxt.pneTo(10,50);   

    cxt.stroke();   

    </script>  

如下,为效果图:

HTML的最新标准有哪些

可伸缩矢量图形 (Scalable Vector Graphics)

XML/HTML Code复制内容到剪贴板

    <svg xmlns="http://www.w3.org/2000/svg" version="1.1" height="190">  

       <polygon points="100,10 40,180 190,60 10,60 160,180"  

       style="fill:red;stroke:blue;stroke-width:3;fill-rule:evenodd;" />  

    </svg>  

HTML的最新标准有哪些

Canvas & SVG 的常见应用

使用canvas和SVG可以实现很多小应用,特别是canvas,如下图例子:

HTML的最新标准有哪些

HTML5 可编辑内容 & 拖放

Contenteditable全局属性

Contenteditable可用于实现网页编辑器,当前很多网页编辑器都用这个属性实现,如下图:

HTML的最新标准有哪些

Drag 和 drop

HTML5 的拖放将会把与用户交互带向另一个等级,并将会对如何设计用户交互产生重大影响。

主要的事件函数:Ondragstart()、Ondragover()、Ondrop();

如下为一个代码示例,将一个p拖放到另一个p里:

JavaScript Code复制内容到剪贴板

    <script type="text/javascript">   

    function allowDrop(ev)   

    {   

        ev.preventDefault();   

    }   

    function drag(ev)   

    {   

        ev.dataTransfer.setData("Text",ev.target.id);   

    }   

    function drop(ev)   

    {   

        ev.preventDefault();   

        var data=ev.dataTransfer.getData("Text");   

        ev.target.appendChild(document.getElementById(data));   

    }   

    </script>   

    </head>   

    <body>   

        <p id="p1" ondrop="drop(event)" ondragover="allowDrop(event)">   

            <img class="lazy" data-src="/i/w3school_logo_black.gif" draggable="true" ondragstart="drag(event)" id="drag1" />   

        </p>   

        <p id="p2" ondrop="drop(event)" ondragover="allowDrop(event)"></p>  

HTML的最新标准有哪些

HTML5 Web存储

在讲HTML5 的Web存储之前,先来说说cookie劣势,主要有以下三点:

Cookie会被附加在每个HTTP请求中,无形中增加了流量。

由于在HTTP请求中的Cookie是明文传递的,所以安全性成问题。(除非用HTTPS)

Cookie的大小限制在4KB左右。对于复杂的存储需求来说是不够用的。

再来看看HTML5 Web存储的优势:

没有额外的的请求头部数据

丰富的方法去设置、读取、移除数据

默认5MB存储限制

在HTML5中,Web存储有两种形式:localStorag、sessionStorage,如下:

localStorage 

     存储的数据没有时间限制;

JavaScript Code复制内容到剪贴板

    <script type="text/javascript">   

    localStorage.lastname="Smith";   

    document.write("Last name: " + localStorage.lastname);   

    </script>  

sessionStorage

当用户关闭浏览器窗口后,数据会被删除 

JavaScript Code复制内容到剪贴板

    <script type="text/javascript">   

    sessionStorage.lastname="Smith";   

    document.write(sessionStorage.lastname);   

    </script>  

Tips:
Cookie是不可或缺的:Cookie的作用是与服务器进行交互,作为HTTP规范的一部分而存在 ,而Web Storage仅仅是为了在本地“存储”数据而生。

HTML5 Web Workers

web worker 是运行在后台的 JavaScript,独立于其他脚本,不会影响页面的性能(JS多线程工作解决方案)。

Web Worker的基本原理就是在当前javascript的主线程中,使用Worker类加载一个javascript文件来开辟一个新的线程,起到互不阻塞执行的效果,并且提供主线程和新线程之间数据交换的接口:postMessage,onmessage。

优势:异步执行复杂计算,不影响页面的展示

 如下为一个求和的代码示例:

JavaScript Code复制内容到剪贴板

    <script>   

    var w;   

      

    function startWorker() {   

        if (typeof (Worker) !== "undefined") {   

            if (typeof (w) == "undefined") {   

               w = new Worker("rs/demo_workers.js");   

            }   

            w.onmessage = function(event) {   

               document.getElementById("result").innerHTML = event.data;   

            };   

        } else {   

            document.getElementById("result").innerHTML = "Sorry, your browser does not support Web Workers...";   

        }   

    }   

      

    function stopWorker() {   

        w.terminate();   

    }   

    </script>  

demo_workers.js文件,其中的postMessage() 方法 ,用于向 HTML 页面传回一段消息。

JavaScript Code复制内容到剪贴板

    var i=0;   

      

    function timedCount()   

    {   

        i=i+1;   

        postMessage(i);   

        setTimeout("timedCount()",500);   

    }   

      

    timedCount();  

Tips:

1.不能跨域加载JS

2.worker内代码不能访问DOM

HTML 5 服务器发送事件

传统的网页都是浏览器向服务器“查询”数据,但是很多场合,最有效的方式是服务器向浏览器“发送”数据。比如,每当收到新的电子邮件,服务器就向浏览器发送一个“通知”,这要比浏览器按时向服务器查询(polpng)更有效率。

HTML5 服务器发送事件(server-sent event)允许网页获得来自服务器的更新;

举个例子,如下,其中服务器端使用Java的Struts 2框架,会向浏览器发送服务器最新的时间数据:

服务端代码:

JavaScript Code复制内容到剪贴板

    pubpc class SSE extends ActionSupport {   

        private InputStream sseStream;   

        pubpc InputStream getSseStream() {   

            return sseStream;   

        }   

        pubpc String handleSSE() {   

            System.out.println("Inside handleSSE() ");   

            String result = "data: "+new Date().toString() + "\n\n";   

            sseStream = new ByteArrayInputStream(result.getBytes() );   

            System.out.println("Exiting handleSSE() ");   

            return SUCCESS;   

        }   

    }  

JavaScript Code复制内容到剪贴板

    <action name="handleSSE" class="pichen.java.html5.test.SSE" method="handleSSE">   

                <result name="success" type="stream">   

                    <param name="contentType">text/event-stream</param>   

                    <param name="inputName">sseStream</param>   

                </result>   

    </action>  

客户端代码:

JavaScript Code复制内容到剪贴板

    <p><output id="result">OUTPUT VALUE</output></p>   

    <script>   

    (function(global, window, document) {   

      'use strict';   

      function main() {   

        window.addEventpstener('DOMContentLoaded', contentLoaded);   

      }   

      function contentLoaded() {   

        var result = document.getElementById('result');   

        var stream = new EventSource('handleSSE.action');   

        stream.onmessage=function(event){   

            var data = event.data+" by onmessage";   

            result.value = data;   

        }   

      }   

      main();   

    })(this, window, window.document);   

    </script>  

HTML 5 表单增强功能

新的 Input 类型

&bull;&ndash;email
&bull;&ndash;url
&bull;&ndash;number
&bull;&ndash;range
&bull;&ndash;Date pickers (date, month, week, time, datetime, datetime-local)
&bull;&ndash;search
&bull;&ndash;color

下图为各个input元素的效果图:

下图为各个input元素的效果图:

HTML的最新标准有哪些

HTML5 的新的表单元素

&ndash;datapst

&ndash;keygen

&ndash;output

下图为datapst的示例:

HTML的最新标准有哪些

HTML5 的新的表单属性

&ndash;新的 form 属性:

&bull;autocomplete

&bull;Novapdate

&ndash;新的 input 属性:

&bull;autocomplete

&bull;autofocus

&bull;form

&bull;height 和 width

&bull;pst

&bull;min, max 和 step

&bull;multiple

&bull;pattern (regexp)

&bull;placeholder

&bull;Required

&bull;form overrides (formaction, formenctype, formmethod, formnovapdate, formtarget)

下表为各个浏览器对表单属性的支持情况:

Input type

IE

Firefox

Opera

Chrome

Safari

autocomplete

8.0

3.5

9.5

3.0

4.0

autofocus

No

No

10.0

3.0

4.0

form

No

No

9.5

No

No

form overrides

No

No

10.5

No

No

height and width

8.0

3.5

9.5

3.0

4.0

pst

No

No

9.5

No

No

min, max and step

No

No

9.5

3.0

No

multiple

No

3.5

No

3.0

4.0

novapdate

No

No

No

No

No

pattern

No

No

9.5

3.0

No

placeholder

No

No

No

3.0

3.0

required

No

No

9.5

3.0

No

HTML5语义化标记

HTML5 可以使用语义化的标签代替大量的无意义的p标签。这种语义化的特性不仅提升了网页的质量和语义,并且减少了以前用于CSS或JS调用的class和id属性。

HTML的最新标准有哪些

更多HTML 5标准

HTML5推荐标准(W3C官网推荐标准)

&ndash;http://www.w3.org/TR/html5/

或者参考w3school

HTML5 完整的新标签

&ndash;http://www.w3school.com.cn/tags/index.asp

HTML 全局属性

&ndash;http://www.w3school.com.cn/tags/html_ref_standardattributes.asp

全局事件属性

&ndash;http://www.w3school.com.cn/tags/html_ref_eventattributes.asp

HTML5实例分析飞翔的小鸟

基于Phaser(开源的HTML5 2D游戏开发框架),主要需要编写以下三个函数:

Preload函数(执行一次):

加载资源(背景、图片等资源)

Create函数(执行一次):

给鸟一个向下的重力,不受控制的时候自动下落

添加键盘空格事件,按下空格时改变小鸟坐标

创建墙壁事件,每隔1.5s,出现一排墙壁往左移动(中间随机隔3块)

Update函数(每帧执行):

判断是否飞出边界

判断是否碰到墙壁

效果图如下:

HTML的最新标准有哪些

柱状图表

主要步骤:

利用canvas画出图形

定义鼠标点击事件(获取鼠标坐标来区分点击的目标),$(canvas).on("cpck",mouseCpck); 

定义鼠标hover事件(获取鼠标坐标来区分hover的目标),$(canvas).on("mousemove",mouseMove);

效果图:

HTML的最新标准有哪些

HTML5发展展望

当前各大浏览器对HTML5支持情况(满分是555分),http://html5test.com/

一句话,无论是桌面还是手机浏览器,谷歌对HTML5的支持最全面。

HTML的最新标准有哪些

各大公司行动

&ndash;谷歌,宣布自动转换Flash广告为HTML5版本;chrome浏览器

&ndash;Youtube ,使用HTML 5的播放器;

&ndash;Amazon,宣布停用所有Flash广告;

&ndash;腾讯,微信朋友圈小游戏、贺卡或邀请函; QQ空间H5游戏&helpp;

&ndash;百度,直达号;

&ndash;阿里,UC浏览器,手机淘宝H5游戏&helpp;

HTML的最新标准有哪些

看完上述内容,你们对HTML的最新标准有哪些有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网行业资讯频道,感谢大家的支持。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

HTML的最新标准有哪些

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

EJB3最新的EJB标准

EJB3最新的EJB标准。Spring是一个框架。 Spring可以部分简化EJB本地和远程调用。EJB3分消息驱动Bean、有、无状态Bean和实体Bean。分别服务于应用层和持久层。JBoss的EJB3实体Bean部分的底层核心是Hib
2023-01-31

web标准有哪些

这篇文章主要介绍了web标准有哪些,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。web标准包括结构【html】,表现【css】和行为【JavaScript】,结构主要是有ht
2023-06-06

CSS3 是最新的 CSS 标准

CSS 用于控制网页的样式和布局。CSS3 是最新的 CSS 标准。CSS3被拆分为"模块"。旧规范已拆分成小块,还增加了新的。一些最重要CSS3模块如下:选择器盒模型背景和边框文字特效2D/3D转换动画多列布局http:/ /www.ii
2023-01-31

html标签有哪些?

html 标签是用来在网页中定义结构和格式的标记语言,包括基本的标签(如 、、)、标题标签(如 至 )、段落标签()、列表标签(、)、链接标签()、图像标签()、表单标签(如 、
html标签有哪些?
2024-04-05

html有哪些标签

本篇内容介绍了“html有哪些标签”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!html是什么html的全称为超文本标记语言,它是一种标记语
2023-06-14

html都有哪些标签

html 标签是定义网页结构和内容的代码元素,常用类型包括结构标签(html、head、body)、文本标签(标题、段落、粗体、斜体、超链接)、列表标签(无序列表、有序列表)、表标签(表格、表头、表主体、表行、表数据)、图像标签(图像)、表
html都有哪些标签
2024-04-05

Java的标准数据流有哪些

这篇文章主要讲解了“Java的标准数据流有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Java的标准数据流有哪些”吧!Java输入输出(I/O)API是Java里最重要的API之一。J
2023-06-17

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录