1. <legend id='cpcg4'><style id='cpcg4'><dir id='cpcg4'><q id='cpcg4'></q></dir></style></legend>

      1. <tfoot id='cpcg4'></tfoot>
        <i id='cpcg4'><tr id='cpcg4'><dt id='cpcg4'><q id='cpcg4'><span id='cpcg4'><b id='cpcg4'><form id='cpcg4'><ins id='cpcg4'></ins><ul id='cpcg4'></ul><sub id='cpcg4'></sub></form><legend id='cpcg4'></legend><bdo id='cpcg4'><pre id='cpcg4'><center id='cpcg4'></center></pre></bdo></b><th id='cpcg4'></th></span></q></dt></tr></i><div id='cpcg4'><tfoot id='cpcg4'></tfoot><dl id='cpcg4'><fieldset id='cpcg4'></fieldset></dl></div>
          <bdo id='cpcg4'></bdo><ul id='cpcg4'></ul>

        <small id='cpcg4'></small><noframes id='cpcg4'>

        JavaScript 类型转换:(true &amp;&amp; 1) vs (true

        时间:2023-08-07
        <legend id='JVpLg'><style id='JVpLg'><dir id='JVpLg'><q id='JVpLg'></q></dir></style></legend>
        <i id='JVpLg'><tr id='JVpLg'><dt id='JVpLg'><q id='JVpLg'><span id='JVpLg'><b id='JVpLg'><form id='JVpLg'><ins id='JVpLg'></ins><ul id='JVpLg'></ul><sub id='JVpLg'></sub></form><legend id='JVpLg'></legend><bdo id='JVpLg'><pre id='JVpLg'><center id='JVpLg'></center></pre></bdo></b><th id='JVpLg'></th></span></q></dt></tr></i><div id='JVpLg'><tfoot id='JVpLg'></tfoot><dl id='JVpLg'><fieldset id='JVpLg'></fieldset></dl></div>
        • <bdo id='JVpLg'></bdo><ul id='JVpLg'></ul>
            <tbody id='JVpLg'></tbody>

          <small id='JVpLg'></small><noframes id='JVpLg'>

          <tfoot id='JVpLg'></tfoot>

                  本文介绍了JavaScript 类型转换:(true &amp;&amp; 1) vs (true | | 1)的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

                  问题描述

                  JavaScript 是非严格类型的语言,例如 Java.

                  我们知道,它根据上下文转换结果的值:

                  "2" + "3" 结果 "23"

                  "2" * "3" 结果 6

                  这个比较清楚,可以理解.

                  我只是尝试了以下表达式并感到困惑:

                  真 &&1 结果 1
                  真||1 结果

                  为什么第一个给出数字,第二个给出布尔值?

                  考虑到 JavaScript 转换规则,由于 boolean 表达式的上下文,我希望在这两种情况下都能得到 boolean 值.

                  解决方案

                  检查 Douglas Crockford 的网站,它说:

                  <块引用>

                  &&运算符通常称为逻辑与.它也可以称为警卫.如果第一个操作数为 false、null、未定义,"(空string) 或数字 0 则返回第一个操作数.否则,它返回第二个操作数.这提供了一种方便的编写方式空检查:

                  var value = p &&p.名称;/* 名称值只会从p 如果 p 有值,则避免错误.*/

                  <块引用>

                  ||运营商通常是称为逻辑或.它也可以称为默认值.如果第一个操作数为 false、null、未定义、""(空字符串)或数字 0,然后它返回第二个操作数.否则,它返回第一个操作数.这提供了一种指定默认值的便捷方式:

                  值 = v ||10个;/* 使用 v 的值,但如果 v 没有值,改用 10.*/

                  JavaScript is non-strictly typed language as Java,for example.

                  As we know, it converts value of result dependently upon context:

                  "2" + "3" results "23"

                  "2" * "3" results 6

                  This is quite clear and OK for understanding.

                  I just tried following expressions and got confused:

                  true && 1 results 1
                  true || 1 results true

                  Why the first gives Number and the second gives boolean?

                  Considering JavaScript conversion rules,I expect to get boolean values in both cases,due to boolean context of expression.

                  解决方案

                  Check Douglas Crockford's site, it says:

                  The && operator is commonly called logical and. It can also be called guard. If the first operand is false, null, undefined, "" (the empty string), or the number 0 then it returns the first operand. Otherwise, it returns the second operand. This provides a convenient way to write a null-check:

                  var value = p && p.name; /* The name value will only be retrieved from
                  p if p has a value, avoiding an error. */
                  

                  The || operator is commonly called logical or. It can also be called default. If the first operand is false, null, undefined, "" (the empty string), or the number 0, then it returns the second operand. Otherwise, it returns the first operand. This provides a convenient way to specify default values:

                  value = v || 10; /* Use the value of v, but if v doesn't have a value,
                  use 10 instead. */
                  

                  这篇关于JavaScript 类型转换:(true &amp;&amp; 1) vs (true | | 1)的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持html5模板网!

                  上一篇:转换“浮动";到没有 Float32Array 的 Javascript 下一篇:为什么“valueAsNumber"返回 NaN 作为值?

                  相关文章

                  最新文章

                  <legend id='J6IQR'><style id='J6IQR'><dir id='J6IQR'><q id='J6IQR'></q></dir></style></legend>

                1. <tfoot id='J6IQR'></tfoot>
                    <bdo id='J6IQR'></bdo><ul id='J6IQR'></ul>
                2. <small id='J6IQR'></small><noframes id='J6IQR'>

                3. <i id='J6IQR'><tr id='J6IQR'><dt id='J6IQR'><q id='J6IQR'><span id='J6IQR'><b id='J6IQR'><form id='J6IQR'><ins id='J6IQR'></ins><ul id='J6IQR'></ul><sub id='J6IQR'></sub></form><legend id='J6IQR'></legend><bdo id='J6IQR'><pre id='J6IQR'><center id='J6IQR'></center></pre></bdo></b><th id='J6IQR'></th></span></q></dt></tr></i><div id='J6IQR'><tfoot id='J6IQR'></tfoot><dl id='J6IQR'><fieldset id='J6IQR'></fieldset></dl></div>