如何解决将字符串转换为数字 - parseInt() vs Number();
为什么在这种情况下,我想将字符串转换为数字 parseInt() 有效但 Number() 无效?
parseInt(this.element.style.left) << it works
Number(this.element.style.left) << it doesn't,there is NaN
解决方法
使用parseInt:
如果 parseInt 遇到一个不是指定基数中的数字的字符,它会忽略它和所有后续字符,并返回解析到该点的整数值。 parseInt 将数字截断为整数值。允许前导和尾随空格。
相反,Number
尝试将整个参数解析为数字。
例如,style.left
以 px
结尾,parseInt('12px')
有效,因为 px
可以被 parseInt
忽略。但是 Number('12px')
不起作用,因为 '12px'
的所有字符都不能解释为数字。
parseInt
跳过无效字符(并在那里停止解析),评估到目前为止已解析的内容。
Number
在任何地方都有任何无效字符时,根本无法解析。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。