javascript - 如何对jquery中动态添加的变量进行乘法

标签 javascript jquery onchange

我想在更改#quantity文本框值后动态地获取价格和产品数量的总金额。 我是这样做的。但当我在 Firefox 控制台中检查时,没有调用 calculate 函数。有什么解决办法吗?

$(document).ready(function(){
    $("#quantity").bind('change',calculate);
    function calculate()
    {
    var price = $("#price").val();
    var quantity = $("#quantity").val();
    var amount = price * quantity;
    $("#amount").val(amount);
    }
    }); 

最佳答案

您应该使用格式编号

$.fn.formatNumber = function() {
$(this).keydown(function (e) {
    // Allow: backspace, delete, tab, escape, enter and .
    if ($.inArray(e.keyCode, [46, 8, 9, 27, 13, 109, 110, 189, 190]) !== -1 ||
         // Allow: Ctrl+A
        (e.keyCode == 65 && e.ctrlKey === true) || 
         // Allow: home, end, left, right
        (e.keyCode >= 35 && e.keyCode <= 39)) {
             // let it happen, don't do anything
             return;
    }
    // Ensure that it is a number and stop the keypress
    if ((e.shiftKey || (e.keyCode < 48 || e.keyCode > 57)) && (e.keyCode < 96 || e.keyCode > 105)) {
        e.preventDefault();
    }

});
return this;

};

然后使用keyup:

$.fn.setupQty = function() {
$(this).keyup(function(){
    if( $('#quantity').val() != '' && $('#price').val() != '') {
        var quantity = $(this).val();
        var price = $("#price").val();  
        var amount = price * quantity;
        $("#amount").val(amount);
    }
    else {
        $("#amount").val(0);
    }
});
return this;
};
$('#quantity').formatNumber().setupQty(); 

关于javascript - 如何对jquery中动态添加的变量进行乘法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24339572/

相关文章:

javascript - $(window).load 或 $(window).scroll 在同一个函数中?

javascript - Twitter bootstrap - 单击时关注模式内的文本区域

javascript - 从复选框 onchange 事件中获取值

javascript - 中止 window.location.hash

javascript - 无法将对象插入到 json 对象数组中

JQuery UI - 如何将更改事件绑定(bind)到组合框?

vba - 自动在小数点分隔符后写入 2 位数字

javascript - 函数或类之外的“ super ”-react-native

javascript - 使用 where 时使用 toType 时出错

javascript - 跨浏览器确定Javascript垂直滚动百分比的方法