Html5 学习系列(三)增强型表单标签

简介: 引言      在之前的HTML表单标签中,对于一些功能支持的不够好,比如:文本框提示信息(之前只能通过js和input的事件结合处理)、表单校验、日期选择控件、颜色选择控件、范围控件、进度条、标签跨表单等功能。

引言

     在之前的HTML表单标签中,对于一些功能支持的不够好,比如:文本框提示信息(之前只能通过js和input的事件结合处理)、表单校验、日期选择控件、颜色选择控件、范围控件、进度条、标签跨表单等功能。当然这些东西我们都可以直接通过js和dom元素配合实现这些通用的功能。这些功能或者是标签都已经大量的使用在了现代的Web应用中,而这些公共性的东西在早期的HTML标准没有直接的标准支持,而在HTML5中,新标准直接把这些常用的基本的功能直接加入的新的表单标签中,真正把表单功能异常的强大,那就跟我走一下HTML5智能表单之旅吧!

     由于最新版本的Opera浏览器对新型表单支持的最为完美,所以建议本blog或者以下示例请在Opera浏览器上打开.

HTML5新增加表单标签

     新的标准中添加了很多输入型控件,比如:Number、URL、Email、Range、Color等。而他们都是以 input标签的type属性出场,那下面我一一简单介绍一下[以下所有的例子请用Opera浏览器浏览] 

1)只能输入数字的Number类型input标签

Html代码为:<input type="number" name="demoNumber" min="1" max="100" step="2"/>

运行效果:

:此标签其实就是普通的input标签,只不过是type类型指向了number,标识当前标签接受数字类型输入.另外添加了四个属性.

name:属性大家很熟悉了用来标识表单提交时的key值

min:是表单标签新增加的属性标识当前输入框输入的最小值

max:那就是最大值了

step:是步长的意思,也就是在点击增大或者减小的时候的增加减少的步长

小结:min,max,step是表单标签中添加的新的属性。另外就是type又增加了一个新的number类型,接受数字输入。而之前我们要做到这样的效果只能通过js在失去焦点时候判断,控制起来不那么方便,现在一切都那么简单简洁。 

2)新型Email类型input标签

Html代码:<input type="email" name="email" placeholder="请输入注册邮箱" />

运行效果:

:在上面HTML代码中,相对于之前的标签,不同点:type="email"表示当前input标签接受一个邮箱的输入。另外就是:placeholder="请输入注册邮箱"   这个属性的功能,相信你看到此时的效果的时候你会感到非常想兴奋,而在之前实现此提示信息,需要监听一下文本框的blur事件,然后判断是否为空,为空再去给文本框赋值一个灰色的字体提示信息,而现在只需要一个简单属性指定就可以了,浏览器都帮我们实现了。

小结:当表单在提交前,此文本框会自动校验是否符合邮箱的正则表达式,另外placeholder属性带来的提示信息功能太强大了。

3)新型Url类型input标签

这里不再赘述了,跟Email类型input标签类似。只看一效果吧:

Html代码:<input type="url" placeholder="请输入网址" name="url" />

运行效果:

4)新型Tel类型input标签

Html代码:<input type="tel" placeholder="输入电话" name="phone"/>

运行效果:

5)新型range类型input标签

Html代码:<input type="range" min="0" max="50" step="5" name="rangedemo" value="0" />

运行效果:

     此类型标签的加入,输入范围内的数据变得非常简单容易,而且非常标准,用户输入可感知体验非常好。另外此标签可以跟表单新增加的Output标签一块使用,达到一个联动的效果。看demo源码:

<form action="" method="POST" id="form1">
        <input type="range" min="0" max="50" step="5" name="rangedemo" value="0" />
        <output onforminput="value=rangedemo.value">0</output>
 </form>

运行效果:

6)新的日期、时间、月份、星期input标签

相信你如果做过相关的Web项目开发,肯定会遇到相关的js日期控件。而一系列版本问题,使用不方便等问题将一去不复返,因为…看下面的标签吧:

Html代码:<input type="date" name="datedemo" />

运行效果:

还有其他的type:month(月)  、time、week、datetime-local、datetime。那赶紧实验一下吧。

7)颜色选择input标签

颜色选择器实现起来还是有点困难的,而现在一切都变得那么简单。且看代码:

Html代码:<input type="color"/>

运行效果:

8)input标签自动完成功能

如果您有一定的开发经验的话,肯定做过相关的自动完成或者输入提示功能。那这将不再那么复杂,简单几个标签就自动实现此功能,请看如下demo:

<input type="text" autocomplete="on" name="demoAutoComplete" list="autoNames" />
<datalist id="autoNames">
       <option  value="飞龙天惊" ></option>
       <option  value="厚德IT" ></option>
       <option  value="Flydragon" ></option>
</datalist>

执行结果:

HTML5表单新增属性

Input标签新增加的特有属性

  • 1)autofocus属性

              demo:<input type="text" autofocus="autofocus"/>  此属性可以设置当前页面中input标签加载完毕后获得焦点。

  • 2)max,min,step这些上面都介绍过了,都是跟数字相关。
  • 3)placeholder:提示信息属性,上面有demo。
  • 4)multiple:用于文件上传控件,设置此属性后,允许上传多个文件。
  • 5)校验属性:设置了required 属性后预示着当前文本框在提交前必须有数据输入,而这一切都是由浏览器自动完成。

             这跟使用Jq Validate的时候一样的爽。而且还添加了:pattern正则表达式的校验。

             demo:input type="text" autofocus="autofocus" required pattern="\d+" />

  • 6)另外一个比较大的改进就是增加了form属性,也就是说,任何一个标签都可以指定它所属于一个表单,而不是必须在<form></form>进行包裹了。
  • 且看demo:<input type="text" form="demoForm" name="demo"/>

Form表单标签新增加属性

  • 1)novalidate 属性规定在提交表单时不应该验证 form 或 input 域

           demo:<form action="" method="POST" novalidate="true"></form>

  • 2)autocomplete 属性规定 form 或 input 域应该拥有自动完成功能

综合性实例

    <fieldset>
        <legend>只能表单演示:请用最新Opera 浏览器</legend>
        <form action="" method="POST" id="form1">
            <input type="text" autofocus="autofocus" required pattern="\d+" name="auto" placeholder="必填项测试" />
            <input type="number" name="demoNumber" min="1" max="100" step="2" />
            <input type="email" placeholder="请输入邮箱" name="mail" />
            <input type="url" name="url" placeholder="输入正确的网址" />
            <br />
            日期:<input type="datetime" name="time" />
            颜色:
            <input type="color" name="color" /><br />
            <br />
            <input type="range" min="0" max="50" step="5" name="rangedemo" value="0" />
            <output onforminput="value=rangedemo.value">0</output>
            <br />
            <input type="submit" value="提交表单" />
        </form>
        表单外的input标签:
        <input type="text" form="form1" name="demo" />
    </fieldset>

 执行结果: 

由于部分属性不能正常提交到博客园后台,上一张图片加源码:

图片:

 

实际运行情况:

只能表单演示:请用最新Opera 浏览器
日期: 颜色:

0

表单外的input标签:

总结

       在新版本的表单中的确添加了很多令人兴奋的功能。其实进步不是特别大,只不过是把之前的常用的功能,加入到了标准中来定义,然后浏览器帮我们实现了很多我们原先需要自己用js实现的一些功能罢了。但是对于开发者来说,这的确是很不错的一件事情。



目录
相关文章
|
2月前
|
移动开发 搜索推荐 UED
HTML5的新语义化标签
HTML5引入的这些新语义化标签,通过明确标识内容的结构和意义,使得网页结构更加清晰,易于理解和维护。使用这些标签不仅提升了网页的可读性和可访问性,还增强了搜索引擎和辅助技术对网页内容的解析能力。在实际开发中,合理使用这些语义化标签,能够显著提升网页的质量和用户体验。
97 49
|
2月前
|
移动开发 HTML5
HTML5 表单属性3
`&lt;input&gt;` 标签的 `formaction`、`formenctype` 和 `formmethod` 属性分别用于指定表单提交的 URL 地址、数据编码类型和提交方法,这些属性可覆盖 `&lt;form&gt;` 标签中的相应属性,并且主要适用于 `type=&quot;submit&quot;` 和 `type=&quot;image&quot;` 的输入类型。
|
1月前
|
移动开发 JavaScript 前端开发
HTML5 表单属性7
`pattern` 属性使用正则表达式验证 `&lt;input&gt;` 元素的值,适用于 `text`, `search`, `url`, `tel`, `email`, 和 `password` 类型。
|
1月前
|
移动开发 UED HTML5
HTML5 表单属性6
`min`、`max` 和 `step` 属性用于限制 `&lt;input&gt;` 标签中的数值或日期范围。例如,可以设置日期选择器的最早和最晚日期,或限制数字输入框的值范围。`multiple` 属性允许在 `&lt;input&gt;` 中选择多个值,适用于邮箱和文件类型。这些属性增强了表单控件的功能性和用户体验。
|
1月前
|
移动开发 HTML5
HTML5 表单属性5
`height` 和 `width` 属性用于 `&lt;input&gt;` 标签中的 `image` 类型,定义图像的高度和宽度。
|
2月前
|
移动开发 HTML5
HTML5 表单属性4
`formnovalidate` 属性是一个布尔属性,用于 `&lt;input&gt;` 元素,指示该输入在表单提交时不需验证,可覆盖 `&lt;form&gt;` 元素的 `novalidate` 属性,常与 `type=&quot;submit&quot;` 一起使用。示例中展示了如何通过两个提交按钮(一个使用验证,另一个不使用)实现不同的表单提交方式。
|
2月前
|
移动开发 JavaScript 前端开发
HTML5 表单属性2
`novalidate` 是 HTML `&lt;form&gt;` 元素的布尔属性,用于禁用浏览器的默认表单验证功能。当此属性存在时,浏览器不会检查表单字段是否符合预设的验证规则,允许开发者通过 JavaScript 等手段自定义验证逻辑。
|
1月前
|
移动开发 数据安全/隐私保护 HTML5
HTML5 表单属性8
`required`属性确保表单提交前输入框不能为空,适用于多种类型的 `&lt;input&gt;` 标签,如文本、邮箱、密码等。`step`属性则用于指定输入域中合法数值的间隔,常与`max`和`min`属性配合使用,适用于数字、日期等类型。例如,设置`&lt;input type=&quot;number&quot; step=&quot;3&quot;&gt;`可使输入值以3为单位递增或递减。
|
2月前
|
存储 移动开发 前端开发
高效的 HTML 与 CSS 编写技巧,涵盖语义化标签、文档结构优化、CSS 预处理、模块化设计、选择器优化、CSS 变量、媒体查询等内容
本文深入探讨了高效的 HTML 与 CSS 编写技巧,涵盖语义化标签、文档结构优化、CSS 预处理、模块化设计、选择器优化、CSS 变量、媒体查询等内容,旨在提升开发效率、网站性能和用户体验。
50 5
|
2月前
|
移动开发 UED HTML5
HTML5 表单属性1
HTML5为&lt;form&gt;和&lt;input&gt;标签引入了多个新属性,增强了表单的功能性和用户体验。其中,&lt;form&gt;新增了autocomplete和novalidate属性;&lt;input&gt;则增加了如autofocus、formaction、placeholder等13个新属性,支持更精细的表单控制和数据验证。例如,autocomplete属性允许表单或输入字段提供自动完成功能,提高用户填写效率。