js 混合拼接应该用 () 还是 String() 方法处理计算优先级?

2020-04-02 22:13:17 +08:00
 lisisi

js 混合拼接的顺序差异,导致结果差别这么大,为什么 js 这么设计?要避免这种混合处理的差异,应该用 () 还是 String() 方法处理计算优先级?

3 * 0.3 + 1 + 'foo' => 1.9foo

'foo' + 3 * 0.3 + 1 => foo0.8999 九 99999 九 999991
2638 次点击
所在节点    JavaScript
13 条回复
wobuhuicode
2020-04-02 22:16:09 +08:00
这是合理的设计,JS 不是强类型语言,但是也是有类型的。 + 号是根据类型来进行运算的。
字符串拼接用 `string${a}` 这种语法就好了
lisisi
2020-04-02 22:22:30 +08:00
@wobuhuicode 不是 String() 和 toString() 吗?

小写 string${a} 是什么语法?
tyx1703
2020-04-02 22:31:25 +08:00
@lisisi 这是字符串模板,es6 的新语法
seki
2020-04-02 22:31:32 +08:00
1 楼说的是模板字符串
https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/template_strings

如果要问为什么这么设计,答案就是这是 js 糟粕部分。建议完全放弃加号拼接字符串的行为
xcstream
2020-04-02 23:00:31 +08:00
var a = 1
var b= `${a}`
SoloCompany
2020-04-03 00:03:39 +08:00
1. 能用 es6 尽量用 template string
2. 不能用 es6 的字符串串接可以选择
2.1 开头加一个 '' +
2.2 用 Array.prototype.join
rabbbit
2020-04-03 00:43:42 +08:00
哪个符号优先级高就算哪个

'foo' + 3 * 3 // "foo9"

然后不同类型相加会自动转换类型,就全乱套了.

'a' + 1 // a1
'a' + true // "atrue"
'a' + null // "anull"
'a' + undefined // "aundefined"

1 + true // 2
1 + undefined // NaN
1 + null // 1

[] + 1// "1"
[] + 'a' // "a"

{} + 1 // 1

({}) + 1 // "[object Object]1"

所以最好用模板字符串,而不是加号
xiangyuecn
2020-04-03 00:53:54 +08:00
乘法优先级比加法高,先运算乘法。相同的加法从左往右一路加过去。这个结果没毛病

另外一坨 9999 的,其实也没毛病。阅读: http://0.30000000000000004.com/
xiangyuecn
2020-04-03 01:08:50 +08:00


DOLLOR
2020-04-03 02:00:10 +08:00
3 * 0.3 + 1 + 'foo'
=> 0.8999999999999999 + 1 + 'foo'
=> 1.9 + 'foo'
=>"1.9foo"


'foo' + 3 * 0.3 + 1
=>'foo' + 0.8999999999999999 + 1
=>"foo0.8999999999999999" + 1
=>"foo0.89999999999999991"

为什么这么设计,当然是因为先乘除后加减,更符合学过数学的人的思维。
而“+”既可以作为数学的加法运算,也可以作为字符串的拼接运算。当你用“+”来混合操作 String 和 Number 时,会把 Number 转为 String,再跟另一个 String 做拼接运算。

要尽量避免用数学操作符来直接操作非 Number 数据类型,以免出现不可预知的隐式转换。
字符串的拼接尽量用字符串模板(`${}`),避免用“+”拼接。
citrix
2020-04-03 09:05:26 +08:00
开启 eslint-config-airbnb, 这些编程规范的事情交给 lint 来 fix 就好了
christin
2020-04-03 10:47:28 +08:00
+既可以用作数字运算也可以字符串拼接。第一个前面是数字后面是字符就先数字运算再字符拼接。第二个 开始就是字符就一直字符拼接
crz
2020-04-03 11:11:31 +08:00
@rabbbit 类型转换的问题模板字符串其实不解决

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/658808

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX