[label][翻译][JavaScript]如何使用JavaScript操纵radio和check boxes
Radio 和 check boxes是form表单中的一部分,允许用户通过鼠标简单点击就可以选择。当与<textarea>元素的一般JavaScript操纵相比较,这些表单控件(form controls)的JavaScript操纵可以说是大不相同。
一个radio(单选框)与一个复选框(checkbox)的区别
在我们正式开始之前,非常重要的一点就是确定每一个人都清楚知道radio和check box的区别,在一组(a group)radio中你只能选择一个radio,然而,对于check boxes来说,多个选中是被允许。例如:在性别选择中,用radio就是最恰当的,而不是使用check box。
怎么通过JavaScript来访问一个radio/check box呢?
究竟,JavaScript是怎么样做才能访一个radio 和 checkbox呢?其实,你可以通过他们的名字来使用任何别的表单(form)元素。
无论是一个radio,还是一个checkbox,对于JavaScript来说都是没有分别的,下面代码定义了一个名为"test"的单选框,并且使用JavaScript来访问它。
<form name="example">
<input type="radio" name="test" /> </form>
<script type="text/javascript">
// access the button called "test"
document.example.test;
</script>
如何使用JavaScript改变一个radio/checkbox 的选择状态?
如果我们无法改变选择框的状态,那么通过它自身来访问一个选择框(radio or checkbox)是没有什么用处的。
一个选择框的状态有两种——"on"被选中时,与"off",没有被选中时,这个状态被JavaScript中的一个名为"checked"的布尔属性所表示。
使用该属性,我们不仅可以确定一个选择框的是否选中状态,还可以同赋值"true"或"false"来改变它的选中状态。(注意:这里的选中状态只是包括选中和没有选中)
//alerts whether a box is checked
alert(document.example.test.checked); //Dynamically selects a box
document.example.test.checked = true;
http://www.javascriptkit.com/javatutors/radiocheck.shtml
多个选择框的组合
我们很少会看到只有一个radio 或 checkbox在表单form中,它们本来就是被用来组合使用的。
如今,我们知道访问一个选择框的默认方式就是通过它的名字(name属性值)。话虽如此(having said that),想象一下有一个50个radio button的组合。
访问他们就需要我们为了每一个(each and every)按钮定义一个唯一的名字。此外,在一个我们需要使用循环来遍历所有的radio buttons的情况下,这意味着需要手写50行的代码来访问和获取50个按钮中的每一个。这个是一个难以接受的想法。
因此,你自言自语的说,就像你常常注视这天空时说"天空之外肯定有一些更好的事物"。好的,我讨厌打破你的这个想法,但是在实际生活中那确实是不存在的,事实就是如此。
可是,在JavaScript中确实有一种技巧可以允许我们方便快捷访问一组当中的某一个radio/check box,关键就是给每一个选择框同一个名字。通过这样子的做法,JavaScript会使用同一个名字来创建一个这些选择框的数组,并且可以允许我们想访问数组元素一样访问单个的选择框。
下面让我们使用一个包含10个check boxes的表单form来证明上面这个概念。
<form name="example">
<input type="checkbox" name="myboxes" /><br />
<input type="checkbox" name="myboxes" /><br />
<input type="checkbox" name="myboxes" /><br />
<input type="checkbox" name="myboxes" /><br />
<input type="checkbox" name="myboxes" /><br />
<input type="checkbox" name="myboxes" /><br />
<input type="checkbox" name="myboxes" /><br />
<input type="checkbox" name="myboxes" /><br />
<input type="checkbox" name="myboxes" /><br />
<input type="checkbox" name="myboxes" /><br />
</form>
在上面这个表单,我们对每一个选择框都给了同一个名字,那么现在就来看看究竟是怎么样就可以轻易的访问每个选择框:
<script type="text/javascript">
//access the 3rd checkbox
document.example.myboxes[2];
//access the last checkbox
document.example.myboxed[9]; //access each and every one of the boxes
for(var i=0; i<document.example.myboxes.length ; i++){
document.example.myboxes[i] = //do whatever
}
</script>
是的,就如我们所看到的,通过将每一个checkbox命名为同一个名字后,它们就会成为一个包含所有同名checkbox的数组。
如何从多个checkbox的组合中获取被选中的选择框呢?
总的来说,共有两个方法可以被用来判断组合当中的哪个选择框被选中了。请看下面的例子:
<form name="tv">
NBC:<input type="radio" name="station" /><br />
CBS:<input type="radio" name="station" /><br />
ABC:<input type="radio" name="station" /><br/>
CNN:<input type="radio" name="station" /><br/>
ESPN:<input type="radio" name="station" /><br/>
</form>
或许你想要选择NBC,并且你想要在当NBC被选中同时执行某一些操作,其他的则不执行操作。无论你想要脚本去做什么,最根本你必须先要脚本能够判断哪个选择框被选中。下面的就是两个方法帮助我们实现:
1)使用for循环来遍历整个选择框数组,并获取到被选中的那个选择框
调用for循环来遍历整个数据,并且最终获取出被选中的。
// a variable that will hold the index number of the selected radio button
var theOne;
for(var i=0;i<document.tv.station; i++){
if(document.tv.station[i].checked === true){
theOne = i;
break;//exist for loop, as target acquired
}
}
2)在<input>标签内使用onClikc来获取被选中的选择框
<script type="text/javascript">
var theOne;
<form name="tv">
NBC:<input type="radio" name="station" onClick="theOne=0" /><br />
CBS:<input type="radio" name="station" onClick="theOne=1" /><br/>
ABC:<input type="radio" name="station" onClick="theOne=2" /></br/>
CNN:<input type="radio" name="station" onClikc="theOne=3"/><br/>
ESPN:<input type="radio" name="station" onClick="theOne=4" /><br/>
</form> </script>
<script type="text/javascript">
var theOne;
<form name="tv">
NBC:<input type="radio" name="station" onClick="theOne=0" /><br />
CBS:<input type="radio" name="station" onClick="theOne=1" /><br/>
ABC:<input type="radio" name="station" onClick="theOne=2" /></br/>
CNN:<input type="radio" name="station" onClikc="theOne=3"/><br/>
ESPN:<input type="radio" name="station" onClick="theOne=4" /><br/>
</form> </script>
无论用户何时点击其中的一个选择框,变量"theOne"将会被设置为该选择框的索引值。
以上例子中,我们展示了在只能选择一个选择框情况下是如何判断哪个选择框被选中了。
在多选的情况下,使用for循环去检索整个数组和保存被选中的选择框索引,比使用onClick事件更加好。
原文来源:http://www.javascriptkit.com/javatutors/radiocheck3.shtml
[label][翻译][JavaScript]如何使用JavaScript操纵radio和check boxes的更多相关文章
- [译]内联Javascript vs 外置Javascript
本文翻译youtube上的up主kudvenkat的javascript tutorial播放单 源地址在此: https://www.youtube.com/watch?v=PMsVM7rjupU& ...
- javaScript系列 [05]-javaScript和JSON
本文输出和JSON有关的以下内容❐ JSON和javaScript❐ JSON的语法介绍❐ JSON的数据类型❐ JSON和XMLHTTPRequest❐ JSON的序列化和反序列化处理 1.1 JS ...
- 2021年3月-第03阶段-前端基础-JavaScript基础语法-JavaScript基础第01天
1 - 编程语言 1.1 编程 编程: 就是让计算机为解决某个问题而使用某种程序设计语言编写程序代码,并最终得到结果的过程. 计算机程序: 就是计算机所执行的一系列的指令集合,而程序全部都是用我们所掌 ...
- JavaScript权威设计--JavaScript函数(简要学习笔记十一)
1.函数调用的四种方式 第三种:构造函数调用 如果构造函数调用在圆括号内包含一组实参列表,先计算这些实参表达式,然后传入函数内.这和函数调用和方法调用是一致的.但如果构造函数没有形参,JavaScri ...
- JavaScript权威设计--JavaScript函数(简要学习笔记十)
1.函数命名规范 函数命名通常以动词为前缀的词组.通常第一个字符小写.当包含多个单词时,一种约定是将单词以下划线分割,就像"like_Zqz()". 还有一种就是"lik ...
- javascript笔记:javascript的关键所在---作用域链
javascript里的作用域是理解javascript语言的关键所在,正确使用作用域原理才能写出高效的javascript代码,很多javascript技巧也是围绕作用域进行的,今天我要总结一下关于 ...
- JavaScript强化教程——JavaScript 总结
本教程中我们向您讲授了如何向 html 页面添加 JavaScript,使得网站的动态性和交互性更强. 你已经学习了如何创建对事件的响应,验证表单,以及如何根据不同的情况运行不同的脚本. 你也学到了如 ...
- JavaScript学习13 JavaScript中的继承
JavaScript学习13 JavaScript中的继承 继承第一种方式:对象冒充 <script type="text/javascript"> //继承第一种方式 ...
- Javascript学习2 - Javascript中的表达式和运算符
原文:Javascript学习2 - Javascript中的表达式和运算符 Javascript中的运算符与C/C++中的运算符相似,但有几处不同的地方,相对于C/C++,也增加了几个不同的运算符, ...
随机推荐
- JavaScript 累加求和练习
输入一个数,求从1加到这个数的和 主要代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" & ...
- ContextLoaderListener和Spring MVC中的DispatcherServlet学习
DispatcherServlet介绍 DispatcherServlet是Spring前端控制器的实现,提供Spring Web MVC的集中访问点,并且负责职责的分派,与Spring IoC容器无 ...
- webdriver自动化脚本
1.需求如下: 启动火狐浏览器首先打开百度,等待3秒然后打开博客首页,等待2秒然后关闭浏览器 from selenium import webdriver from time import sleep ...
- Docker三剑客之 Compose
简介 Docker-Compose 是 Docker 的一种编排服务,是一个用于在 Docker 上定义并运行复杂应用的工具,可以让用户在集群中部署分布式应用. 通过 Docker-Compose 用 ...
- hdoj1010 奇偶剪枝+DFS
Tempter of the Bone Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
- Codeforces 1136E Nastya Hasn't Written a Legend (线段树教做人系列)
题意:有一个数组a和一个数组k,数组a一直保持一个性质:a[i + 1] >= a[i] + k[i].有两种操作:1,给某个元素加上x,但是加上之后要保持数组a的性质.比如a[i]加上x之后, ...
- 运行php网站需要安装什么
php的运行环境: 为了能够运行php,有以下两种方法: 1. 使用支持php和MySQL的web主机(): 2. 本机(自己电脑)安装web服务器,然后安装MySQL和php. web虚拟主机: 大 ...
- android:cmd下面用adb打log
进入cmd命令行,启动adb 1.用adb打log:adb logcat 2.过滤log信息:adb logcat | findstr *** 这里的***就是你需要设置的过滤项,如myscan ...
- ubuntu自动拉黑破解ssh服务的IP
2013年的脚本,今天拿出来备份一下. vim /root/secure_ssh.sh #!/bin/bash cat /var/log/auth.log|awk '/Failed/{print $( ...
- myschool 相思树
题目描述 一群妖王排成一排站在苦情巨树下,寻找自己的转世恋人.虽然都是妖王,但按照涂山的规定必须进行标号,标号为1的妖王排在最后面,标号为n的妖王排在最前面.每个妖王只有一个妖力值a[i]表示它们现在 ...