如何解决三元运算符条件
以下代码使用了reduce方法。它输出元素在数组中出现的次数。如果元素出现一次则只输出1,否则如果是重复项则添加。
let a = ["a","b","c","a","b"]
const t = a.reduce((aa,ll) => {
const count = aa[ll];
count
?
aa[ll] = count + 1 :
aa[ll] = 1
return aa
},{})
console.log(JSON.stringify(t))
// output
// { "a":2,"b":2,"c":1 }
问题是关于三元运算中的条件,特别是 count 变量。 count 变量如何分辨真假。
解决方法
这是我找到的答案。
“JavaScript 对象由键值对组成,其中键是唯一的。如果您尝试添加具有不同值的重复键,则该键的旧值将被新值覆盖。”
基本上计数变量正在检查新属性是否已经存在。
,这个概念分别称为"Truthy"和"Falsy"。即任何不同于 false
、0
、-0
、0n
、NaN
、null
、undefined
和 {{ 1}}(空字符串)可以在 Javascript 中计算为 ""
因此,您将 true
指定为对象 var counter = aa[ll]
中键 ll
的值。那要么是数字,要么是 aa
。如果是数字 undefined
,则为真;如果为 !== 0
或 0
,则为假。因此它可以用于三元运算符。根据 undefined
的值,第一个或第二个赋值的值将被返回(但被忽略)。赋值的返回值总是右边的值...
虽然你也可以在三元运算符的表达式中使用赋值,但我个人不会那样使用它,而是将这个赋值写成如下
counter
const t = a.reduce((aa,ll) => {
aa[ll] = (aa[ll] || 0) + 1;
return aa
},{})
如果是真值则返回 (aa[ll] || 0)
的值,否则返回 aa[ll]
。因此,在您的情况下,此表达式的结果将始终是数字 0
。然后将结果加 1(对于当前出现的 >= 0
)并将其分配回 ll
。这比您的原始代码短得多,恕我直言,可读性更高
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。