为了账号安全,请及时绑定邮箱和手机立即绑定

如何将输入和 php 数组中的值转换为 js 并相乘?

如何将输入和 php 数组中的值转换为 js 并相乘?

慕无忌1623718 2023-05-11 14:01:35
好的,正如您在下面的代码片段中看到的那样,我在数字 (1) 中创建选择(输入),在数字 (2) 中,我显示选择的名称,在数字 (3) 中,我显示单价。(1) 是一个从 1 到 n 的数字,我想从每个 (1) 中取出输入数字并将其与单价 (3) 相乘(例如 x=(1)*(3)),然后将所有的相加这些结果并将它们显示在另一个文本框中。我尝试了几件事,但无法实现。我真的可以在这里使用一些指导。我很乐意提供任何更多信息。    <?php        $sum = $choice['qty'] * $choice['timi'];        foreach($choice3 as $choice3){    ?>    //(1)<input type="number" class="colorqty" name="color[<?php echo $i; ?>][unit]" step="<?php echo $step; ?>" value="0" min="0" class="color_qty_1" onchange="updateTotal();"> //(2)    <input type="text" value="<?php echo $choice3['price_name']; ?>" name="color[<?php echo $i; ?>][price_name]" readonly="readonly" class="color_qty_2"> //(3)    <input type="text" value="<?php echo $choice3['price']."€"; ?>" name="xrwmas" readonly="readonly" class="color_qty_2" id="tests">  <br />    <?php $i++;  }  ?>例如从上面的循环我们得到我想在此示例中乘以 5 * 68、0 * 74 等,然后对结果求和并将其显示在求和框中。
查看完整描述

2 回答

?
喵喔喔

TA贡献1735条经验 获得超5个赞

这对我来说很好


        <?php Route::add('/route', function() { 


        $array = [

            [

            'price_name' => 'Xiaomi Poco X3',

            'price' => 2000

            ],

            [

            'price_name' => 'Xiaomi Poco F1 plus',

            'price' => 1500

            ],

            [

            'price_name' => 'Xiaomi Poco F1',

            'price' => 1000

            ]

            ];


            foreach($array as $key => $value) {


        ?>



        <div id="form">

            <input type="number" id="input_value" class="colorqty" name="color[<?php echo $key; ?>][unit]" value="0" min="0" class="color_qty_1" onkeyup="updateTotal();">

            <input type="text" value="<?php echo $value['price_name']; ?>" name="color[<?php echo $key; ?>][price_name]" readonly="readonly" class="color_qty_2">

            <input type="text" data-id="<?php echo $key; ?>" value="<?php echo $value['price']."€"; ?>" id="price" name="xrwmas" readonly="readonly" class="color_qty_2" id="tests">  <br />

        </div>



        <?php


        }


        echo '<p>SUM <span id="sum">0</span></p>';

        ?> 


        <script>


        function updateTotal(value,id) {

        var elements = document.getElementsByTagName('input')


        var input_val = 0;

        var price_val = 0;


        for(let i = 0 ; i < elements.length; i++) {

            

            if(elements[i].getAttribute('id') == 'price') {

                

                price_val += parseInt(elements[i].value.replace('€',''))

            }


            if(elements[i].getAttribute('id') == 'input_value') {

            

                input_val += parseInt(elements[i].value)

            

            }

        }


        document.getElementById('sum').innerHTML = !Number.isNaN(price_val * input_val) ? price_val * input_val : 0


        }


        </script>


        <?php


        }); 


        ?>

你只需要 javascript 就可以做到吗


查看完整回答
反对 回复 2023-05-11
?
叮当猫咪

TA贡献1776条经验 获得超12个赞

所以对于一开始的代码,我们在我们需要的所有项目中添加唯一的 id。在这个例子中价格和输入所以这里是例子


<?php

        foreach($choice3 as $choice3){

    ?>

    //(1)

<input type="number" class="colorqty" name="color[<?php echo $i; ?>][unit]" step="<?php echo $step; ?>" value="0" min="0" class="color_qty_1" onchange="updateSum();" id="input_value_<?php echo $i; ?>">

 //(2)

    <input type="text" value="<?php echo $choice3['price_name']; ?>" name="color[<?php echo $i; ?>][price_name]" readonly="readonly" class="color_qty_2">

 //(3)

    <input type="text" value="<?php echo $choice3['price']."€"; ?>" name="xrwmas" readonly="readonly" class="color_qty_2" id="price_<?php echo $i; ?>">  


然后我们只需要按类获取一个元素并计算其长度的 JS,然后你就可以看到它适用于无限输入。


 function updateSum(value,id) {

 

    var elements = document.getElementsByClassName('colorqty').length;

    var input_val = 0;

    var price_val = 0;

    var multipl = 0;

    var output = 0;

    var i = 0;

    while(i < elements ) {

                        

        price_val = document.getElementById('price_'+[i]).value;

        input_val = document.getElementById('input_value_'+[i]).value;

        if(input_val != null){ 

        multipl = price_val*input_val;

        output += multipl ;

                        

        document.getElementById('a3').value = !Number.isNaN(output) ? output : 0

            }

          i ++;

          }

     }



查看完整回答
反对 回复 2023-05-11
  • 2 回答
  • 0 关注
  • 116 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信