jQuery操作Form表单元素
Web开发中常常须要操作表单,form表单元素有select、checkbox、radio、textarea、button、file、text、hidden、password等。
当中checkbox和radio的读写值操作比較多变,checkbox和radio常常常使用在一个分组里。实现多选或者单选。
jQuery提供了利用表单选择器我们能够极其方便地获取表单的某个或某类型的元素。
| 选择器 | 返回 | 演示样例 |
|---|---|---|
| :input | 集合元素 | $(“:input”)选取全部,,和元素。 |
| :text | 单行文本框集合 | $(“:text”)选取全部的单行文本框。 |
| :password | 密码框集合 | $(“:password”)选取全部的密码框。 |
| :radio | 单行文本框集合 | $(“:radio”)选取全部的单选框。 |
| :checkbox | 复选框集合 | $(“:checkbox”)选取全部的复选框。 |
| :submit | 提交按钮集合 | $(“:submit”)选取全部的提交按钮。 |
| :image | 图片按钮集合 | $(“:image”)选取全部的图片按钮。 |
| :reset | 重置按钮集合 | $(“:reset”)选取全部的重置按钮。 |
| :button | 按钮集合 | $(“:button”)选取全部的按钮。 |
| :file | 上传域集合 | $(“:file”)选取全部的上传域。 |
| :hidden | 不可见元素集合 | $(“:hidden”)选取全部的不可见元素。 |
以下介绍select、checkbox和radio的使用方法。
select
select元素内容例如以下
<select id="select">
<option value="0">北京</option>
<option value="1">上海</option>
<option value="2">武汉</option>
<option value="3">南京</option>
<option value="4">广州</option>
<option value="5" selected="selected">深圳</option>
</select>
对select的操作
//获取select当前选中项的值
$('#select').val();
//获取select当前选中项的文本
$('#select').children('option:selected').text();
//设置select选中值为3的option
$('#select').val('3');
//设置select选中文本为武汉的option
$('#select').children('option:contains(武汉)').attr('selected', 'selected');
checkbox
<div>
<fieldset id="checkboxGroup">
<legend>选择最喜欢的城市</legend>
<div><input type="checkbox" name="city" value="北京" /><span>北京</span></div>
<div><input type="checkbox" name="city" value="上海" /><span>上海</span></div>
<div><input type="checkbox" name="city" value="南京" /><span>南京</span></div>
<div><input type="checkbox" name="city" value="深圳" /><span>深圳</span></div>
<div><input type="checkbox" name="city" value="广州" /><span>广州</span></div>
<div><input type="checkbox" name="city" value="武汉" /><span>武汉</span></div>
</fieldset>
</div>
<div style="margin-top:20px;">
<button id="btnCheckbox1">获取选择的checkbox</button>
<button id="btnCheckbox2">选择深圳和广州</button>
<button id="btnCheckbox3">全选</button>
<button id="btnCheckbox4">全不选</button>
<button id="btnCheckbox5">反选</button>
</div>
//获取选择的checkbox值
$('#btnCheckbox1').click(function(){
var values = [];
$('#checkboxGroup').find(':checkbox:checked').each(function(){
values.push($(this).val());
});
alert(values.join(','));
});
//选择深圳和广州
$('#btnCheckbox2').click(function(){
var $group = $('#checkboxGroup');
$group.find(':checkbox').each(function(){
var $this = $(this), val = $this.val();
if(val === '深圳' || val === '广州'){
$this.prop('checked', true);
}else{
$this.prop('checked', false);
}
});
});
//全选
$('#btnCheckbox3').click(function(){
var $group = $('#checkboxGroup');
$group.find(':checkbox').prop('checked', true);
});
//全不选
$('#btnCheckbox4').click(function(){
var $group = $('#checkboxGroup');
$group.find(':checkbox').prop('checked', false);
});
//反选
$('#btnCheckbox5').click(function(){
var $group = $('#checkboxGroup');
$group.find(':checkbox').each(function(){
var $this = $(this);
$this.prop('checked', !$this.prop('checked'));
});
});
radio
<div>
<fieldset id="radioGroup">
<legend>选择最喜欢的城市</legend>
<div><input type="radio" name="city" value="北京" /><span>北京</span></div>
<div><input type="radio" name="city" value="上海" /><span>上海</span></div>
<div><input type="radio" name="city" value="南京" /><span>南京</span></div>
<div><input type="radio" name="city" value="深圳" /><span>深圳</span></div>
<div><input type="radio" name="city" value="广州" /><span>广州</span></div>
<div><input type="radio" name="city" value="武汉" /><span>武汉</span></div>
</fieldset>
</div>
<div style="margin-top:20px;">
<button id="btnRadio1">获取选择的radio</button>
<button id="btnRadio2">选择上海</button>
</div>
//获取当前选择的radio值
$('#btnRadio1').click(function(){
var group = $('#radioGroup'),
value = group.find(':radio:checked').val();
alert(value);
});
//选择上海
$('#btnRadio2').click(function(){
$('#radioGroup').find(':radio[value="上海"]').prop('checked', true);
});
form
jQuery提供了serialize()和serializeArray()获取form表单元素的值,serialize()把获取的值拼接成字符串,serializeArray()返回数组。
<form id="form">
<div>姓名:<input type="text" name="name" /></div>
<div>年龄:<input type="text" name="age" /></div>
<div>
性别:
<select name="sex">
<option value="男">男</option>
<option value="女">女</option>
<option value="保密" selected="selected">保密</option>
</select>
</div>
<fieldset>
<legend>最喜欢的城市</legend>
<div><input type="radio" name="city" value="广州" /><span>广州</span></div>
<div><input type="radio" name="city" value="深圳" /><span>深圳</span></div>
<div><input type="radio" name="city" value="上海" checked="checked" /><span>上海</span></div>
</fieldset>
<fieldset>
<legend>喜欢的运动</legend>
<div><input type="checkbox" name="sports" value="足球" /><span>足球</span></div>
<div><input type="checkbox" name="sports" value="篮球" /><span>篮球</span></div>
<div><input type="checkbox" name="sports" value="羽毛球" /><span>羽毛球</span></div>
<div><input type="checkbox" name="sports" value="乒乓球" /><span>乒乓球</span></div>
</fieldset>
</form>
<div style="margin-top:20px;">
<button id="btnSubmit">提交</button>
<button id="btnReset">重置</button>
<button id="btnFormValue">获取form的值</button>
</div>
//提交
$('#btnSubmit').click(function(){
$('#form').submit();
});
//重置
$('#btnReset').click(function(){
//因为jQuery没有提供reset方法,仅仅能用form原生的reset方法。
$('#form').get(0).reset();
});
//获取form的值
$('#btnFormValue').click(function(){
alert(decodeURIComponent($('#form').serialize()));
});
jQuery操作Form表单元素的更多相关文章
- 【jQuery】form表单元素序列化为json对象
序列化form表单元素为json对象: <!Doctype html> <html xmlns=http://www.w3.org/1999/xhtml> <head&g ...
- jQuery控制form表单元素聚焦
CreateTime--2017年5月28日08:57:16Author:Marydon jQuery使form表单的第一个文本框聚焦 /** * 使form表单的第一个文本框聚焦 */ func ...
- Jquery学习笔记:操作form表单元素之二(复选框和单选框)
在上面文章的基础上,我们介绍如何操作表单元素中的 复选框和单选框. 一.复选框 <label> <input type="checkbox" id="i ...
- Jquery操作常用表单元素
由于对前端的东西不是很熟练,导致jquery操作表单的东西总是忘记,每次用都要查一下,效率低下,记录下来,以便下次使用. CheckBox checkbox改变事件 $('#IsAllSearch') ...
- 将form表单元素的值序列化成对象
/**jQuery * 将form表单元素的值序列化成对象 * @returns object */ var serializeObject = function(form) { var o = {} ...
- 第83天:jQuery中操作form表单
操作form表单 1. 属性操作 设置属性: // 第一个参数表示:要设置的属性名称 // 第二个参数表示:该属性名称对应的值 $(selector).attr(“title”, “传智播客”); 获 ...
- form表单元素的值序列化成对象
/** * 将form表单元素的值序列化成对象 * param: form jquery form对象 */ var serializeObject = function(form) { var o ...
- jquery序列化form表单使用ajax提交后处理返回的json数据
1.返回json字符串: /** 将一个字符串输出到浏览器 */ protected void writeJson(String json) { PrintWriter pw = null; try ...
- jQuery实现form表单基于ajax无刷新提交方法详解
本文实例讲述了jQuery实现form表单基于ajax无刷新提交方法.分享给大家供大家参考,具体如下: 首先,新建Login.html页面: <!DOCTYPE html PUBLIC &quo ...
随机推荐
- python解决鸡兔同笼问题
# 这个问题,是我国古代著名趣题之一. # 大约在1500年前,<孙子算经>中就记载了这个有趣的问题. # 书中是这样叙述的:“今有雉兔同笼,上有三十五头,下有九十四足, # 问雉兔各几何 ...
- nginx如何防止高负载造成服务器崩溃
nginx-http-sysguard模块 一.作用 防止因nginx并发访问量过高或者遭受攻击造成服务器宕机,可根据负载设置界面跳转. 二.安装配置 1.下载模块软件包 wget https:/ ...
- Django框架基础知识03-模板变量及模板过滤器
模板变量及模板过滤器. 1.模板路径的查找 -查找顺序 1.尝试,在app目录下存放模板. -两种方案 1.app项目文件夹下存放. 2.templates文件夹下分类存放. 首先查找项目settin ...
- 大数据学习——hive显示命令
show databases; desc t_partition001; desc extended t_partition002; desc formatted t_partition002; !c ...
- 大数据学习——JAVA采集程序
1 需求 从外部购买数据,数据提供方会实时将数据推送到6台FTP服务器上,我方部署6台接口采集机来对接采集数据,并上传到HDFS中 提供商在FTP上生成数据的规则是以小时为单位建立文件夹(2016-0 ...
- python request包使用指西
request是Python的一个网络模块包,使用它可以快速写一些强大的爬虫脚本
- NYOJ-487月老的烦恼(1)类似于素数筛法一样的打表及一种筛法核心代码。。
月老的烦恼(1) 时间限制:1000 ms | 内存限制:65535 KB 难度:3 描述 月老最近遇到了一个很棘手的问题,就是"剩男""剩女"急速增长,而 ...
- iOS第三方地图-百度地图中心点定位
使用百度地图定位后,滑动地图,使用反编码确定地图中心店的位置信息 // // MapControl.m // quyizu // // Created by apple on 15/9/2. // C ...
- POJ 3090 坐标系上的视线遮蔽问题
Description A lattice point (x, y) in the first quadrant (x and y are integers greater than or equal ...
- [POJ2352] Stars(树状数组)
传送门 先按照下标x排序,然后依次把y加入树状数组,边加入边统计即可. 注意下标re从零开始,需+1s ——代码 # include <iostream> # include <cs ...