input属性中html5新增哪些属性( ),html form表单属性
其实input属性中html5新增哪些属性( )的问题并不复杂,但是又很多的朋友都不太了解html form表单属性,因此呢,今天小编就来为大家分享input属性中html5新增哪些属性( )的一些知识,希望可以帮助到大家,下面我们一起来看看这个问题的分析吧!
HTML5中input元素新增加哪些type属性值它们有什么作用
在HTML5中,为input元素新增了以下一些type属性值,用来丰富文本框的类型。
color:用于指定颜色的控件。
date:用于输入日期的控件(年,月,日,不包括时间)。
datetime:基于 UTC时区的日期时间输入控件(时,分,秒及几分之一秒)。
datetime-local:用于输入日期时间控件,不包含时区。
email:用于编辑 e-mail的字段。
month:用于输入年月的控件,不带时区。
number:用于输入浮点数的控件。
range:用于输入不精确值控件。
search:用于输入搜索字符串的单行文本字段。换行会被从输入的值中自动移除。
tel:用于输入电话号码的控件。
time:用于输入不含时区的时间控件。
url:用于编辑URL的字段。。
week:用于输入一个由星期-年组成的日期,日期不包括时区。推荐你去一个教学网站秒秒学上把这些知识过一遍,夯实下基础。
HTML5 新增加了哪些表单元素
首先先说一个html5中表单新增的一个功能,在我们之前的html中,表单元素必须放在form元素所包含的里面,在html5中,可以把他们写在页面上的任何一个地方,然后给该元素增加一个form属性,form属性的值为form表单的id,如下:
[html]view plaincopy
<formmethod="get"id="test">
<inputtype="text"name="name"/>
<inputtype="password"name="password"/>
<inputtype="submit"value="提交">
</form>
<inputtype="text"name="confirm"form="test">
在form元素里面的表单元素可以不用添加form属性,如果你想利用form获取所有表单元素的值,那么在form元素外面的表单元素就必须添加form属性,input、select、textarea等元素都满足该功能。
接下来开始介绍html5新增的表单元素,所有例子均用谷歌浏览器展示。
新增表单元素
email:提交表单的时候验证输入值是否满足email的格式
<input type="email" name="email"/>
url:提交表单的时候验证输入值是否满足url的格式
<input type="url" name="url"/>
number:根据你的设置提供选择数字的功能,其中min为最小值,max为最大值,value为默认值,step为点击箭头时数字的变化量,max、min、step、value均可不写,目前某些浏览器还不支持。
<input type="number" name="number" min=2 max=100 step=5 value="15"/>
range:会以一个滑块的形式表现包含一定范围内数字值的输入域,max为最大值,min为最小值,value为默认值,如果没有设置max和min,默认值是1-100
<input type="range" name="range" min=20 max=200 value="60"/>
日期和时间类型:
date:选取日、月、年
<input type="date" name="date"/>
month:选取月、年
<input type="month" name="month"/>
week:选取周、年
<input type="week" name="week"/>
time:选取小时、分钟
<input type="time" name="time"/>
datetime:选取时间、日、月、年(UTC时间)(我这里浏览器显示不出效果)
<input type="datetime" name="datetime"/>
datetime-local:选取时间、日、月、年(本地时间)
<input type="datetime-local" name="datetime-local"/>
search:用于搜索域,若加上result="s"属性,则会在搜索框前面加一个搜索图标(我这里浏览器显示不出效果)
<input type="search" name="search" result="s"/>
tel:验证输入的是否是电话号码的格式(我这里浏览器显示不出效果)
<input type="tel" name="tel"/>
color:color类型会提供颜色拾取器,供用户选择颜色,并将用户选择的颜色填充到此元素中
<input type="color" name="color"/>
新增input属性(部分容易理解的就不进行代码演示了),后面为支持该属性的元素
autofocus:在打开页面时使元素自动获取焦点//input,button,select,textarea
placeholder:在用户输入时进行提示// input,textarea
form:这篇文章的开头就有这个属性,它用于表明元素属于哪个表单,无论元素的位置在哪里,所属表单都能获取该元素的值//input,output,button,select,textarea,fieldset
required:表明该元素是必填项,当提交表单的时候会自动验证该元素的内容是否不为空//input,textarea
max/min/step:限制值的输入范围,以及值的变化程度。上面的新增number元素有介绍。//input
autocomplete:使form元素或者input元素拥有自动完成功能,既记录用户之前输入的值,关闭为off,默认为on。//form,input
表单重写属性://input
formaction:重写表单的action属性
formenctype:重写表单的enctype属性。
enctype属性管理的是表单的MIME编码,MIME就是一种电子邮件传输的互联网标准,表明传递的信息类型和编码,共有三个值可选:
1,application/x-www-form-urlencoded(默认),设置表单传输的编码。
2,multipart/form-data,指定传输数据的特殊类型,主要就是上传的非文本内容,比如文件、图片。
3,text/plain,纯文本传输。
formmethod:重写表单的method属性
formnovalidate:重写表单的novalidate属性
formtarget:重写表单的target属性。
比如:
[html]view plaincopy<formaction="test.html"method="get"autocomplete="on">
姓名:<inputtype="text"name="name"/><br/>
密码:<inputtype="password"name="pwd"/><br/>
<inputtype="submit"formnovalidate="true"value="提交未经验证"/>
</form>
multiple:规定输入字段可选择多个值//input,select
list:list属性的值为datalist元素的id,datalist元素类似于选择框,在文本框获得焦点的时候以提示输入的方式显示。如下:
[html]view plaincopy姓名:<inputtype="text"name="name"list="name"/>
<datalistid="name">
<optionvalue="zhangsan">张三</option>
<optionvalue="lisi">李四</option>
<optionvalue-"wanger">王二</option>
</datalist>
pattern:验证input输入域的格式,即正则表达式。
<input type="text" name="name" pattern="[A-z0-9]{8}"/>
跟HTML相比,HTML5新增了哪些新特性
1.新的Doctype
尽管使用<!DOCTYPE html>,即使浏览器不懂这句话也会按照标准模式去渲染
2. Figure元素
用<figure>和<figcaption>来语义化地表示带标题的图片
<figure>
<img src=”path/to/image” alt=”About image”/>
<figcaption>
<p>This is an image of something interesting.</p>
</figcaption>
</figure>
3.重新定义的<small>
<small>已经被重新定义了,现在被用来表示小的排版,如网站底部的版权声明
4.去掉link和script标签里面的type属性
5.加/不加括号
HTML5没有严格的要求属性必须加引号,闭合不闭合,但是建议加上引号和闭合标签
6.让你的内容可编辑,只需要加一个contenteditable属性
7. Email Inputs
如果我们给Input的type设置为email,浏览器就会验证这个输入是否是email类型,当然不能只依赖前端的校验,后端也得有相应的校验
8. Placeholders
这个input属性的意义就是不必通过javascript来做placeholder的效果了
9. Local Storage
使用Local Storage可以永久存储大的数据片段在客户端(除非主动删除),目前大部分浏览器已经支持,在使用之前可以检测一下window.localStorage是否存在
10.语义化的header和footer
11.更多的HTML5表单特性
12. IE和HTML5
默认的,HTML5新元素被以inline的方式渲染,不过可以通过下面这种方式让
其以block方式渲染
header, footer, article, section, nav, menu, hgroup{
display: block;
}
不幸的是IE会忽略这些样式,可以像下面这样fix:
document.createElement(”article”);
document.createElement(”footer”);
document.createElement(”header”);
document.createElement(”hgroup”);
document.createElement(”nav”);
document.createElement(”menu”);
13. hgroup
一般在header里面用来将一组标题组合在一起,如
<header>
<hgroup>
<h1> Recall Fan Page</h1>
<h2> Only for people who want the memory of a lifetime.</h2>
</hgroup>
</header>
14. Required属性
required属性定义了一个input是否是必须的,你可以像下面这样声明
<input type=”text” name=”someInput” required>
或者
<input type=”text” name=”someInput” required=”required”>
15. Autofocus属性
正如它的词义,就是聚焦到输入框里面
<input type=”text” name=”someInput” placeholder=”Douglas Quaid” required autofocus>
16. Audio支持
HTML5提供了<audio>标签,你不需要再按照第三方插件来渲染音频,大多数现代浏览器提供了对于HTML5 Audio的支持,不过目前仍旧需要提供一些兼容处理,如
<audio autoplay=”autoplay” controls=”controls”>
<source src=”file.ogg”/><!–FF–>
<source src=”file.mp3″/><!–Webkit–>
<a href=”file.mp3″>Download this file.</a>
</audio>
17. Video支持
和Audio很像,<video>标签提供了对于video的支持,由于HTML5文档并没有给video指定一个特定的编码,所以浏览器去决定要支持哪些编码,导致了很多不一致。Safari和IE支持H.264编码的格式,Firefox和Opera支持Theora和Vorbis编码的格式,当使用HTML5 video的时候,你必须都提供:
<video controls preload>
<source src=”cohagenPhoneCall.ogv” type=”video/ogg; codecs=’vorbis, theora’”/>
<source src=”cohagenPhoneCall.mp4″ type=”video/mp4;’codecs=’avc1.42E01E, mp4a.40.2′”/>
<p> Your browser is old.<a href=”cohagenPhoneCall.mp4″>Download this video instead.</a></p>
</video>
18.预加载视频
preload属性就像它的字面意思那么简单,你需要决定是否需要在页面加载的时候去预加载视频
<video preload>
19.显示视频控制
<video preload controls>
20.正则表达式
由于pattern属性,我们可以在你的markup里面直接使用正则表达式了
<form action=”" method=”post”>
<label for=”username”>Create a Username:</label>
<input type=”text” name=”username” id=”username” placeholder=”4<> 10″ pattern=”[A-Za-z]{4,10}” autofocus required>
<button type=”submit”>Go</button>
</form>
21.检测属性支持
除了Modernizr之外我们还可以通过javascript简单地检测一些属性是否支持,如:
<script>
if(!’pattern’ in document.createElement(’input’)){
// do client/server side validation
}
</script>
22. Mark元素
把<mark>元素看做是高亮的作用,当我选择一段文字的时候,javascript对于HTML的markup效果应该是这样的:
<h3> Search Results</h3>
<p> They were interrupted, just after Quato said,<mark>”Open your Mind”</mark>.</p>
23.什么时候用<div>
HTML5已经引入了这么多元素,那么div我们还要用吗?div你可以在没有更好的元素的时候去用。
24.想立即使用HTML5?
不要等2022了,现在就可以使用了,just do it.
25.哪些不是HTML5
1)SVG
2)CSS3
3)Geolocation
4)Client Storage
5)Web Sockets
26. Data属性
<div id=”myDiv” data-custom-attr=”My Value”> Bla Bla</div>
CSS中使用:
<style>
h1:hover:after{
content: attr(data-hover-response);
color: black;
position: absolute;
left: 0;
}
</style>
<h1 data-hover-response=”I Said Don’t Touch Me!”> Don’t Touch Me</h1>
27. Output元素
<output>元素用来显示计算结果,也有一个和label一样的for属性
28.用Range Input来创建滑块
HTML5引用的range类型可以创建滑块,它接受min, max, step和value属性
可以使用css的:before和:after来显示min和max的值
<input type=”range” name=”range” min=”0″ max=”10″ step=”1″ value=”">
input[type=range]:before{ content: attr(min); padding-right: 5px;
}
input[type=range]:after{ content: attr(max); padding-left: 5px;}
关于本次input属性中html5新增哪些属性( )和html form表单属性的问题分享到这里就结束了,如果解决了您的问题,我们非常高兴。