西西木科技丨Shopify开发机构 2022-09-18 02:02 采纳率: 96.4%
浏览 64
已结题

js根据显示的div获取所有productprice并相加

js根据显示的div获取所有productprice并相加
需要获取所有display不等于none的productprice的值并相加
以这个为例 $79.99 + $70.00 + $39.99 + $39.99 的金额就是$229.97

<div class="container"
     id="finalform"
     style="">
    <div class="product-boxx"
         id="product-laptop"
         style="">
        <p class="productprice">$79.99 USD</p>
    </div>
    <div class="product-boxx"
         id="product-monitor"
         style="display:none;">
        <p class="productprice">$69.99 USD</p>
    </div>
    <div class="product-boxx"
         id="product-lapmon"
         style="display:none;">
        <p class="productprice">$99.99 USD</p>
    </div>
    <div class="product-boxx"
         id="product-monitor2"
         style="display:none;">
        <p class="productprice">$89.99 USD</p>
    </div>
    <div class="product-boxx"
         id="product-light"
         style="">
        <p class="productprice">$70.00 USD</p>
    </div>
    <div class="product-boxx"
         id="product-pad"
         style="">
        <p class="productprice">$39.99 USD</p>
    </div>
    <div class="product-boxx"
         id="product-micro"
         style="">
        <p class="productprice">$39.99 USD</p>
    </div>

</div>

  • 写回答

4条回答 默认 最新

  • CSDN专家-showbo 2022-09-18 14:13
    关注

    jQuery或原生js示例如下

    <div class="container"
         id="finalform"
         style="">
        <div class="product-boxx"
             id="product-laptop"
             style="">
            <p class="producttitle">Laptop</p>
            <p class="productprice">$79.99 USD</p>
        </div>
        <div class="product-boxx"
             id="product-monitor"
             style="display:none;">
            <p class="producttitle">Monitor</p>
            <p class="productprice">$69.99 USD</p>
        </div>
        <div class="product-boxx"
             id="product-lapmon"
             style="display:none;">
            <p class="producttitle">Laptop</p>
            <p class="productprice">$99.99 USD</p>
        </div>
        <div class="product-boxx"
             id="product-monitor2"
             style="display:none;">
            <p class="producttitle">Laptop</p>
            <p class="productprice">$89.99 USD</p>
        </div>
        <div class="product-boxx"
             id="product-light"
             style="">
            <p class="producttitle">Laptop Light</p>
            <p class="productprice">$70.00 USD</p>
        </div>
        <div class="product-boxx"
             id="product-pad"
             style="">
            <p class="producttitle">Laptop pad</p>
            <p class="productprice">$39.99 USD</p>
        </div>
        <div class="product-boxx"
             id="product-micro"
             style="">
            <p class="producttitle">Laptop</p>
            <p class="productprice">$39.99 USD</p>
        </div>
        <input type="number" id="finalprice">
    </div>
    
    
    <script src="https://g.csdnimg.cn/??lib/jquery/1.12.4/jquery.min.js"></script>
    <script>
        var sum = 0;
    
        //jQuery
        $('#finalform .product-boxx:visible p.productprice').each(function () {
            sum += parseFloat(this.innerText.substring(1));
        });
        /*//原生JS
        document.querySelectorAll('.product-boxx').forEach(item => {
            if (item.style.display != 'none') {
                sum += parseFloat(item.querySelector('p.productprice').innerText.substring(1));
            }
        })
        */
    
        sum = sum.toFixed(2);//保留2位小数,防止浮点数计算精度丢失
        alert(`总价为$${sum} USD`)
    </script>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(3条)

报告相同问题?

问题事件

  • 系统已结题 9月27日
  • 已采纳回答 9月19日
  • 创建了问题 9月18日

悬赏问题

  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)
  • ¥15 AIC3204的示例代码有吗,想用AIC3204测量血氧,找不到相关的代码。