读书时间《JavaScript高级程序设计》七:表单
在HTML中表单是有<form>元素表示,在JS中表单对应的是HTMLFormElement类型。
表单自有的属性和方法:

获取表单
1. 通过ID document.getElementById
2. 通过 document.forms 获取表单集合 在通过索引值或者name值获取具体表单元素
提交表单
使用input 或者 button 可以定义提交按钮,将其type设置为 submit。
<input type="submit" value="提交" />
<button type="button">提交</button>
<input type="image" src="button.png" />
当表单中有提交按钮,在表单控件拥有焦点时,按下Enter键就可以提交表单(textarea例外)。并且在提交表单时会触发submit事件。
var form = document.getElementById('myForm');
form.addEventListener('submit', function(e){
    // 阻止提交
    e.preventDefault();
});
// 提交表示
form.submit();
重置表单
点击表单重置按钮时,表单会重置。设置input或者button的type为reset。
<input type="reset" value="重置" />
<button type="reset">重置</button>
重置表单会触发reset事件。
var form = document.getElementById('myForm');
form.addEventListener('reset', function(e){
    // 取消重置
    e.preventDefault();
});
// 重置表单
form.reset();
表单字段
每个表单都有elements属性,这个属性是表单中所有元素的集合。这个集合是个有序的列表,其中包含表单中所有的字段。可以通过每个字段在集合中的位置和name访问。
// 获取表单
var form = document.getElementById('myForm'); // 获取表单的第一个字段
var frist = form.elements[0]; // 获取名为username的字段
var username = form.elements['username'];
表单元素拥有一些共有的属性:

   表单元素共有的方法: 
window.onload = function(){
    // 第一个表单中的第一个元素获取焦点
    document.forms[0].elements[0].focus();
};
注:如果第一个表单元素是一个input元素并且type值为hidden, 或使用css的display和visibility隐藏了改元素,focus会导致错误。
文本框
单行文本框:input元素
多行文本框: textarea元素
<!-- 文本框能够显示25个字符 输入不超过50个字符 -->
<input type="text" size="25" maxlength="50" value="" />
<!-- 文本框显示 10行 30列(字符数列) -->
<textarea rows="10" cols="30"></textarea>
选择文本
<input type="text" value="呵呵,这是一个表情。">
window.onload = function() {
    var input = document.forms[0].elements[0];
    input.select();
    input.addEventListener('select', function() {
        // 选择了什么文本 - HTML5 API
        console.log( input.value.substring(input.selectionStart, input.selectionEnd) )
    });
};
function selectText(textbox, startIndex, stopIndex){
    if (textbox.setSelectionRange){
        textbox.setSelectionRange(startIndex, stopIndex);
    } else if (textbox.createTextRange){
        var range = textbox.createTextRange();
        range.collapse(true);
        range.moveStart("character", startIndex);
        range.moveEnd("character", stopIndex - startIndex);
        range.select();
    }
    textbox.focus();
}
。。。
读书时间《JavaScript高级程序设计》七:表单的更多相关文章
- 《JAVASCRIPT高级程序设计》表单基础知识和文本框脚本
		
在HTML中,表单是由<form>元素来表示,在javascript中,表单对应的是HTMLFormElement类型,它具有一些独有的属性和方法: 一.表单基础知识 1.取得表单的方式 ...
 - JavaScript高级程序设计之表单基础
		
A FORM <form id='form' action='http://a-response-url' method="post"> <!--maxlengt ...
 - js高级程序设计 笔记 --- 表单
		
一,基础知识 在html中,表单是form元素,而在js中,表单对应的是HTMLFormElement类型,继承自HTMLElement,其独特的属性和方法有(常见): action:接收请求的URL ...
 - 读书笔记-JavaScript高级程序设计(1)
		
1.组合继承 (JavaScript 中最常用的继承模式 ) (position: page168) (书中定义了两个变量名 SuperType SubType 乍一看 感觉不太能区分,我将改为 ...
 - javascript 高级程序设计 七
		
引言:好几天没有写随笔了,项目有点紧,恰好今天项目遇到了比较大阻塞,就只好来写一篇随笔来压压惊. 1.Date类型 创建一个新的Date:(除了new Date()外) var someDate = ...
 - 读书笔记 - javascript 高级程序设计 - 第二章 在Html中使用JavaScript
		
1 <script>的6个属性 async 立即下载当前script标签的外部脚本 但不能影响别的 charset 没用了 defer 文档显示之后再执行脚本,只对外部脚本有效 lan ...
 - 读书笔记 - javascript 高级程序设计 - 第一章 简介
		
第一章 简介 诞生时间 1995 最初用途 客服端验证 第一版标准 注意是标准 1997年 Ecma-262 一个完整的js实现由三部分组成 ECMAScript DOM 文档对象模型 BO ...
 - JavaScript高级程序设计(七):JavaScript中的in关键字
		
in 使用点一: 在js中,for--in用于遍历一个对象的属性,把对象的属性名和属性值都提出来. var obj = { "key1":"value1", & ...
 - 读书时间《JavaScript高级程序设计》一:基础篇
		
第一次看了<JavaScript高级程序设计>第二版,那时见到手上的书,第一感觉真是好厚的一本书啊.现在再次回顾一下,看的是<JavaScript高级程序设计>第三版,并记录一 ...
 - 《JavaScript高级程序设计》读书笔记--前言
		
起因 web编程过程使用javascript时感觉很吃力,效率很低.根本原因在于对javascript整个知识体系不熟,看来需要找些书脑补一下,同时欢迎众网友监督. 大神推荐书籍 看了博客大神们推荐的 ...
 
随机推荐
- struts2对action中的方法进行输入校验(2)
			
struts2输入校验流程: 1.类型转换器对请求參数运行类型转换,并把转换后的值赋给aciton中的属性 2.假设在运行类型转换的过程中出现异常,系统会将异常信息保存到ActionContext, ...
 - AccountManager使用教程
			
API解读 这个类给用户提供了集中注冊账号的接口.用户仅仅要输入一次账户password后,就能够訪问internet资源. 不同的在线服务用不同的方式管理用户,所以account manager 为 ...
 - Adaboost的几个人脸检测网站
			
[1]基础学习笔记之opencv(1):opencv中facedetect例子浅析 http://www.cnblogs.com/tornadomeet/archive/2012/03/22/2411 ...
 - hdu4280(最大流)
			
传送门:Island Transport 题意:有N个岛屿 M条无向路 每个路有一最大允许的客流量,求从最西的那个岛屿最多能运用多少乘客到最东的那个岛屿. 分析:无向图正反都加弧,权值一样,这题点多, ...
 - HTML中的div标签
			
在网页制作过程过中,能够把一些独立的逻辑部分划分出来.放在一个<div>标签中,这个<div>标签的作用就相当于一个容器. 为了使逻辑更加清晰,我们能够为这一个独立的逻辑部分设 ...
 - SVN冲突解决详解
			
在: http://blog.csdn.net/windone0109/article/details/4857044
 - As long as Binbin loves Sangsang
			
题目连接 题意: 给定一个无向图,每一个边有两个属性.长度和一个字母'L','O','V'.'E'中的一个.从1点開始到达n点,每次必须依照L -> O -> V -> E -> ...
 - 安装配置gerrit
			
Centos 安装配置gerrit 关闭selinux,不然nginx的反向代理会报错connect() to 127.0.0.1:8080 failed (13: Permission denied ...
 - Android的目录结构说明
 - [置顶] LLVM每日谈之十五 LLVM自带的examples
			
作者:snsn1984 在LLVM源码的目录下,有一个目录叫做examples,这个目录下边有几个LLVM的例子,初学者一般不会太关注这些例子,但是这些例子确实是精华中的精华,在LLVM的学习过程中不 ...