繁体   English   中英

如何在不使变量在JavaScript中成为全局变量的情况下使用另一个函数中的变量?

[英]How do I use a variable from another function without making the variable global in JavaScript?

本质上,我有两个不同的函数,它们基于HTML表单输入执行不同的计算。

我需要第三个函数从每个变量中获取一个变量以执行最后的数学计算。

有什么方法可以使变量成为全局变量或不合并函数?

功能如下:

function getStateTax(){
    var income = salaryBox.value;
    var sel = document.getElementById("state");
    var state = sel.options[sel.selectedIndex].value;
    var rate = taxRates[state];
    var el = document.getElementById("rate");
    el.innerHTML = rate;
    stateTaxElement.innerHTML = "Your state tax amount is: $" + Math.round(((income * (1 + rate)) - income) * 100) / 100;
}

function getFedTax() {
    var fedTax = 0;
    var income = salaryBox.value;
    if (document.getElementById("single").checked) {
        if (income <= 8350) {
            fedTax = income * .10;
        } else if (income <= 33950) {
            fedTax = 8350 * 0.10 + (income - 8350) * 0.15;
        } else if (income <= 82250) {
            fedTax = 8350 * 0.10 + (33950 - 8350) * 0.15 + (income - 33950) * 0.25;
        } else if (income <= 171550) {
            fedTax = 8350 * 0.10 + (33950 - 8350) * 0.15 + (82250 - 33950) * 0.25 + (income - 82250) * 0.28;
        } else if (income <= 372950) {
            fedTax = 8350 * 0.10 + (33950 - 8350) * 0.15 + (82250 - 33950) * 0.25 + (171550 - 82250) * 0.28 + (income - 171550) * 0.33;
        } else {
            fedTax = 8350 * 0.10 + (33950 - 8350) * 0.15 + (82250 - 33950) * 0.25 + (171550 - 82250) * 0.28 + (372950 - 171550) * 0.33 + (income - 372950) * 0.35;
        }
    }
    if (document.getElementById("jointorwidow").checked) {
        if (income <= 16700) {
            fedTax = income * 0.10;
        } else if (income <= 67900) {
            fedTax = 16700 * 0.10 + (income - 16700) * 0.15;
        } else if (income <= 137050) {
            fedTax = 16700 * 0.10 + (67900 - 16700) * 0.15 + (income - 137050) * 0.25;
        } else if (income <= 208850) {
            fedTax = 16700 * 0.10 + (67900 - 16700) * 0.15 + (137050 - 67900) * 0.25 + (income - 137050) * 0.28;
        } else if (income <= 372950) {
            fedTax = 16700 * 0.10 + (67900 - 16700) * 0.15 + (137050 - 67900) * 0.25 + (208850 - 137050) * 0.28 + (income - 208850) * 0.33;
        } else {
            fedTax = 16700 * 0.10 + (67900 - 16700) * 0.15 + (137050 - 67900) * 0.25 + (208850 - 137050) * 0.28 + (372950 - 208850) * 0.33 + (income - 372950) * 0.35;
        } 
    }
    if (document.getElementById("separate").checked) {
        if (income <= 8350) {
            fedTax = income * 0.10;
        } else if (income <= 33950) {
            fedTax = 8350 * 0.10 + (income - 8350) * 0.15;
        } else if (income <= 68525) {
            fedTax = 8350 * 0.10 + (33950 - 8350) * 0.15 + (income - 33950) * 0.25;
        } else if (income <= 104425) {
            fedTax = 8350 * 0.10 + (33950 - 8350) * 0.15 + (68525 - 33950) * 0.25 + (income - 68525) * 0.28;
        } else if (income <= 186475) {
            fedTax = 8350 * 0.10 + (33950 - 8350) * 0.15 + (68525 - 33950) * 0.25 + (104425 - 68525) * 0.28 + (income - 104425) * 0.33;
        } else {
            fedTax = 8350 * 0.10 + (33950 - 8350) * 0.15 + (68525 - 33950) * 0.25 + (104425 - 68525) * 0.28 + (186475 - 104425) * 0.33 + (income - 186475) * 0.35;
        }
    }  
    if (document.getElementById("head").checked) {
        if (income <= 11950) {
            fedTax = income * 0.10;
        } else if (income <= 45500) {
            fedTax = 11950 * 0.10 + (income - 11950) * 0.15;
        } else if (income <= 117450) {
            fedTax = 11950 * 0.10 + (45500 - 11950) * 0.15 + (income - 45500) * 0.25;
        } else if (income <= 190200) {
            fedTax = 11950 * 0.10 + (45500 - 11950) * 0.15 + (117450 - 45500) * 0.25 + (income - 117450) * 0.28;
        } else if (income <= 372950) {
            fedTax = 11950 * 0.10 + (45500 - 11950) * 0.15 + (117450 - 45500) * 0.25 + (190200 - 117450) * 0.28 + (income - 190200) * 0.33;
        } else {
            fedTax = 11950 * 0.10 + (45500 - 11950) * 0.15 + (117450 - 45500) * 0.25 + (190200 - 117450) * 0.28 + (372950 - 190200) * 0.33 + (income - 372950) * 0.35;
        }
    }
    fedTaxElement.innerHTML = "Your federal tax amount is: $" + Math.round(fedTax * 100) / 100;
}

我需要做的是制作第三个函数,并将fedTax和第一个收入变量加在一起,然后从新变量中减去它们。

javascript中的函数具有返回值的能力(就像大多数(即使不是全部)编程语言一样)。

这意味着函数完成执行后,您可以return特定值。

一个简单的返回结果的例子是一个简单的add函数:

var add = function(a, b) {
    return a + b;
}

var result = add(20, 30); // result is 50
console.log(result);

当然,这是一个不好的例子,因为有+运算符允许您添加数字或连接字符串,但是它仍然显示return作用。

如果要替换return a + b; 只有a + b; 在该行中,将不返回任何值。

现在假设我们有一个函数,该函数带有3个参数,前两个参数将彼此相加,第三个参数将从结果中减去。

我们可以使用嵌套在函数中的add方法来返回可以继续进行计算的结果。

该函数如下所示:

var custom_calc = function(a, b, c) {
    var add_res = add(a, b);
    return (add_res - c);
}

var result = custom_calc(10, 20, 20); // result is 10
console.log(result);

因此,在前两个函数中,您希望每个函数的最后一行是一个return语句,该语句返回第三个函数中所需的变量。 在我的示例中,我们使用add获得结果,将其存储在变量中,然后使用该变量进行进一步的计算,然后返回结果。

同样适用于您的情况,祝您好运!

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM