JavaScript 学习(2)表单元素
JavaScript 学习-2
1. 表单和表单元素
1.1 form对象
form
对象的引用:document.forms[0]
或者引用name
属性,如:document.forms["formname"]
,也可以直接使用document.formname
调用form对象
1.2 form表单属性和元素
name,target,action,method,enctype
赋值改变:document.forms[0].action
或document.formName.action
获得form中的元素使用form.elements[]
,如下面将text值清零
var form=window.document.forms[0];
for(var i=0;i<form.elements.length;i++){
if(form.elements[i].type=="text"){
form.elements.value="";
}
}
1.3表单控件
- 文本框
text
,文本的最常用的属性是value属性,value属性的内容通常是一个字符串。 - 按钮对象
button
,主要是click处理事件 - 复选框对象
checkbox
,属性为checked,布尔类型 - 单选按钮对象
radio
,设置该对象时候需要设置为相同的name,获取单选按钮对象的数量可以使用document.forms[0].groupName.length
,检测是否高亮选择使用document.forms[0].groupName[0].checked
- select对象,select对象是符合对象一个包含了option对象数组的对象,访问方法如下
document.forms[0].selectName.selectedIndex
获得当前选择的下标,document.forms[0].selectName.options[n].text
和document.forms[0].selectName.options[n].value
,其中text
属性是select对象显示的字符串,可以使用onchange事件处理器,比如我们常见的下拉后选择网站后直接导航。
<html>
<head>
<title></title>
<script type="text/javascript">
function goThere () {
var list=document.forms[0].urlList;
location.href=list.options[list.selectedIndex].value;
}
</script>
</head>
<body>
<form name="radiolist">
<select name="urlList" onchange="goThere()">
<option selected value="http://www.baidu.com">baidu
<option value="http://www.qq.com">qq
</select>
</form>
</body>
</html>
1.4向函数传递表单数据和元素
javaScript提供了一个关键字this
,它通常指向对象,这个对象包含使用这个关键词的脚本,因此,在一个文本域的onchange
事件处理器中,可以使用this
作为关键词为函数的参数如
<input type="text" name="entry" onchage="upperMe(this)">
function upperMe(field){ //dosomething }
每个控件都有一个指向所含的表的属性,故可以这么写this.form
获取该form
<html>
<head>
<title>js_4</title>
<script type="text/javascript">
function processData (formthis) {
for(var i=0;i<formthis.Beatles.length;i++){
if(formthis.Beatles[i].checked){
break;
}
}
var beatle=formthis.Beatles[i].value;
var song=formthis.song.value;
alert("chcecking whether "+song+" feature in " +""+beatle);
}
function varifySong(entry){
var song=entry.value;
alert("checking whether "+song+" is a beatles tunes");
}
</script>
</head>
<body>
<form onsubmit="return false">
<p>choose your favoriate Beatle:
<input type="radio" name="Beatles" value="Jhon" checked>John
<input type="radio" name="Beatles" value="Markey">Markey</p>
<p> input your song name:<br>
<input type="text" name="song" value="song search" onchange="varifySong(this)">
<input type="button" name="process " value="process requset..." onclick="processData(this.form)"></p>
</p>
</form>
</body>
</html>
这段代码有一个比较特殊的逻辑,实验后能发现,在输入框输入之后,点击process requeset
之后我们可以看到首次触发是文本框的onchange事件,而process requeset
的事件并没有执行。因为text onChange
事件的触发是在text
离开焦点就触发了,所以在点击text
之外的任何的地方都会先触发onChange
事件,而按钮的单击在第二次点击后才能执行。这就是组合验证。
1.5提交和验证表单
onsubmit
事件处理必须求值得到return true
才允许继续提交,或者return false
阻止提交。
<html>
<head>
<title>js_5</title>
<script type="text/javascript">
function checkForm(fomr1){
for (var i = 0; i < fomr1.elements.length; i++) {
if(fomr1.elements[i].type=="text" &&fomr1.elements[i].value==""){
alert("fill all the name");
return false;
}
};
}
</script>
</head>
<body>
<form onsubmit="return checkForm(this)">
Please enter all requested information:<br>
FirstName: <input type="text" name="FirstName"><br>
LastName :<input type="text" name="LastName"><br>
<input type="submit">
</form>
</body>
</html>
JavaScript 学习(2)表单元素的更多相关文章
- 9. Javascript学习笔记——表单处理
9. 表单处理 9.1 表单的基础知识 ///表单用 <form> 元素表示,对应的是 HTMLFormElement 类型,继承自 HTMLElement. //属性:action.me ...
- JavaScript之控制表单元素的值
表单元素.value 获取表单元素的值 表单元素.value='这是修改后的值' 修改表单元素的值 案例: (1)html <input type="text" id=&qu ...
- HTML学习笔记 表单元素
<form></form>代表表单 action:往什么地方提交 method:提交方式 get显示提交(不安全) post隐视提交(安全) 提交内容: name=输入的 ...
- [html5] 学习笔记-表单新增的元素与属性(续)
本节主要讲解表单新增元素的controls属性.placeholder属性.List属性.Autocomplete属性.Pattern属性.SelectionDirection属性.Indetermi ...
- HTML5 学习总结(二)——HTML5新增属性与表单元素
一.HTML5新增属性 1.1.contextmenu contextmenu的作用是指定右键菜单. <!DOCTYPE html> <html> <head> & ...
- HTML5 学习笔记(二)——HTML5新增属性与表单元素
目录 一.HTML5新增属性 1.1.contextmenu 1.2.contentEditable 1.3.hidden 1.4.draggable 1.5.data-* 1.6.placehold ...
- HTML5学习总结——HTML5新增属性与表单元素
一HTML5新增属性 1.1contcxtmcnu contextmenu的作用是指定右键菜单. <!DOCTYPE html> <html> <head> < ...
- HTML之学习笔记(十)表单元素
html表单元素的基本格式为(必须包含在form标签中)
- [html5] 学习笔记-表单新增元素与属性
本节讲的是表单元素的form,formaction属性,frommethod,formenctype属性,formtarget,autofocus属性,required,labels属性. 1.for ...
随机推荐
- andorid HTTPS 不需要证书 VolleyEror: com.android.volley.NoConnectionError: javax.net.ssl.SSLHandshakeException: java.security.cert.CertPathValidatorException: Trust anchor for certification path not fou
1.加证书(这里不说) 2.修改代码 import java.security.KeyManagementException;import java.security.NoSuchAlgorithmE ...
- 关闭了的SQL Server服务如何打开
在cmd里输入如下:net start mssqlserver
- Postman 常用操作
一,入参为json 格式 实例:添加学生信息,这个接口是用来讲入参式json 类型的 二,上传文件 三,添加header 信息 实例:获取所有学生信息 四,添加cookie以及身份验证 实例:学生金币 ...
- php中Http请求方法和响应状态码整理教程
HTTP请求报文由请求行(request line).请求头部(header).空行和请求数据4个部分组成,格式如下 可见请求行由请求方法字段.URL字段和HTTP协议版本字段3个字段组成,它们用空格 ...
- MySQL 记录中包含换行符
换行符: \r\n \r CHAR(10) 处理方法: REPLACE(str,from_str,to_str); 如:REPLACE('aaa\nbbb','\n','');
- HTML5七巧板canvas绘图(复习)
<!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...
- Mongodb 和 Solr 实时同步
一.安装前准备 1.mongo-connector(基于python)中间件 2.python-3.4.3.msi 3.Mongodb 4.Solr 二.配置Mongodb集群 1).配置replic ...
- Shoot the Bullet ZOJ - 3229 有源汇有上下界的最大流
/** zoj提交评判不了,所以不知道代码正不正确.思路是应该没问题的.如果有不对的地方,请多指教. 题目:Shoot the Bullet ZOJ - 3229 链接:https://vjudge. ...
- [转]OpenMP中的private/firstprivate/lastprivate/threadprivate之间的比较
转自:http://blog.csdn.net/gengshenghong/article/details/6985431 private/firstprivate/lastprivate/threa ...
- Java 设计模式01 - 简单工厂模式
先要学习设计模式之前的先看看一些基础 UML类图简单说明 可以先看看我的这篇博客: UML类图简单说明,学习编程思路的必会技能 接下来才是重点,开始我们的旅程吧. 一.UML类图展示 我们要用简单工厂 ...