jQuery是一个兼容多浏览器的javascript库,核心理念是write less,do more(写得更少,做得更多)。其中也提供了很多函数来更加简洁的实现复杂的功能。

  事件切换函数toggle(fn1,fn2,fn3 ...):作用是每次点击后依次调用函数,第一次点击调用fn1,第二次调用fn2,依次类推直到调用最后一个函数,然后继续重新开始从第一个继续开始 继续循环

<body>
<ul>
<li>Go to the store</li>
<li>Pick up dinner</li>
<li>Debug crash</li>
<li>Take a jog</li>
</ul>
<button>click me</button>
<script type="text/javascript">
$(document).ready(function(){
$("button").toggle(function(){
$("body").css("background-color","green");},
function(){
$("body").css("background-color","red");},
function(){
$("body").css("background-color","yellow");}
);
}); </script>
</body>

  上面代码的效果就是第一次点击button,body背景色变为绿色,第二次变为红色,第三次变为黄色,第四次重新变为绿色...

  

  事件切换函数hover(over, out):一个模仿悬停事件的方法,鼠标悬停时调用over函数,鼠标移出时调用out函数

<body>
<ul>
<li>Go to the store</li>
<li>Pick up dinner</li>
<li>Debug crash</li>
<li>Take a jog</li>
</ul>
<script type="text/javascript">
$(document).ready(function(){
$("ul").hover(function(){
$("ul").css("background-color","green");},
function(){
$("ul").css("background-color","red");}
);
}); </script>
</body>

  鼠标移动到ul标签上面,ul标签的背景色变为绿色,鼠标移出ul标签背景色变为红色

  在项目开发中有时会涉及到报表系统,报表中通常会有合计、总计这样的字段,为了数据的准确性,合计和总计这些字段数据库不会实际建字段,或者使用视图中计算出来的数字或者在后台逻辑计算中计算得出,那么当需要修改这个页面的字段时就会出现一个问题,修改了基本字段,那么合计也应该动态的进行变化,那么我们使用jQuery里面的函数就可以比较简洁快速的进行页面联动的效果。上图中总建筑面积就是下面3个面积相加得出的

<div class="wrapper">
<div class="title-box">
<a class="btn icon-read" href="#" onclick="doSave()" title="保存">保存</a>
</div>
<div class="table-box" id="mainTable">
<t:formvalid formid="formobj" dialog="true" usePlugin="password" layout="div" tiptype="5" action="tllazghjmdghssAction.do?doSave">
<table class="the-table" border="0" cellspacing="0" cellpadding="0">
<tr>
<td style="width:auto;" class="title" rowspan="2">序号</td>
<td style="width:10%;" class="title" rowspan="2">项目名称</td>
<td style="width:auto;" class="title" rowspan="2">单位</td>
<td style="width:auto;" class="title" colspan="2">初步设计</td>
<td style="width:auto;" class="title" colspan="2">安置实施</td>
</tr>
<tr>
<td style="width:auto;" class="title">达德移民安置点</td>
<td style="width:auto;" class="title">多卡移民安置点</td>
<td style="width:auto;" class="title">达德移民安置点</td>
<td style="width:auto;" class="title">多卡移民安置点</td>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">1</td>
<td style="text-align:left;vertical-align: middle;">规划范围面积</td>
<td style="text-align:center;vertical-align: middle;">㎡</td>
<c:forEach items="${jmghList}" var="jmgh">
<input id="id" name="id" value="${jmgh.id}" type="hidden">
<input id="fsjd1" name="fsjd1" value="${jmgh.fsjd}" type="hidden">
<input id="fsymazd1" name="fsymazd1" value="${jmgh.fsymazd}" type="hidden">
<td style="text-align:center;vertical-align: middle;"><input class="inputxt" id="ffghfwmj1" name="ffghfwmj1" value="${jmgh.ffghfwmj}" datatype="n" nullmsg="请填写规划范围面积"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">2</td>
<td style="text-align:left;vertical-align: middle;">总建筑面积</td>
<td style="text-align:center;vertical-align: middle;">㎡</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input readonly="readonly" class="inputxt" id="ffzjzmj1" name="ffzjzmj1" value="${jmgh.ffptgjmj+jmgh.ffjzjzmj+jmgh.ffszjzmj}" datatype="n" nullmsg="请填写总建筑面积"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">2.1</td>
<td style="text-align:center;vertical-align: middle;">配套公建面积</td>
<td style="text-align:center;vertical-align: middle;">㎡</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input onblur="doChange()" class="inputxt" id="ffptgjmj1" name="ffptgjmj1" value="${jmgh.ffptgjmj}" datatype="n" nullmsg="请填写配套公建面积"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">2.2</td>
<td style="text-align:center;vertical-align: middle;">居住建筑面积</td>
<td style="text-align:center;vertical-align: middle;">㎡</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input onblur="doChange()" class="inputxt" id="ffjzjzmj1" name="ffjzjzmj1" value="${jmgh.ffjzjzmj}" datatype="n" nullmsg="请填写居住建筑面积"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">2.3</td>
<td style="text-align:center;vertical-align: middle;">市政建筑面积</td>
<td style="text-align:center;vertical-align: middle;">㎡</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input onblur="doChange()" class="inputxt" id="ffszjzmj1" name="ffszjzmj1" value="${jmgh.ffszjzmj}" datatype="n" nullmsg="请填写市政建筑面积"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">3</td>
<td style="text-align:left;vertical-align: middle;">容积率</td>
<td style="text-align:center;vertical-align: middle;"></td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input class="inputxt" id="ffrjl1" name="ffrjl1" value="${jmgh.ffrjl}" datatype="n" nullmsg="请填写容积率"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">4</td>
<td style="text-align:left;vertical-align: middle;">建筑密度</td>
<td style="text-align:center;vertical-align: middle;">%</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input class="inputxt" id="ffjzmd1" name="ffjzmd1" value="${jmgh.ffjzmd}" datatype="n" nullmsg="请填写建筑密度"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">5</td>
<td style="text-align:left;vertical-align: middle;">绿地率</td>
<td style="text-align:center;vertical-align: middle;">%</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input class="inputxt" id="ffldl1" name="ffldl1" value="${jmgh.ffldl}" datatype="n" nullmsg="请填写绿地率"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">6</td>
<td style="text-align:left;vertical-align: middle;">人均用地面积</td>
<td style="text-align:center;vertical-align: middle;">㎡</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input class="inputxt" id="ffrjydmj1" name="ffrjydmj1" value="${jmgh.ffrjydmj}" datatype="n" nullmsg="请填写人均用地面积"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">7</td>
<td style="text-align:left;vertical-align: middle;">总户数</td>
<td style="text-align:center;vertical-align: middle;">户</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input class="inputxt" id="ffzhs1" name="ffzhs1" value="${jmgh.ffzhs}" datatype="n" nullmsg="请填写总户数"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">8</td>
<td style="text-align:left;vertical-align: middle;">户均人口</td>
<td style="text-align:center;vertical-align: middle;">个</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input class="inputxt" id="ffhjrk1" name="ffhjrk1" value="${jmgh.ffhjrk}" datatype="n" nullmsg="请填写总户数"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">9</td>
<td style="text-align:left;vertical-align: middle;">搬迁人口</td>
<td style="text-align:center;vertical-align: middle;">个</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input class="inputxt" id="ffbqrk1" name="ffbqrk1" value="${jmgh.ffbqrk}" datatype="n" nullmsg="请填写搬迁人口"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
<tr>
<td style="text-align:center;vertical-align: middle;">10</td>
<td style="text-align:left;vertical-align: middle;">停车位</td>
<td style="text-align:center;vertical-align: middle;">个</td>
<c:forEach items="${jmghList}" var="jmgh">
<td style="text-align:center;vertical-align: middle;"><input class="inputxt" id="fftcw1" name="fftcw1" value="${jmgh.fftcw}" datatype="n" nullmsg="请填写停车位"><span class="Validform_notnull">*</span></td>
</c:forEach>
</tr>
</table>
</t:formvalid>
</div>
</div> <script type="text/javascript">
function doChange(){
var i=0;
var ffptgjmj = new Array(4);
var ffjzjzmj = new Array(4);
var ffszjzmj = new Array(4);
$("input[name='ffptgjmj1']").each(function(){
ffptgjmj[i] = isNull($(this).val());
i++;
});
i = 0;
$('input[name="ffjzjzmj1"]').each(function(){
ffjzjzmj[i] = isNull($(this).val());
i++;
});
i = 0;
$('input[name="ffszjzmj1"]').each(function(){
ffszjzmj[i] = isNull($(this).val());
i++;
});
i = 0;
$('input[name="ffzjzmj1"]').each(function(){
$(this).attr('value',parseInt(ffptgjmj[i])+parseInt(ffjzjzmj[i])+parseInt(ffszjzmj[i]));
i++;
}); }
function isNull(data){
return (data == "" || data == undefined || data == null) ? 0 : data;
}
</script>

  这个就是使用each函数进行遍历,然后当对应的input文本框失去焦点时调用doChange()方法进行更新总建筑面积字段,这个是一个完整的例子i,有兴趣的朋友可以copy过去自己跑一下试试,其中jsp部分有很多项目中框架的痕迹,感兴趣朋友自己写一个jsp,然后模仿我上面的js函数试验一下。

  

JQuery学习笔记系列(二)----的更多相关文章

  1. JS与Jquery学习笔记(二)

    一. JS 的面向对象 JS没有类,其类就用function来代替如下所示: function Cat(name, color){ this.name=name; this.color=color; ...

  2. JQuery学习笔记系列(一)----选择器详解

    笔者好长时间没有更新过博客园的笔记了,一部分原因是去年刚刚开始工作一段时间忙碌的加班,体会了一种每天加班到凌晨的充实感,之后闲暇时间了也因为自己懒惰没有坚持记笔记的习惯,现在重新拾起来. 借用古人的一 ...

  3. jQuery学习笔记(二):this相关问题及选择器

    上一节的遗留问题,关于this的相关问题,先来解决一下. this的相关问题 this指代的是什么 这个应该是比较好理解的,this就是指代当前操作的DOM对象. 在jQuery中,this可以用于单 ...

  4. jquery学习笔记之二

    1.one()与bind()的区别 bind():给一个对象绑定事件,可以绑定一个事件,也可以绑定多个事件. one():跟bind一样,都是给对象绑定事件的. 如给一个按钮绑定了三个相同的click ...

  5. JQuery学习笔记(二)JQuery方法

    jQuery 提供一系列与 DOM 相关的方法,便于访问和操作元素和属性 Query 文档操作方法 这些方法对于 XML 文档和 HTML 文档均是适用的,除了:html(). 方法 描述 addCl ...

  6. 初步学习jquery学习笔记(二)

    jQuery事件 jquery是为事件处理而设计的 什么是事件? 页面对不同访问者的相应叫做事件. 事件处理程序指的是html中发生某些事件所调用的方法 实例: 在元素上移动鼠标 选取单选按钮 点击元 ...

  7. JNI 学习笔记系列(二)

    c中没有Boolean类型的值,一般是使用1表示true,0表示false,c中也没有String类型的数据,c中的字符串要通过char数组来表示.c中没有byte类型,一般用char表示byte类型 ...

  8. jQuery学习笔记(二)

    1. 基本选择器 #id      ("#one") .class  $(".two") element (根据给定的元素名匹配元素) $("div& ...

  9. Windows-universal-samples学习笔记系列二:Controls, layout, and text

    Controls, layout, and text AutoSuggestBox migration Clipboard Commanding Context menu Context menu ( ...

随机推荐

  1. day008 字符编码之 字符编码 、Python2和Python3字符编码的区别

    计算机基础(掌握) 启动应用程序的流程 双击qq 操作系统接受指令然后把该操作转化为0和1发送给CPU CPU接受指令然后把指令发送给内存 内存接受指令把指令发送给硬盘获取数据 qq在内存中运行 文本 ...

  2. [转载]Linux内存高,触发oom-killer问题解决

    最近遇到两起Linux的内存问题,其一是触发了oom-killer导致系统挂 首先确认该系统的版本是32位 #uname -a Linux alarm 2.6.9-67.ELsmp #1 SMP We ...

  3. 设计模式 第一天 UML图,设计模式原则:开闭原则、依赖倒转原则、接口隔离原则、合成复用原则、迪米特法则,简单工厂模式

    1 课程大纲 2 UML的概述 总结: UML unified model language 统一建模语言 一共有十种图: 类图 用例图 时序图 * 对象图 包图 组件图 部署图 协作图 状态图 (最 ...

  4. GDI 边框绘制函数(8)

    绘制矩形 调用 Rectangle 函数可以绘制一个矩形(它将填充这个矩形): BOOL Rectangle( HDC hdc, // 设备环境句柄 int nLeftRect, // 左边线的位置 ...

  5. Java核心技术读书笔记01

    Volume I Chapter 1  An Introduction to Java  • 1.1 Java as a Programming Platform• 1.2 The Java ‘Whi ...

  6. shell脚本中source无效

    发现在shell里面执行source,提示找不到命令.所以,我取搜了一些资料,总结一下. 一. 脚本中,source找不到命令--------------是因为用了sh执行脚本,而debian系统的s ...

  7. FusionCharts,双折线图和双柱状图

    一个电商项目中,用到了"双柱状图",对比 当前库存和累计库存. 网上找了好几个贴子,才找到具体用法. 代码整理下,以备不时之需. 效果图-双折线图 效果图-双柱状图 <%@ ...

  8. BZOJ 3119 Book (贪心+数学推导)

    手动博客搬家: 本文发表于20191029 22:49:41, 原地址https://blog.csdn.net/suncongbo/article/details/78388925 URL: htt ...

  9. Vue.js教程—1.介绍和安装

    Vue.js(读音 /vjuː/, 类似于 view) 是一套构建用户界面的渐进式框架.Vue 只关注视图层, 采用自底向上增量开发的设计.Vue 的目标是通过尽可能简单的 API 实现响应的数据绑定 ...

  10. CodeForces 551E GukiZ and GukiZiana

    GukiZ and GukiZiana Time Limit: 10000ms Memory Limit: 262144KB This problem will be judged on CodeFo ...