javascript - function(){} == true || function(){} != true;function(){}不为true?

查看:74
本文介绍了javascript - function(){} == true || function(){} != true;function(){}不为true?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

1 描述:

今天看到看到红宝书第27页有写到: 任何对象转换为true;那么实验了一下:

好像没错, function(){} 为 true!

2 后来:

呵呵,好像并不是这样,闲的蛋疼的我又来了一波:

3 问题:

那么问题是
function(){} 为什么用双等判断的时候 为false!

解决方案

值等于是比较值的。
所以浏览器会先将运算符两边的变量/表达式的值先算出来,并转换成同类型(基本类型)的形式进行比较。
(function(){})表达式的值通过valueOf()/toString()来计算,
你可以看一下这两个返回的值是什么,并且看一下返回值可否转换成为true。
抱歉打脸,今天有的别的事情。
-----------------update-----------------
更新:
@Starch
像这种比较运算符或者一些基本概念问题,我有一个推荐:
JavaScript 5
http://ecma-international.org...
JavaScript 6
http://ecma-international.org...
你可以到对应版本的JavaScript中寻找你需要的解释。
回到本题,先来看一下 == 运算符它的原理吧:


这个就是浏览器在遇到 == 时采取的操作步骤,我来翻译一下是什么意思:

==运算符是这样被计算的:
1 让左引用(lref: left reference)成为正在计算的表达式左侧的值。
2 将左值(lval:left value)赋值为 GetValue(lval)。
3 让右引用(rref: right reference)成为正在计算的表达式右侧的值。
4 将右值(rval:left value)赋值为 GetValue(rval)。
5 返回执行rval == lval 抽象值比较的结果(参见 11.9.3)

那么在11.9.3,又是怎么规定abstract equality comparison 的呢?


这就比较长了,但是也很详细。这就不一条一条的解释了。
直接看第七条就好了:
If Type(y) is Boolean, return the result of the comparison x == ToNumber(y).
那么结果就变成了:
function() {} == 1
然后再看第9条:
If Type(x) is Object and Type(y) is either String or Number,
return the result of the comparison ToPrimitive(x) == y.
最后参考我一开始写的就好了。

答案就是false。

这篇关于javascript - function(){} == true || function(){} != true;function(){}不为true?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆