vue.js - javascript小数类型求和运算问题
PHP中文网
PHP中文网 2017-04-11 12:44:57
[JavaScript讨论组]

下面一段代码是vuejs的一个求和:

sum: function () {
                    var totalAmount = 0;
                    for (var i = 0, length = this.items.length; i < length; i++) {
                        var item = this.items[i];
                        if (item.selected === true) {
                            totalAmount += item.price;
                        }
                    }
                    return totalAmount;
                }

其中item.price是从后台数据库读取的数据,当item.price时整数类型的时候,totalAmount可以正常进行求和运算,当改为小数decimal的时候,totalAmount不是进行加法运算,而是像字符串一样把每个数连起来。
问题:
小数怎么做才能让它做加法运算?

PHP中文网
PHP中文网

认证高级PHP讲师

全部回复(4)
天蓬老师

你可以用typeof 判断一下priced的类型,我估计是string。如果是string 你可以用Number(price) 或者price-0转换一下格式.

巴扎黑

外部加载的都是字符串格式,需要显式转换。就是整数也最好显式转换以保证。
当然这个转换到底放什么地方就值得思考啦,因为这个数据是从数据库加载的,如果处理加载的后台恰当,其实可以返回合适的数据结构的,比如采用json格式时,返回的数据可以是数值类型的。
否则你需要自己在使用前进行显式转换。

黄舟
totalAmount += item.price;
totalAmount +=  +item.price; 改成数字进行运算可以吗
高洛峰

javascript作为弱类型语言经常会把数字当成字符串,直接加运算会当成拼接,所以先要用number对象转为数字类型,最简单的办法就是将这个可能是字符串的数字-0,会自动转为数字类型

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号