我正在尝试将事件目标值传递给另一个函数

时间:2018-12-01 06:09:07

标签: javascript events scope

我设置了两个事件,一个英尺,一个英寸。我试图获取每个事件的价值(英尺和英寸),但是由于每个事件的范围,我无法做到。有没有办法将两个值都传递到我的totalHeight函数中,以便可以将两个值加在一起?

const justFeet = totalFeet.addEventListener('input', (e) => {
    const heightInFeet = e.target.value;
    let displayFeet = document.createElement('h3')
    displayFeet.textContent = heightInFeet * 12
    // totalInches.appendChild(displayFeet)
})

const justInches = inches.addEventListener('input', (e) => {
    const addOnInches = e.target.value;
    let displayInches = document.createElement('h3')
    displayInches.textContent = addOnInches
    // totalInches.appendChild(displayInches)
})
    
function totalHeight (feet, inches) {
    const finalTotal = feet + inches;
    let finalHeight = document.createElement('h3')
    finalHeight.textContent = finalTotal
    totalInches.appendChild(finalHeight)
}

totalHeight(displayFeet, displayInches)

1 个答案:

答案 0 :(得分:1)

您要尝试执行的操作的示例。您还需要做更多的事情,例如我在下面使用了整数,但是您可以使用浮点数,并且可能为isNaN()添加了更好的处理方法。

<html>
<style>
</style>

    Feet:<input id="feet" type="number"></input>
    Inches:<input id="inches" type="number"></input>
    <h3>Feet converted to inches: <span id="displayFeetToInches"></span></h3>
    <h3>Inches: <span id="displayInches"></span></h3>
    <h3>Total inches:<span id="finalHeight"></span></h3>

    <script>

        const feet = document.getElementById("feet");
        const inches = document.getElementById("inches");
        const total = document.getElementById("total");  //in inches
        const displayFeetToInches = document.getElementById("displayFeetToInches");  //in inches
        const displayInches = document.getElementById("displayInches");  //in inches

        const justFeet = feet.addEventListener('input', (e) => {
            console.log('justFeet');
            const heightInFeet = e.target.value;
            displayFeetToInches.textContent = heightInFeet * 12;
            totalHeight();
        })

        const justInches = inches.addEventListener('input', (e) => {
            console.log('justInches');
            const addOnInches = e.target.value;
            displayInches.textContent = addOnInches
            totalHeight();
        })

        function totalHeight (feet, inches) {
            console.log('totalinches');
            const ftToInches = displayFeetToInches.textContent;
            const addOn = displayInches.textContent;
            const finalTotal = parseInt(ftToInches) + parseInt(addOn);
            finalHeight.textContent = finalTotal
        }

    </script>
</html>