jQuery不兼容input的change事件问题解决过程
最近开发一个项目,需要实现用户在WEB表单里的多个INPUT框中输入数量后,立即自动计算加总各项输入的数量之和,并显示在指定的INPUT框中,这个功能实现的原理是简单的,就是只需要在INPUT的onchange事件中计算加总并将结果赋给指定的INPUT框中即可实现,代码如下:
$("input.syxcost").change(function(){
computeReceivedsyxcost();
}
function computeReceivedsyxcost(){ //计算加总
var syxcost=0;
$("input.syxcost").each(function(){
var cost=parseFloat($(this).val());
if (!isNaN(cost))
syxcost=syxcost + cost;
});
$("#receivedsyxcost").val(syxcost); //显示最终结果
}
原以为这样就解决了,在谷歌浏览器确实是OK的,但在IE 9中,却发现在INPUT中输入数量后,并不会立即触发change事件,存在兼容问题,在网上搜了许多,也都说存在这个问题,没有办法,我就只有自己来依据实现情况来写,我的思路是:当INPUT获取焦点时,就获取当前的VALUE并存入该INPUT的自定义的属性中(如:data-oval),然后在INPUT失去焦点的时候,就获取当前的VALUE与之前存在自定义的属性中的值是否相同,若不相同,则说明VALUE被改变,就需要重新计算,否则忽略,实现代码如下:
$("input.syxcost").focus(function(){
$(this).attr("data-oval",$(this).val()); //将当前值存入自定义属性
}).blur(function(){
var oldVal=($(this).attr("data-oval")); //获取原值
var newVal=($(this).val()); //获取当前值
if (oldVal!=newVal)
{
computeReceivedsyxcost(); //不相同则计算
}
});
经反复验证,在所有的浏览器下均显示正常,解决了兼容的问题!
- jQuery解决input超多的表单提交
- js与jquery实时监听输入框值的oninput与onpropertychange方法
- jquery中$(#form :input)与$(#form input)的区别
- jQuery根据ID获取input、checkbox、radio、select的示例
- jquery ajax提交表单数据的两种方式
- jquery validate.js表单验证的基本用法入门
- jQuery-serialize()输出序列化form表单值的方法
- jQuery对表单元素的取值和赋值操作代码
- jquery下异步提交表单 异步跨域提交表单
- jquery的ajaxSubmit()异步上传图片并保存表单数据演示代码
- jQuery获取及设置表单input各种类型值的方法小结
相关文章
html+jQuery实现拖动滑块图片拼图验证码插件【移动端适用】
这篇文章主要介绍了html+jQuery实现拖动滑块图片拼图验证码插件,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下2019-09-09jQuery EasyUI 中文API Button使用实例
jQuery EasyUI 中文API Button使用小结,需要的朋友可以参考下。2010-04-04Jquery下的26个实用小技巧(jQuery tips, tricks & solutions)
前段时间发布了Jquery类库1.4版本,使用者也越来越多,为了方便大家对Jquery的使用,下面列出了一些Jquery使用技巧。2010-03-03jQuery插件zTree实现获取当前选中节点在同级节点中序号的方法
这篇文章主要介绍了jQuery插件zTree实现获取当前选中节点在同级节点中序号的方法,结合实例形式分析了属性插件zTree针对节点序号的相关操作技巧,需要的朋友可以参考下2017-03-03
最新评论