一、获取下拉列表选中项的值和文本(select)
1. <html>
2. <head><title>获取下拉列表选中项的值和文本(select)</title></head>
3. <body>
4. <script>
6. //获取下拉列表选中项的文本
7. function getSelectedText(name){
8. var obj=document.getElementById(name);
9. for(i=0;i<obj.length;i++){
10. .selected==true){
11. return obj[i].innerText; //关键是通过option对象的innerText属性获取到选项文本
12. }
13. }
14. }
16. //获取下拉列表选中项的值
17. function getSelectedValue(name){
18. var obj=document.getElementById(name);
19. return obj.value; //如此简单,直接用其对象的value属性便可获取到
20. }
22. </script>
23. <select id="myselect">
24. <option value="fist">1</option>
25. <option value="second">2</option>
26. <option value="third">3</option>
27. </select>
29. <input type="button" value="所选文本" onclick="alert(getSelectedText('myselect'));" />
30. <input type="button" value="所选值" onclick="alert( getSelectedValue('myselect'));" />
31. </body>
32. </html>
<html> <head><title>获取下拉列表选中项的值和文本(select)</title></head> <body> <script> //获取下拉列表选中项的文本 function getSelectedText(name){ var obj=document.getElementById(name); for(i=0;i<obj.length;i++){ if(obj[i].selected==true){ return obj[i].innerText; //关键是通过option对象的innerText属性获取到选项文本 } } } //获取下拉列表选中项的值 function getSelectedValue(name){ var obj=document.getElementById(name); return obj.value; //如此简单,直接用其对象的value属性便可获取到 } </script> <select id="myselect"> <option value="fist">1</option> <option value="second">2</option> <option value="third">3</option> </select> <input type="button" value="所选文本" οnclick="alert(getSelectedText('myselect'));" /> <input type="button" value="所选值" οnclick="alert( getSelectedValue('myselect'));" /> </body> </html>
二、获取单选按钮(radio)组的值和修改选中项
看到很多帖子里说js获取单选按钮(radio)组的值可以直接用document.getElementById("oper").value,虽然跟单选按钮组一样的下拉列表(也是列表项的数组)也是一个数组,用这种方式可以获到下拉列表的值,但是单选按钮组却获不到所选的值。仔细研究了下,总结如下:
与下拉列表不同,单选按钮须用this.form.oper或者document.getElementsByName('oper')方式获取该数组对象,document.getElementById('oper')不能获取该数组对象(select可以)。而且要获取值须通过一循环判断获取,不能直接用.value(select可以)。而要改变单选按钮组的选中项,也须用循环判断改变各个单选按钮的value。
测试代码radio.html 如下:
1. <html>
2. <head></head>
3. <script language="javascript">
5. //求单选按纽的值,适用单选项及多选项。未选返回false;有选择项,返回选项值。
6. function getRadio(oRadio){
7. var oRadiooRadioLength= oRadio.length;
8. var oRadioValue = false;
9. //alert("oRadioLength:["+oRadioLength+"]");
11. if (oRadioLength== undefined){
12. if (oRadio.checked){
13. oRadiooRadioValue
14. }
15. }else{
16. i=0;i<oRadioLength;i++){
17. //alert("oRadio["+i+"]:"+oRadio[i].checked+"/"+oRadio[i].value);
18. if (oRadio[i].checked){
19. oRadiooRadioValue
20. break;
21. }
22. }
23. }
24. return oRadioValue;
25. }
28. //方法改进:
30. //求单选按纽的值,传radio名字作为参数。未选返回false;有选择项,返回选项值。
31. function getRadioValue(name){
32. var radioes = document.getElementsByName(name);
33. for(var i=0;i<radioes.length;i++)
34. {
35. if(radioes[i].checked){
36. return radioes[i].value;
37. }
38. }
39. return false;
40. }
43. //通过值修改所选中的单选按钮
44. function changeRadio(oRadio,oRadioValue){ //传入一个对象
45. for(var i=0;i<oRadio.length;i++) //循环
46. {
47. .value==oRadioValue) //比较值
48. {
49. .checked=true; //修改选中状态
50. break; //停止循环
51. }
52. }
53. }
56. //改进:
58. //通过值修改所选中的单选按钮
59. function setRadio(name,sRadioValue){ //传入radio的name和选中项的值
60. var oRadio = document.getElementsByName(name);
61. for(var i=0;i<oRadio.length;i++) //循环
62. {
63. .value==sRadioValue) //比较值
64. {
65. .checked=true; //修改选中状态
66. break; //停止循环
67. }
68. }
69. }
71. </script>
73. <body>
74. <form name="frm">
76. <input type="radio" name="oper" value="agree" >同意</td>
77. <input type="radio" name="oper" value="downchange" checked>下发修改</td>
78. <input type="radio" name="oper" value="refuse">拒保</td>
79. <input type="radio" name="oper" value="report" >上报 </td>
80. <br>
81. alert('result:'+getRadio(this.form.oper))
82. <input type="button" name="test1" value="按钮1" onclick="alert('result:'+getRadio(this.form.oper));">
83. <br>
84. alert('result:'+getRadio(document.getElementById('oper')))
85. <input type="button" name="test2" value="按钮2" onclick="alert('result:'+getRadio(document.getElementById('oper')));">
86. <br>
87. alert(this.form.oper.value)
88. <input type="button" name="test3" value="按钮3" onclick="alert(this.form.oper.value);">
89. <br>
90. changeRadio(this.form.oper,"上报")
91. <input type="button" name="test4" value="按钮4" onclick="changeRadio(this.form.oper,'report');">
92. <br><br><br><br>
95. <select id="slt">
96. <option value="agree" >同意</option>
97. <option value="downchange" selected>下发修改</option>
98. <option value="refuse">拒保</option>
99. <option value="report">上报</option>
100. </select>
101. <br>
102. alert(this.form.slt.value)
103. <input type="button" name="test5" value="按钮5" onclick="alert(this.form.slt.value);">
104. <br>
105. document.getElementById('slt')[2].innerText)
106. <input type="button" name="test6" value="按钮6" onclick="alert(document.getElementById('slt')[2].innerText);">
109. </form>
110. </body>
111. </html>
tornado RequestHandler prepare 解析post请求参数
一、常用注解回顾1.1 @RequestBody与@ResponseBody//注意并不要求@RequestBody与@ResponseBody成对使用。
public @ResponseBody AjaxResponse saveArticle(@RequestBody ArticleVO article)如上代码所示:@RequestBody修饰请求参数,注解用于接收HTTP的body,默认