《HTML5CSS3权威指南(第二章).ppt》由会员分享,可在线阅读,更多相关《HTML5CSS3权威指南(第二章).ppt(35页珍藏版)》请在三一办公上搜索。
1、HTML5&CSS3权威指南,第二章 HTML 5与HTML 4的区别,第二章 HTML 5与HTML 4的区别,2.1 HTML 5的语法变化2.2 HTML 5中的标记方法2.3 HTML 5确保了与之前HTML版本的兼容性 2.4 HTML5新增的结构元素2.5 HTML5新增的其他元素2.6 HTML5 新增的input元素的类型 2.7 HTML5 废除的元素 2.8 HTML5 新增的属性2.9 HTML5 废除的属性2.10 HTML5全局属性,2.1 HTML 5的语法变化,与HTML 4相比,HTML 5在语法上发生了很大的变化。可能有很多人会有疑问,“之前的HTML已经相当
2、普及了!”,“如果改变基础语法,会产生什么影响?”等。但是,HTML 5中的语法变化,与其他开发语言中的语法变化在根本意义上有所不同。它的变化,正是因为在HTML 5之前几乎没有符合标准规范的Web浏览器!HTML的语法是在SGML(Standard Generalized Markup Language)语言的基础上建立起来的。但是SGML语法非常复杂,要开发能够解析SGML语法的程序也很不容易,所以很多浏览器都不包含SGML的分析器。因此,虽然HTML基本上遵从SGML的语法,但是对于HTML的执行在各浏览器之间并没有一个统一的标准。在这种情况下,各浏览器之间的互兼容性和互操作性在很大程度
3、上取决于网站或网络应用程序的开发者们在开发上所做的共同努力,而浏览器本身始终是存在缺陷的如上所述,在HTML 5中提高Web浏览器之间的兼容性是它的一个很大的目标,为了确保兼容性,就要有一个统一的标准。因此,在HTML 5中,就围绕着这个Web标准,重新定义了一套在现有的HTML的基础上修改而来的语法,使它运行在各浏览器时各浏览器都能够符合这个通用标准。因为关于HTML 5语法解析的算法也都提供了详细的记载,所以各Web浏览器的供应商们可以把HTML 5分析器集中封装在自己的浏览器中。最新的Firefox(默认为4.0以后的版本)与WebKit浏览器引擎中都迅速地封装了供HTML 5使用的分析
4、器,IE(Internet Explorer)与Opera也在努力加快对于HTML 5的支持浏览器兼容性的提高指日可待。接下来,让我们具体看一下在HTML 5中,到底对语法进行了哪些改变。,2.2 HTML 5中的标记方法,首先,让我们来看一下在HTML 5中的标记方法。1.内容类型(ContentType)首先,HTML 5的文件扩展符与内容类型保持不变。也就是说,扩展符仍然为“.html”或“.htm”,内容类型(ContentType)仍然为“text/html”。2.DOCTYPE声明DOCTYPE声明是HTML文件中必不可少的,它位于文件第一行。在HTML 4中,它的声明方法如下:在
5、HTML 5中,刻意不使用版本声明,一份文档将会适用于所有版本的HTML。HTML 5中的DOCTYPE声明方法(不区分大小写)如下:,2.2 HTML 5中的标记方法,另外,当使用工具时,也可以在DOCTYPE声明方式中加入SYSTEM识别符,声明方法如下面的代码所示:在HTML 5中像这样的DOCTYPE声明方式是允许的(不区分大小写,引号不区分是单引号还是双引号)3.指定字符编码在HTML 4中,使用meta元素的形式指定文件中的字符编码,如下所示:在HTML 5中,可以使用对 元素直接追加charset属性的方式来指定字符编码,如下所示:两种方法都有效,可以继续使用前面一种方式(通过c
6、ontent元素的属性来指定),但是不能同时混合使用两种方式。在以前的网站代码中可能会存在下面代码所示的标记方式,但在HTML 5中,这种字符编码方式将被认为是错误的,这一点请注意:,2.3 HTML 5确保了与之前HTML版本的兼容性,HTML 5的语法是为了保证与之前的HTML语法达到最大程度的兼容而设计的。例如,符合“没有的结束标记”的HTML代码随处可见,HTML 5中并没有把这种情况作为错误来处理,而是允许存在这种情况,但明确地规定了这种情况应该怎么处理。那么,针对这个问题,让我们从元素标记的省略、具有boolean值的属性、引号的省略这几方面来详细看一下在HTML 5中是如何确保与
7、之前版本的HTML达到兼容的。1.可以省略标记的元素在HTML 5中,元素的标记可以省略。具体来说,元素的标记分为“不允许写结束标记”、“可以省略结束标记”和“开始标记和结束标记全部可以省略”三种类型。让我们来针对这三类情况列举一个元素清单,其中包括HTML 5中的新元素。,2.3 HTML 5确保了与之前HTML版本的兼容性,不允许写结束标记的元素有:area、base、br、col、command、embed、hr、img、input、keygen、link、meta、param、source、track、wbr。可以省略结束标记的元素有:li、dt、dd、p、rt、rp、optgroup
8、、option、colgroup、thead、tbody、tfoot、tr、td、th。可以省略全部标记的元素有:html、head、body、colgroup、tbody。说明:“不允许写结束标记的元素”是指,不允许使用开始标记与结束标记将元素括起来的形式,只允许使用“”的形式进行书写。例如“.”的书写方式是错误的,正确的书写方式为“”。当然,HTML 5之前的版本中这种写法可以被沿用。“可以省略全部标记的元素”是指,该元素可以完全被省略。请注意,即使标记被省略了,该元素还是以隐式的方式存在的。例如将body元素省略不写时,但它在文档结构中还是存在的,可以使用document.body进行访
9、问。,2.3 HTML 5确保了与之前HTML版本的兼容性,2.具有boolean值的属性对于具有boolean值的属性,例如disabled与readonly等,当只写属性而不指定属性值时,表示属性值为true;如果想要将属性值设为false,可以不使用该属性。另外,要想将属性值设定为true时,也可以将属性名设定为属性值,或将空字符串设定为属性值。属性值的设定方法可以参考下面的代码示例:,2.3 HTML 5确保了与之前HTML版本的兼容性,3.省略引号大家已经知道,指定属性值的时候,属性值两边既可以用双引号,也可以用单引号。HTML 5在此基础上做了一些改进,当属性值不包括空字符串、“”
10、、“=”、单引号、双引号等字符时,属性值两边的引号可以省略。如下面的代码所示:,2.4 HTML5新增的结构元素,在HTML 5中,新增了以下与结构相关的元素:section元素section元素表示页面中的一个内容区块,比如章节、页眉、页脚或页面中的其他部分。它可以与h1、h2、h3、h4、h5、h6等元素结合起来使用,标示文档结构。HTML 5中代码示例:.HTML 4中代码示例:.article元素article元素表示页面中的一块与上下文不相关的独立内容,譬如博客中的一篇文章或报纸中的一篇文章。HTML 5中代码示例:.HTML 4中代码示例:.,2.4 HTML5新增的结构元素,as
11、ide元素aside元素表示article元素的内容之外的、与article元素的内容相关的辅助信息。HTML 5中代码示例:HTML 4中代码示例:.header元素header元素表示页面中一个内容区块或整个页面的标题。HTML 5中代码示例:.HTML 4中代码示例:.,2.4 HTML5新增的结构元素,hgroup元素hgroup元素用于对整个页面或页面中一个内容区块的标题进行组合。HTML 5中代码示例:.HTML 4中代码示例:.footer元素footer元素表示整个页面或页面中一个内容区块的脚注。一般来说,它会包含创作者的姓名、创作日期以及创作者联系信息。HTML 5中代码示例
12、:HTML 4中代码示例:.,2.4 HTML5新增的结构元素,nav元素nav元素表示页面中导航链接的部分。HTML 5中代码示例:HTML 4中代码示例:figure元素figure元素表示一段独立的流内容,一般表示文档主体流内容中的一个独立单元。使用 figcaption元素为figure元素组添加标题。HTML 5中代码示例:PRCThe Peoples Republic of China was born in 1949.HTML 4中代码示例:PRCThe Peoples Republic of China was born in 1949.,2.5 HTML5新增的其他元素,除了
13、结构元素外,在HTML 5中,还新增了以下元素:video元素video元素定义视频,比如电影片段或其他视频流。HTML 5中代码示例:video元素 HTML 4中代码示例:audio元素audio元素定义音频,比如音乐或其他音频流。HTML 5中代码示例:audio元素 HTML 4中代码示例:,2.5 HTML5新增的其他元素,embed元素embed元素用来插入各种多媒体,格式可以是 Midi、Wav、AIFF、AU、MP3等。HTML 5中代码示例:HTML 4中代码示例:mark元素mark元素主要用来在视觉上向用户呈现那些需要突出显示或高亮显示的文字。mark元素的一个比较典型的
14、应用就是在搜索结果中向用户高亮显示搜索关键词。HTML 5中代码示例:HTML 4中代码示例:,2.5 HTML5新增的其他元素,progress元素progress元素表示运行中的进程,可以使用 progress元素来显示 JavaScript 中耗费时间的函数的进程。HTML 5中代码示例:这是HTML 5中新增功能,故无法用HTML 4代码来实现。time元素time元素表示日期或时间,也可以同时表示两者。HTML 5中代码示例:HTML 4中代码示例:,2.5 HTML5新增的其他元素,ruby元素ruby元素表示ruby注释(中文注音或字符)。HTML 5中代码示例:汉()这也是HT
15、ML 5中新增的功能。rt元素rt元素表示字符(中文注音或字符)的解释或发音。HTML 5中代码示例:汉 这是HTML 5中新增的功能。rp元素rp元素在ruby注释中使用,以定义不支持ruby元素的浏览器所显示的内容。HTML 5中代码示例:汉()这是HTML 5中新增的功能。,2.5 HTML5新增的其他元素,wbr元素wbr元素表示软换行。wbr元素与br元素的区别是:br元素表示此处必须换行;而wbr元素的意思是浏览器窗口或父级元素的宽度足够宽时(没必要换行时),不进行换行,而当宽度不够时,主动在此处进行换行。wbr元素好像对字符型的语言作用挺大,但是对于中文,貌似没多大用处。HTML
16、 5中代码示例:To learn AJAX,you must be familiar with the XMLHttp Request Object.这是HTML 5中新增的功能。canvas元素canvas元素表示图形,比如图表和其他图像。这个元素本身没有行为,仅提供一块画布,但它把一个绘图API展现给客户端JavaScript,以使脚本能够把想绘制的东西绘制到这块画布上。HTML 5中代码示例:HTML 4中代码示例:,2.5 HTML5新增的其他元素,command元素command元素表示命令按钮,比如单选按钮、复选框或按钮。HTML 5中代码示例:这是HTML 5中新增的功能。det
17、ails元素details元素表示用户要求得到并且可以得到的细节信息。它可以与summary元素配合使用。summary元素提供标题或图例。标题是可见的,用户点击标题时,会显示出细节信息。summary元素应该是details元素的第一个子元素。HTML 5中代码示例:HTML 5This document teaches you everything you have to learn about HTML 5.这是HTML 5中新增的功能。,2.5 HTML5新增的其他元素,datalist元素datalist元素表示可选数据的列表,与input元素配合使用,可以制作出输入值的下拉列表。H
18、TML 5中代码示例:这是HTML 5中新增的功能。datagrid元素datagrid元素表示可选数据的列表,它以树形列表的形式来显示。HTML 5中代码示例:,2.5 HTML5新增的其他元素,这是HTML 5中新增的功能。keygen元素keygen元素表示生成密钥。HTML 5中代码示例:这是HTML 5中新增的功能。output元素output元素表示不同类型的输出,比如脚本的输出。HTML 5中代码示例:HTML 4中代码示例:,2.5 HTML5新增的其他元素,source元素source元素为媒介元素(比如和)定义媒介资源。HTML 5中代码示例:HTML 4中代码示例:men
19、u元素menu元素表示菜单列表。当希望列出表单控件时使用该标签。HTML 5中代码示例:Redblue在HTML 4中,menu元素不被推荐使用。,2.6 HTML5 新增的input元素的类型,HTML 5中新增了很多input元素的类型,现列举如下:emailemail类型表示必须输入E-mail地址的文本输入框。urlurl类型表示必须输入URL地址的文本输入框。numbernumber类型表示必须输入数值的文本输入框。rangerange类型表示必须输入一定范围内数字值的文本输入框。Date PickersHTML 5拥有多个可供选取日期和时间的新型输入文本框:date选取日、月、年m
20、onth选取月、年week选取周和年time选取时间(小时和分钟)datetime选取时间、日、月、年(UTC时间)datetime-local选取时间、日、月、年(本地时间),2.7 HTML5 废除的元素,由于各种原因,在HTML 5中废除了很多元素,简单介绍如下。1.能使用CSS替代的元素对于basefont、big、center、font、s、strike、tt、u这些元素,由于它们的功能都是纯粹为画面展示服务的,而HTML 5中提倡把画面展示性功能放在CSS样式表中统一编辑,所以将这些元素废除了,并使用编辑CSS、添加CSS样式表的方式进行替代。其中font元素允许由“所见即所得”的
21、编辑器来插入,s元素、strike元素可以由del元素替代,tt元素可以由CSS的font-family属性替代。2.不再使用frame框架对于frameset元素、frame元素与noframes元素,由于frame框架对网页可用性存在负面影响,在HTML 5中已不支持frame框架,只支持iframe框架,或者用服务器方创建的由多个页面组成的复合页面的形式,同时将以上这三个元素废除。3.只有部分浏览器支持的元素对于applet、bgsound、blink、marquee等元素,由于只有部分浏览器支持这些元素,特别是bgsound元素以及marquee元素,只被Internet Explor
22、er所支持,所以在HTML 5中被废除。其中applet元素可由embed元素或object元素替代,bgsound元素可由audio元素替代,marquee可以由JavaScript编程的方式所替代。,2.7 HTML5 废除的元素,4.其他被废除的元素其他被废除元素还有:废除rb元素,使用ruby元素替代废除acronym元素,使用abbr元素替代废除dir元素,使用ul元素替代废除isindex元素,使用form元素与input元素相结合的方式替代废除listing元素,使用pre元素替代废除xmp元素,使用code元素替代废除nextid元素,使用GUIDS替代废除plaintext元
23、素,使用“text/plian”MIME类型替代,2.8 HTML5 新增的属性,1.表单相关的属性新增的与表单相关的元素如下:可以对input(type=text)、select、textarea与button元素指定autofocus属性。它以指定属性的方式让元素在画面打开时自动获得焦点。可以对input元素(type=text)与textarea元素指定placeholder属性,它会对用户的输入进行提示,提示用户可以输入的内容。可以对input、output、select、textarea、button与fieldset指定form属性,声明它属于哪个表单,然后将其放置在页面上任何位置
24、,而不是表单之内。可以对input元素(type=text)与textarea元素指定required属性。该属性表示在用户提交的时候进行检查,检查该元素内一定要有输入内容。为input元素增加了几个新的属性:autocomplete、min、max、multiple、pattern与step。同时还有一个新的list元素与datalist元素配合使用。datalist元素与autocomlete属性配合使用。multiple属性允许在上传文件时一次上传多个文件。为input元素与button元素增加了新属性formaction、formenctype、formmethod、formnoval
25、idate与formtarget,他们可以重载form元素的action、enctype、method、novalidate与target属性。为fieldset元素增加了disabled属性,可以把它的子元素设为disabled(无效)状态。为input元素、button元素、form元素增加了novalidate属性,该属性可以取消提交时进行的有关检查,表单可以被无条件地提交。2.链接相关属性新增的与链接相关的属性如下:为a与area元素增加了media属性,该属性规定目标URL是为什么类型的媒介/设备进行优化的,只能在href属性存在时使用。,2.8 HTML5 新增的属性,为area元
26、素增加了hreflang属性与rel属性,以保持与a元素、link元素的一致。为link元素增加了新属性sizes。该属性可以与icon元素结合使用(通过rel属性),该属性指定关联图标(icon元素)的大小。为base元素增加了target属性,主要目的是保持与a元素的一致性。3.其他属性除了上面介绍的与表单和链接相关的属性外,HTML 5还增加了下面的属性:为ol元素增加属性reversed,它指定列表倒序显示。为meta元素增加charset属性,因为这个属性已经被广泛支持了,而且为文档的字符编码的指定提供了一种比较良好的方式。为menu元素增加了两个新的属性type与label。lab
27、el属性为菜单定义一个可见的标注,type属性让菜单可以以上下文菜单、工具条与列表菜单的三种形式出现。为style元素增加scoped属性,用来规定样式的作用范围,譬如只对页面上某个树起作用。为script元素增加async属性,它定义脚本是否异步执行。为html元素增加属性manifest,开发离线Web应用程序时它与API结合使用,定义一个 URL,在这个URL上描述文档的缓存信息。为iframe元素增加三个属性sandbox、seamless与srcdoc,用来提高页面安全性,防止不信任的Web页面执行某些操作。,2.9 HTML5 废除的属性,HTML4中的一些属性在HTML5中不再被
28、使用,而是采用其他属性或其他方案进行替代,具体如下表。,2.9 HTML5 废除的属性,2.10 HTML5全局属性,在HTML 5中,新增了一个“全局属性”的概念。所谓全局属性,是指可以对任何元素都使用的属性,本节将详细介绍几种常用的全局属性。1、contentEditable属性contentEditable是由微软开发、被其他浏览器反编译并投入应用的一个全局属性。该属性的主要功能是允许用户编辑元素中的内容,所以该元素必须是可以获得鼠标焦点的元素,而且在点击鼠标后要向用户提供一个插入符号,提示用户该元素中的内容允许编辑。contentEditable属性是一个布尔值属性,可以被指定为tru
29、e或false。除此之外,该属性还有个隐藏的inherit(继承)状态,属性为true时,元素被指定为允许编辑;属性为false时,元素被指定为不允许编辑;未指定true或false时,则由inherit状态来决定,如果元素的父元素是可编辑的,则该元素就是可编辑的。另外,除了contentEditable属性外,元素还具有一个isContentEditable属性,当元素可编辑时,该属性为true;当元素不可编辑时,该属性为false。代码清单2-2中给出了一个使用contentEditable属性的示例,当列表元素被加上contentEditable属性后,该元素就变成可编辑的了,读者可自行
30、在浏览器中对该示例进行试验。代码清单2-2 contentEditable属性示例,2.10 HTML5全局属性,conentEditalbe属性示例可编辑列表列表元素1列表元素2列表元素3,2.10 HTML5全局属性,在编辑完元素中的内容后,如果想要保存其中内容,只能把该元素的innerHTML发送到服务器端进行保存,因为改变元素内容后该元素的innerHTML内容也会随之改变,目前还没有特别的API来保存编辑后元素中的内容。最后,在这里列举一下支持contentEditable属性的元素:defaults、A、ABBR、ACRONYM、ADDRESS、B、BDO、BIG、BLOCKQUO
31、TE、BODY、BUTTON、CENTER、CITE、CODE、CUSTOM、DD、DEL、DFN、DIR、DIV、DL、DT、EM、FIELDSET、FONT、FORM、hn、I、INPUT type=button、INPUT type=password、INPUT type=radio、INPUT type=reset、INPUT type=submit、INPUT type=text、INS、ISINDEX、KBD、LABEL。2、designMode属性designMode属性用来指定整个页面是否可编辑,当页面可编辑时,页面中任何支持上文所述的contentEditable属性的元素都
32、变成了可编辑状态。designMode属性只能在JavaScript脚本里被编辑修改。该属性有两个值“on”与“off”。属性被指定为“on”时,页面可编辑;被指定为“off”时,页面不可编辑。使用JavaScript脚本来指定designMode属性的方法如下所示:document.designMode=on针对designMode属性,各浏览器的支持情况也各不相同:IE8:出于安全考虑,不允许使用designMode属性让页面进入编辑状态。IE9:允许使用designMode属性让页面进入编辑状态。Chrome 3和Safari:使用内嵌frame的方式,该内嵌frame是可编辑的。Fir
33、efox和Opera:允许使用designMode属性让页面进入编辑状态。,2.10 HTML5全局属性,3、hidden属性在HTML 5中,所有的元素都允许使用一个hidden属性。该属性类似于input元素中的hidden元素,功能是通知浏览器不渲染该元素,使该元素处于不可见状态。但是元素中的内容还是浏览器创建的,也就是说页面装载后允许使用JavaScript脚本将该属性取消,取消后该元素变为可见状态,同时元素中的内容也即时显示出来。Hidden属性是一个布尔值的属性,当设为true时,元素处于不可见状态;当设为false时,元素处于可见状态。4、spellcheck属性spellche
34、ck属性是HTML 5针对input元素(type=text)与textarea这两个文本输入框提供的一个新属性,它的功能为对用户输入的文本内容进行拼写和语法检查。spellcheck属性是一个布尔值的属性,具有true或false两种值。但是它在书写时有一个特殊的地方,就是必须明确声明属性值为true或false,书写方法如下所示:需要注意的是,如果元素的readOnly属性或disabled属性设为true,则不执行拼写检查。,2.10 HTML5全局属性,目前除了IE之外,Firefox、Chrome、Safari、Opera等浏览器都对该属性提供了支持。下图Opera浏览器中spell
35、check属性的表现形式。(上面写的支持的几种浏览器我的测试了一下,只有Opera浏览器可以,其它的都不行,不知道什么原因),2.10 HTML5全局属性,5、tabindex属性tabindex是开发中的一个基本概念,当不断敲击Tab键让窗口或页面中的控件获得焦点,对窗口或页面中的所有控件进行遍历的时候,每一个控件的tabindex表示该控件是第几个被访问到的。过去这个属性在编辑网页时是非常有用的,但如今控件的遍历顺序是由元素在页面上所处的位置决定的,所以就不再需要了。但是tabindex还有另外一个作用,在默认情况下,只有链接元素与表单元素可以通过按键获得焦点。如果对其他元素使用tabindex属性后,也能让该元素获得焦点,那么当脚本中执行focus()语句的时候,就可以让该元素获得焦点了。但这样做会产生一个副作用:该元素也可以通过按Tab键获得焦点,而这有时可能不是开发者想要的结果。把元素的tabindex值设为负数(通常为-1)后就解决这个问题了。tabindex的值为负数后,仍然可以通过编程的方式让元素获得焦点,但按下Tab键时该元素就不能获得焦点了,这在复杂的页面中或复杂的Web应用程序中是十分有用的。在HTML 4中,-1是一个无用的属性值,但到了HTML 5中,通过巧妙地运用让该属性值得到了极大的应用。,
链接地址:https://www.31ppt.com/p-6507681.html