5.1 《锋利的jQuery》jQuery对表单的操作
tip1:
注意使用<label>的for标签,对应input的id。(for 属性规定 label 与哪个表单元素绑定。)
tip2:
注意:jquery从1.6版本开始,哪些属性应该用attr()访问,哪些应该用prop()访问。
第一个原则:只添加属性名称该属性就会生效应该使用prop();
第二个原则:只存在true/false的属性应该使用prop();
按照官方说明,如果是设置disabled和checked这些属性,应使用prop()方法,而不是attr()方法。
1、获取焦点和失去焦点改变样式
input:focus,textarea:focus{
border: 1px solid #ff3300;
background-color: #fcc;
}
/*IE6并不支持除超链接元素之外的:hover伪类选择符。*/
so,
$(":input").focus(function(){
$(this).addClass("focus");
}).blur(function(){
$(this).removeClass("focus");
});
// :input表示选择表单中的input,select,textarea,button元素,input仅仅选择input元素。
2、改变文本框/滚动条高度
var $comment=$("#commnet");
$(".bigger").click(function(){
if($comment.is(":animated")){
// if($comment.height()<500){
// $comment.animate({height:"+=50"},400);
// } //高度变大
$comment.animate({scrollTop:"-=50"},400); //向上滚动
}
});
$(".smaller").click(function(){
if($comment.is(":animated")){
// if($comment.height()>50){
// $comment.animate({height:"-=50"},400);
// } //高度变小
$comment.animate({scrollTop:"+=50"},400); //向下滚动
}
})
3、复选框应用
<form action="#" method="post" id="regForm">
你爱好的运动是?
<input type="checkbox" id="CheckAll">全选/全不选
<br/>
<input type="checkbox" name="items" value="足球"> 足球
<input type="checkbox" name="items" value="篮球"> 篮球
<input type="checkbox" name="items" value="羽毛球"> 羽毛球
<input type="checkbox" name="items" value="乒乓球"> 乒乓球<br/>
<input type="button" id="CheckRev" value="反选">
<input type="button" id="send" value="提交">
</form>
$(function () {
// 全选/全不选
$("#CheckAll").click(function () {
$("[name=items]:checkbox").prop("checked", this.checked);
});
// 反选
$("#CheckRev").click(function () {
$("[name=items]:checkbox").each(function () {
this.checked = !this.checked;
})
});
// 提交
$("#send").click(function () {
var str = "你选择中的是:";
$("[name=items]:checkbox:checked").each(function () {
str += $(this).val() + "/";
})
alert(str);
})
// 跟全选联动
$("[name=items]:checkbox,#CheckRev").click(function(){ //#CheckRev添加了反选的联动
var flag=true;
$("[name=items]:checkbox").each(function(){
if(!this.checked){
flag=false;
}
});
$("#CheckAll").prop("checked",flag);
})
});
4、下拉框应用
<div class="fz">
<div class="content l">
<select multiple id="select1" style="width: 100px; height: 160px;">
<option value="1">选项1</option>
<option value="2">选项2</option>
<option value="3">选项3</option>
<option value="4">选项4</option>
<option value="5">选项5</option>
<option value="6">选项6</option>
<option value="7">选项7</option>
<option value="8">选项8</option>
</select>
<div>
<span id="add">选中添加到右边>></span><br/>
<span id="add_all">全部添加到右边>></span>
</div>
</div>
<div class="content l">
<select multiple id="select2" style="width: 100px; height: 160px;"></select>
<div>
<span id="remove"><<选中删除到左边</span><br/>
<span id="remove_all"><<全部删除到左边</span>
</div>
</div>
</div>
$(function () {
// 选中添加到右边
$("#add").click(function(){
var $option=$("#select1 option:selected");
// var $remove=$option.remove();
// $remove.appendTo("#select2");
// 删除和追加可以用appendTo()方法直接完成
$option.appendTo("#select2");
});
// 全部添加到右边
$("#add_all").click(function(){
var $option=$("#select1 option");
$option.appendTo("#select2");
});
// 双击添加到右边
$("#select1").dblclick(function(){
var $option=$("option:selected",this);
$option.appendTo("#select2");
})
});

5、表单验证:
<form method="post" action="">
<div class="int">
<label for="username">用户名:</label>
<input type="text" id="username" class="required">
</div>
<div class="int">
<label for="email">邮箱:</label>
<input type="text" id="email" class="required">
</div>
<div class="int">
<label for="personinfo">个人资料:</label>
<input type="text" id="personinfo">
</div>
<div class="sub">
<input type="submit" value="提交" id="send"> <input type="reset" id="res">
</div>
</form>
$(function () {
$("form :input.required").each(function(){
var $required=$("<strong class='red'>*</strong>");
$(this).parent().append($required);
});
$("form :input").blur(function(){
$parent=$(this).parent();
$parent.find(".formtips").remove();
// 验证用户名
if($(this).is("#username")){
if(this.value==""||this.value.length<6){
var errorMsg="请输入至少6位数的用户名";
$parent.append("<span class='formtips onError'>"+errorMsg+"</span>");
}else{
var okMsg="输入正确";
$parent.append("<span class='formtips onSuccess'>"+okMsg+"</span>");
}
}
// 验证邮箱
if($(this).is("#email")){
if(this.value==""||this.value!=""&&!/.+@.+\.[a-zA-Z]{2,4}$/.test(this.value)){
var errorMsg="请输入正确的email";
$parent.append("<span class='formtips onError'>"+errorMsg+"</span>");
}else{
var okMsg="输入正确";
$parent.append("<span class='formtips onSuccess'>"+okMsg+"</span>");
}
}
}).keyup(function(){ //新增,keyup()用户每次松开按键的时候触发
$(this).triggerHandler("blur"); //trigger()不仅会触发为元素绑定的blur事件,也会触发浏览器默认的blur事件,
// 即不能将光标定位到文本框上。而triggerHander("blur")只会触发为元素绑定的blur,而不触发浏览器默认的blur事件
}).focus(function(){ //新增,focus()元素得到焦点的时候触发
$(this).triggerHandler("blur");
});
// 表单提交
$("#send").click(function(){
$("form .required:input").trigger("blur");
var numError=$("form .onError").length;
if(numError){
return false;
}else{
alert("注册成功!");
}
})
});
5.1 《锋利的jQuery》jQuery对表单的操作的更多相关文章
- jQuery对表单的操作
表单应用 一个表单有3个基本组成部分: 表单标签:包含处理表单数据所用的服务器端程序URL以及数据提交到服务器的方法 表单域:包含文本框.密码框.隐藏域.多行文本框.复选框.单选框.下拉选择框和文件上 ...
- JavaScript学习笔记——对表单的操作
javascript-对表单的操作实例讲解 <form name="myform" id="form1" action="" meth ...
- HTML 学习笔记 JQuery(表单,表格 操作)
表单应用 一个表单有3个基本组成部分 (1)表单标签:包含处理表单数据所用的服务器端程序URL 以及数据提交到服务器的方法 (2)表单域:包含文本框 密码框 隐藏框 多行文本框 复选框 单选框 下拉选 ...
- JS对表单的操作
JS对表单中的style的操作,包括复选框技术 废话不多说直接上文件代码!!! 功能:全选\反选,鼠标监测变颜色 <html> <head> <meta charset= ...
- jQuery(6)——jQuery对表单、表格的操作及更多应用
jQuery对表单.表格的操作及更多应用 [表单应用] 一个表单有表单标签.表单域及表单按钮三个基本部分. 单行文本框应用:获取和失去焦点改变样式. 也可以用CSS中的伪类选择符来实现,但是IE6并不 ...
- 【锋利的jQuery】表单验证插件踩坑
和前几篇博文提到的一样,由于版本原因,[锋利的jQuery]表单验证插件部分又出现照着敲不出效果的情况. 书中的使用方法: 1. 引入jquery源文件, 2. 引入表单验证插件js文件, 3. 在f ...
- 《锋利的JQuery》读书要点笔记4——表格表单的操作
第五章 jQuery对表单,表格的操作以及更多应用 这章主要以一些具体案例讲解了jQuery对表单,表格的常用操作,以及一些常见的jQuery应用,用到的都是上几章说的东西.下面就以具体的案例来展开. ...
- jQuery 对表单、表格的操作及更多应用-简略笔记
[jQuery 对表单.表格的操作及更多应用] jquery对表单及表格的操作是实际应用中相当广泛. 对于表单的操作,可以实现 (1)获取和失去焦点改变样式: (2)在多行文本框中可以实现网站评论框的 ...
- js进阶 14-7 jquery的ajax部分为什么需要对表单进行序列化
js进阶 14-7 jquery的ajax部分为什么需要对表单进行序列化 一.总结 一句话总结:如果用ajax传递表单的数据,如果不进行表单的序列化,要一个参数一个参数的写,太麻烦,序列化的话,一句代 ...
随机推荐
- PHP使用frameset制作后台界面时,怎样实现通过操作左边框架,使右边框架中的页面跳转?
左框架的链接,不仅要指定链接的文件名,还需要通过 target 属性指定要打开的目标框架名(即楼主要求的右框架名). 例:假设右框架为 <frame scr="lx1.htm" ...
- VS2010 MFC中 窗口分割的实现
分割窗口概述 分割窗口,顾名思义,就是将一个窗口分割成多个窗格,在每个窗格中都包含有视图,或者是同一类型的视图,或者是不同类型的视图. MFC分割窗口的方式有两种,动态分割和静态分割. 动态分割窗口通 ...
- ZOJ - 3228 Searching the String (AC自己主动机)
Description Little jay really hates to deal with string. But moondy likes it very much, and she's so ...
- JAVA Eclipse 出现 load id=gralloc != hmi-id=gralloc怎么办
一般是应用程序权限导致的,在Manifest.xml文件中,targetSdkVersion设置不正确,你可以直接删掉这个信息
- shell脚本实现定时重启任务并输出日志信息
#!/bin/bash #当前日期 time=`date` pidno=`ps aux|grep adserver-beta|grep -v "grep"|awk '{print ...
- iscroll的理解
1. 最佳的HTML结构如下: <div id="wrapper"> <ul> <li>...</li> <li>... ...
- 数组方式使用jQuery对象
一. 使用jQuery选择器获取结果是一个jQuery对象.然而,jQuery类库会让你感觉你正在使用一个定义了索引和长度的数组.在性能方面,建议使用简单的for或者while循环来处理,而不是$.e ...
- WPF非UI线程中调用App.Current.MainWindow.Dispatcher提示其他线程拥有此对象,无权使用。
大家都知道在WPF中对非UI线程中要处理对UI有关的对象进行操作,一般需要使用委托的方式,代码基本就是下面的写法 App.Current.MainWindow.Dispatcher.Invoke(ne ...
- 如何禁止同IP站点查询和同IP站点查询的原理分析 Robots.txt屏蔽BINGBOT
很多站长工具中都有“同IP站点查询”.“IP反查域名”这种服务不少人都不知道是什么原理,其实这些服务几乎都是用BING(以前的LIVE)来实现 的,BING有个特别功能 BING抓取页面时会把站点的I ...
- hadoop生态系统学习之路(六)hive的简单使用
一.hive的基本概念与原理 Hive是基于Hadoop之上的数据仓库,能够存储.查询和分析存储在 Hadoop 中的大规模数据. Hive 定义了简单的类 SQL 查询语言,称为 HQL.它同意熟悉 ...