HTMLCSS学习笔记

dirname 属性

input 和 textarea 元素有了一个新元素 dirname,用于用户所设置的提交的方向性的控制 (译注,即书写的方向性,ltr 或 rtl)。

<form action="addcomment.cgi" method=post>
 <p><label>Comment: <input type=text  required></label></p>
 <p><button >Post Comment</button></p>
</form>

用户提交的时候,浏览器会接收到 3 个参数,分别是:comment, comment.dir 和 mode,类似下面这样:comment=Hello&comment.dir=ltr&mode=add

如果是阿拉伯文的浏览器,输入的是阿拉伯文مرحبًا的话,那传回的参数就应该是这样的:

comment=%D9%85%D8%B1%D8%AD%D8%A8%D9%8B%D8%A7&comment.dir=rtl&mode=add

textarea 下的 maxlength 和 wrap 属性

textarea 新增的 maxlength 和 input 的 maxlength 是一样的,都是限制最大长度的。

新增的 wrap 属性为枚举值(soft/hard),意思分别是:

  • hard:自动硬回车换行,换行标记一同被传送到服务器中去,必须与 cols 同时使用才能判断多少字符换行;
  • soft:自动软回车换行,换行标记不会传送到服务器中去

form 下的 novalidate 属性

新增属性 novalidate 的意思是允许 form 表单不验证即可提交(不用管 form 里的元素是否有验证条件,例如 required, min, max 等)。

例子代码:

<form action="demo_form.asp" novalidate="novalidate">
  E-mail: <input type="email"  />
  <input type="submit" />
</form>

还有一种用法是,同一个 form 里有多个 submit 按钮,可以针对某个按钮设置 formnovalidate 属性来忽略验证,例如:

<form action="editor.cgi" method="post">
 <p><label>Name: <input required name=fn></label></p>
 <p><label>Essay: <textarea required name=essay></textarea></label></p>
 <p><input type=submit ></p>
 <p><input type=submit formnovalidate ></p>
 <p><input type=submit formnovalidate ></p>
</form>

该 form 只有在点击 Submit essay 按钮的时候才验证表单,另外 2 个按钮不验证。

input 与 button 下的新属性

input 和 button 元素新增加了几个新属性(formaction, formenctype, formmethod, formnovalidate 和 formtarget),如果这些设置这些属性的话,那所对应的 form 属性值将被覆盖,即 input 或 button 所属的 form 元素的 action, enctype, method, novalidate 和 target 属性的值将被覆盖。

例子代码:

<form action="demo_form.asp" method="get">
First name: <input type="text"  /><br />
Last name: <input type="text"  /><br />
<input type="submit" value="Submit" />
<input type="submit" formmethod="post" formaction="demo_post.asp" value="Submit" />
</form>
<form action="demo_form.asp" method="get">
  First name: <input type="text"  /><br />
  Last name: <input type="text"  /><br />
  <input type="submit" value="Submit" /><br />
  <input type="submit" formaction="demo_admin.asp" value="Submit as admin" />
</form>
<form action="demo_form.asp" method="get">
  First name: <input type="text"  /><br />
  Last name: <input type="text"  /><br />
<input type="submit" value="Submit" />
<input type="submit" formtarget="_blank" value="Submit" />
</form>

menu 下的 type 和 label 属性

menu 元素有了两个新属性:type 和 label。它们允许元素转化成典型用户界面里的菜单,并结合全局 contextmenu 属性提供上下文菜单。

style 下的 scoped 属性

style 元素有了一个新的 scoped 属性,用来启用限定作用范围的样式表。在一个这样的 style 元素里的样式规则只应用到当前 style 元素的父元素根下的子树,即兄弟树。

<!-- 这个article正常使用head里声明的style -->
 <article>
    <h1>Blah Title Blah</h1>
    <p>Blah blah article blah blah.</p>
</article>
<article>
    <!-- 这里声明的style只能让该article以及子元素使用 -->
    <style scoped>
        h1 { color: hotpink; }
        article { border: solid 1px hotpink; }
    </style>
    <h1>Blah Title Blah</h1>
    <p>Blah blah article blah blah.</p>
</article>

script 下的 async 属性

async 属性可以让 script 加载的脚步异步执行(即必须是 src 引用文件的形式才可以用),例如:

<script type="text/javascript" src="demo_async.js" async="async"></script>

有多种执行外部脚本的方法:

  1. 如果 async="async":脚本相对于页面的其余部分异步执行(当页面继续进行解析时,脚本将被执行)
  2. 如果不使用 async 且 defer="defer":脚本将在页面完成解析时执行
  3. 如果既不使用 async 也不使用 defer:在浏览器继续解析页面之前,立即读取并执行脚本

html 下的 manifest 属性

html 元素有了一个新属性 manifest,指向一个用于结合离线 Web 应用 API 的应用程序缓存清单。

首先,需要先创建 manifest 文件

CACHE MANIFEST
#This is a comment
CACHE #需要缓存的文件
index.html
style.css
NETWORK: #不需要缓存的文件
search.php
login.php
FALLBACK: #资源不可用的情况下,重定向的地址
/api offline.html

然后加该文的地址加到 html 属性里:

<html manifest="/offline.manifest">

例子:http://www.mangguo.org/create-offline-html5-web-apps-in-5-easy-steps/

link 下的 sizes 属性

link 元素有了一个新的属性 sizes。可以结合 icon 的关系 (通过设置 rel 属性,可被用于如网站图示) 一起使用来表明被引用图标的大小。因此允许了不同的尺寸的图标。

例子代码:

<link rel="icon" href="demo_icon.gif" type="image/gif" sizes="16x16" />

ol 下的 reversed 属性

ol 元素有了一个新属性 reversed。当其存在时,代表列表中的顺序为降序。

iframe 下的 sanddbox, seamless 和 srcdoc 属性

iframe 元素有了三个新属性分别是 sandbox, seamless, 和 srcdoc,用以允许沙箱内容,例如,博客评论。

例子代码:

<iframe sandbox src="http://usercontent.example.net/getusercontent.cgi?id=12193"></iframe>
<iframe sandbox="allow-same-origin allow-forms allow-scripts"
        src="http://maps.example.com/embedded.html"></iframe>

Seamless:

<nav><iframe seamless src="nav.include.html"></iframe></nav>

video 和 audio 的 play 属性

HTML5 也使得所有来自 HTML4 的事件处理属性(那些形如 onevent-name 的属性)变成全局属性,并为其定义的新的事件添加了几个新的事件处理属性。比如,媒体元素 (video 和 audio)API 所使用的 play 事件。