Jquery对表单、表格的操作以及应用
表单的应用
(1)表单标签:包含处理表单数据所用的服务器端程序URL以及数据提交到服务器的方法
(2)表单域:包含文本框、密码框、隐藏域、多行文本框、复选框、单选框、下拉选择框、和文件上传框
(3)表单按钮:包括提交按钮、复位按钮和一般按钮,用于将数据传送到服务器上或者取消传送,还可以用来控制其他定义了处理脚本的处理工作。
5.1.1单行文本框
获取和失去焦点改变样式
<label> 标签为 input 元素定义标注(标记)。
label 元素不会向用户呈现任何特殊效果。不过,它为鼠标用户改进了可用性。如果您在 label 元素内点击文本,就会触发此控件。就是说,当用户选择该标签时,浏览器就会自动将焦点转到和标签相关的表单控件上。
<label> 标签的 for 属性应当与相关元素的 id 属性相同。
for id 规定 label 绑定到哪个表单元素。
form formid 规定 label 字段所属的一个或多个表单。
<script>
$(function () {
$("input").focus(function () {
$(this).addClass("focus");
}).blur(function () {
$(this).removeClass("focus");
})
})
</script>
聚焦是改变,不聚焦时则恢复原样 5.1.2多行文本框的应用
高度变化:改变评论框的大小
<script>
$(function () {
var $comment=$("#comment");
$(".bigger").click(function () {
if ($comment.height()<500){
$comment.height($comment.height()+50);
}
});
$(".smaller").click(function () {
if ($comment.height()>50){
$comment.height($comment.height()-50);
}
})
})
</script>
使用动画进行控制高度
<script>
$(function () {
var $comment=$("#comment");
$(".bigger").click(function () {
if ($comment.height()<500){
$comment.animate({height:"+=50"},400);
}
});
$(".smaller").click(function () {
if ($comment.height()>50){
$comment.animate({height:"-=50"},400);
}
})
})
</script>
2滚动条的高度变化scrollTop 方法
对于多行文本框,还可以通过控制多行文本框的滚动条的变化,使文本框里的内容滚动。
{ scrollTop:“50px”}
5.1.3复选框应用
基本:就是对复选框进行全选、反选、和反全选等操作
如果需要使复选框处于选中或者不选中的状态,必须通过控制元素的checked属性来达到目的;
如果属性checked的值为true,说明被选中,如果值为false,说明没被选中。
$('[name=item]:checkbox').attr('checked',true); //全选
$('[name=item]:checkbox').attr('checked',false); //全不选
5.1.4 下拉框应用
dbclick()方法 双击实现
5.1.5 表单验证
5.2表格应用
1.普通的隔行变色
$("tr:odd").addClass("odd");//给奇数行添加样式
$("tr:even").addClass("even");//给偶数行添加样式 索引是从0开始的 故第一行是偶数
为了排除表头<thead>中的<tr>,将选择符改为
$(function(){
$("tbody>tr:odd").addClass("odd");
$("tbody>tr:even").addClass("even");
})
若需要将某一行进行修饰,可以使用contains选择器实现:
$("tr:contains("王五")").addClass("selected");
单选框控制表格行高亮
当单击某一行后,此行被选中高亮显示,并且单选框被选中。实现步骤:
(1)为表格行添加单击事件
(2)给单击的当前行添加高亮样式,然后将它的兄弟行的高亮样式去掉,最后将当前行里的单选框设置为选中。
注意使用完sibling之后需要使用end()方法,才可以重新返回$(this)对象
find() 方法返回被选元素的后代元素。
后代是子、孙、曾孙,依此类推
(this).find(":radio").attr("checked",true);
注意:
$(‘table:radio:checked’).parent().parent().addClass("selected");是通过parent()方法逐步向父节点获取相应元素的,也可以使用parents()方法直接获取
$("table :radio:checked").parents("tr").addClass(‘selected’);
此外可以通过has选择器进一步简化,表示含有选中的单选框<tr>行被元素高亮显示。
$('tbody>tr:has(:checked)').addClass('selected');
3复选框控制行亮高
复选框能控制多行变色,并没有数量限制。当单击某行时,如果已经高亮了,则移除高亮样式并去掉当前行复选框选中状态;如果还没有高亮,则添加该样式,将当前行的复选框选中;
判断是否高亮,可以使用hasClass()方法来完成。
$(this).find(':checkbox').attr("checked",true);
5.2.2表格展开关闭
$(this).toggleClass("selected")//增加、删除高亮
.siblings('.child_'+this.id).toggle(); //隐藏、显示所谓的子行
5.2.3 表格内容的筛选
filter()方法和contains选择器//能匹配包含指定的文本元素 相结合
filter(“:contains(李)”).show();
为文本框绑定keyup事件:
$(function(){
$("filterName").keyup(function(){})
})
注意表单元素有个特点,就是刷新网页,其值会保持不变。但是表格的内容已经被刷新了
为了解决这个问题,只需要在DOM刚加载完时,为表单元素绑定事件并且立即触发该事件即可
$(function(){
$("#filterName").keyup(fucntion(){
$("table tbody tr").hide().filter(":contains('"+(this).val()+"')").show();
}).keyup; //DOM加载完成时,绑定事件完成后立即触发
});
当网页刷新后会立即执行id为“”filternName“”的keyup事件,因此表格内容会保持刚筛选出来的结果
5.3.1网页字体的大小
5.3.2网页选项卡
5.3.3网页换肤
Jquery对表单、表格的操作以及应用的更多相关文章
- jQurey对表单表格的操作及更多应用(方法型)
- jQuery(6)——jQuery对表单、表格的操作及更多应用
jQuery对表单.表格的操作及更多应用 [表单应用] 一个表单有表单标签.表单域及表单按钮三个基本部分. 单行文本框应用:获取和失去焦点改变样式. 也可以用CSS中的伪类选择符来实现,但是IE6并不 ...
- jQuery 对表单、表格的操作及更多应用-简略笔记
[jQuery 对表单.表格的操作及更多应用] jquery对表单及表格的操作是实际应用中相当广泛. 对于表单的操作,可以实现 (1)获取和失去焦点改变样式: (2)在多行文本框中可以实现网站评论框的 ...
- (十)jQuery对表单、表格的操作
一.表单应用 1.HTML中的表单大致由三部分组成 (1).表单标签:包含处理表单数据所用的服务端程序URL,以及数据提交到服务器的方法. (2).表单域:包含文本框.密码框.隐藏域.多行文本框.复选 ...
- 第5章 jQuery对表单、表格的操作及更多应用
本章主要是对前面4章的小结和应用. 一. 表单form应用 表单分为3个组成部分 (1)form标签 表单可包含文本域,复选框,单选按钮等等.表单用于向指定的 URL 传递用户数据. (2)表单域 - ...
- jQuery对表单、表格的操作以及更多应用
表单和表格都是HTML的重要组成部分,分别用于采集.提交用户输入的信息和显示列表数据. 表单应用:一个表单有3个基本组成部分: ①表单标签:包含处理表单数据所用的服务器端程序URL以及数据提交到服务器 ...
- jQuery对表单、表格的操作及更多应用(上:表单应用)
内容摘录自锋利的JQuery一书 一.表单应用 1 获取和失去焦点改变样式(P142) $(function(){ $(":input").focus(function(){ // ...
- jQuery对表单、表格的操作及更多应用(中:表格应用)
内容摘录自锋利的JQuery一书 二.表格应用 1 表格隔行变色(:odd和:even选择器 P157) $(function(){ $("tr:odd").addClass(&q ...
- jQuery对表单、表格的操作及更多应用
<head> <style type="text/css"> .even { background-color: #fff38f;/*偶数行样式*/ ...
随机推荐
- github 管理代码、笔记
1.先注册github.com的账号官方网站: https://github.com/ 2.登录 3.创建仓库 二. 1.安装git 2.刚才我们已经在github上面创建了一个仓库,那么我们现在就在 ...
- XML、HTML、XHTML的关系
标记语言 XML.HTML.XHTML这三者都有ML.ML(Markup Language)标记语言在维基百科中的解释是: 一种将文本以及文本相关的信息结合起来,展示出关于文档结构和数据处理细节的计算 ...
- js中4种遍历语法比较
前言:本文主要比较for.for-in.forEach和for-of的异同以及优缺点. for for循环是最原始最易理解的循环遍历方式 for(var index = 0;index < ar ...
- 51nod 1020
求 $n$ 个数的排列中逆序数为 $k$ 的排列数$f[n][k]$ 表示 $n$ 个数的排列中逆序数为 $k$ 的排列数$f[n][k] = \sum_{i = 0}^{n - 1} f[n - 1 ...
- 洛谷 P2251 质量检测(st表)
P2251 质量检测 题目提供者ws_ly 标签 难度 普及/提高- 题目描述 为了检测生产流水线上总共N件产品的质量,我们首先给每一件产品打一个分数A表示其品质,然后统计前M件产品中质量最差的产品的 ...
- idea 启动 Error running 'XxGatewayApplication': Command line is too long. Shorten command line for XxGatewayApplication or also for Spring Boot default
在idea workspace里 <component name="PropertiesComponent">标签下加入 <property name=" ...
- rxjs与vue
原创文章,转载请注明出处 使用vue-rx插件将vue和rxjs联系起来 在main.js中将vue-rx注入vue中 import Vue from 'vue' import App from '. ...
- 3-自定义构造方法和description方法
http://www.cnblogs.com/mjios/archive/2013/04/19/3031412.html -自定义构造方法和description方法 1 默认的构造方法是什么?有什么 ...
- ie中打印的问题
一般正常的情况下使用window.print();各个浏览器都可以调用出打印功能来但是ie有个坑就是如果页面在iframe里的话打印出来就是错的页面所以在这里要这样写: var agent = nav ...
- CF1208C
CF1208C 这场杜老师大战tourist的比赛怎么这么多人类智慧题... 题意: 构造一个 $ n \times n $ 的矩阵,使得该矩阵每一行与每一列的元素的异或和全部相等. 解法: 异或的神 ...