您的位置:首页 > Web前端 > JavaScript

读书时间《JavaScript高级程序设计》七:表单

2016-06-24 13:32 627 查看
    在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();
}


。。。

 

   
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: