1,同样的代码使用firefox运行不会报错,正常运行。

2,同样的代码使用google chrome 有时候会误报网页?

如下:代码可以在 firfox edge正常运行,在chrome  opera 运行报错。应该是兼容性问题。

代码:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <script>
         function BinaryTree(){
            //初始化节点对象,包括3个属性
            var Node=function(key){
                this.key=key;
                this.left=null;
                this.right=null;
            };

var root=null;//根节点

//给当前节点添加左右孩子。
            var insertNode = function(node,newNode){
                //如果节点小于父节点,放在左边作为左孩子
                if (newNode.key<node.key) {
                    if (node.left===null) {
                        node.left=newNode;
                    }else{
                        insertNode(node.left,newNode);
                    }
                    //否则就放右边,作为右孩子
                }else{
                    if (node.right===null) {
                        node.right=newNode;
                    }else{
                        //递归,继续添加左右孩子节点。
                        insertNode(node.right,newNode);
                    }
                }
            }

//判断根节点是否为空。
            this.insert=function(key){
                var newNode=new Node(key);
                if (root===null) {
                    root=newNode;
                }else{
                    //给当前节点添加左右孩子节点。
                    insertNode(root,newNode);
                }
            }
         }

var nodes=[8,3,10,1,6,14,4,7,13];
         var BinaryTree=new BinaryTree();
         nodes.forEach(function(key){  //控制台,鼠标悬停key未定义,也不会往里面执行代码
            BinaryTree.insert(key);
         });
    </script>
</body>
</html>

====================

逻辑操作符  &&与  ||或  !非
一,&&与
只要有一个条件不成立就返回 false。
只要有一个条件不成立就返回 false。从第一个开始,一旦遇到false,就不会继续往下读取,直接返回当前操作数。

在有一个操作数不是返回布尔值的情况,那么逻辑与操作就不一定返回值。此时遵循以下几个规则:

1,如果第一个操作隐式类型转换后为true,则返回第二个操作数
    var a=10;
    var b=20;
    var c=30;
    var d;
    var name=null;
    var str="abc";
    console.log(a<b && a<c);  /*全部true,返回最后一个true*/
    console.log(str && c);  /*30 */
    /*str="abc" 这里有一个隐式类型转换 Boolean(str)返回值:true。
     Boolean(c)=Boolean(30) 隐式类型转换 返回值:true。返回第二个值,这里的值是30*/

var a ,b;
     console.log(null && undefined && 0); // 返回0 隐式类型转换全部false,则返回最后一个操作数。
     console.log(a && b); //返回undefined

console.log( c && 50 && str);  /*abc*/
    /*隐式类型转换,Boolean(c)返回值:true。
    饮食类型转换 Boolean(str) 返回值:true。 如果&&与中全部值返回true,则返回最后一个true对象没有进行隐式类型转换的值*/

2,如果第一个操作数隐式类型转换值为:false。则返回第一个操作数,指的是第一个返回值为:false,如果返回值为:true则跳过。
    var a=10;
    var b=20;
    var c=30;
   console.log(a>c && 88 && a>b); /*返回值:false  这里a>c的返回值就是:false*/
   console.log(a>c && 88 && a>b); /*返回值:false  这里a>c是第一个返回值false的对象*/
   console.log(0 && 88);  /*返回0 ,隐式转换Boolean(0)返回值:false。所以返回值是0。返回第一个false的对象的原值。*/

3,如果有一个操作数null,则返回null。
   console.log("" && 88 && a<b);    /*返回空值,在控制台中就是一个空格*/

4,如果有一个操作数为:undefined,则返回undefined。
    var d;
   console.log(a<c && 88 && d);  /*d  这里的d在上文中没有进行定义赋值,所以返回d*/

5,如果有一个操作数为:NaN,则返回NaN。
    var str="abc";
   console.log( a<c && a+str && 88);  /*88   这里Boolean(a+str)  这里的+变成连字符,所以返回值为:true。所有经过隐式转换返回值都为:true,则值默认返回最后一个原值 88。*/

console.log( a<c && a*str && 88); /*NaN   Boolean(a*str) a=10 str="abc" 数字和字符串相乘,返回值:NaN非数值*/

6,&&与 可以操作任意类型的数据

google chrome调试的更多相关文章

  1. Google Chrome调试js代码,开发者工具之调试工具常用功能

    参考:Google Chrome调试js代码-http://www.open-open.com/lib/view/open1384785324165.html 重点:左下角一个{}括号图标按钮用于把杂 ...

  2. Google Chrome 调试

    [原文地址:http://www.cnblogs.com/QLeelulu/archive/2011/08/28/2156402.html ] 在Google Chrome浏览器出来之前,我一直使用F ...

  3. google chrome 调试技巧:监控 DOM 元素被修改

    在很多时候, 页面上一个元素的属于被修改.删除,子节点的添加与修改,很难一下找到对应的代码,在 google chrome 开发者工具里, 提供了对 DOM 元素的监控: 在 Elements 标签, ...

  4. Google Chrome 调试JS简单教程[更新]

    题外话,刚开始我写这篇内容只是将自己了解的一些知识放上来,不巧的是我分析了我的来访日志,很多朋友都有这个需求,为了大家没有白来,我决定充实下这篇文章.最近更新时间2014-02-14 chrome版本 ...

  5. Javascript系列: Google Chrome调试js代码(zz)

    你 是怎么调试 JavaScript 程序的?最原始的方法是用 alert() 在页面上打印内容,稍微改进一点的方法是用 console.log() 在 JavaScript 控制台上输出内容.嗯~, ...

  6. Google Chrome调试js代码

    你 是怎么调试 JavaScript 程序的?最原始的方法是用 alert() 在页面上打印内容,稍微改进一点的方法是用 console.log() 在 JavaScript 控制台上输出内容.嗯~, ...

  7. Google Chrome调试js入门

    平常在开发过程中,经常会接触到前端页面.那么对于js的调试那可是家常便饭,不必多说.最近一直在用火狐的Firebug,但是不知道怎么的不好使了.网上找找说法,都说重新安装狐火浏览器就可以了,但是我安装 ...

  8. Google Chrome调试常用快捷键

    Ctrl+Shift+I调出开发者工具 Ctrl+R刷新(界面显示不清楚,刷新后变清楚)

  9. Google Chrome Uncaught TypeError: object is not a function

    <html> <script type="text/javascript"> function testForm(){ alert("hello ...

随机推荐

  1. 将一个整数数组先按照因子数量排序,再按照数字大小排序,输出第k个数

    同小米OJ比赛题:现在有 n 个数,需要用因子个数的多少进行排序,因子个数多的排在后面,因子个数少的排在前面,如果因子个数相同那么就比较这个数的大小,数大的放在后面,数小的放在前面.现在让你说出排序之 ...

  2. 一个包含python和java环境的dockerfile

    现在一个项目中遇到python调用java的jar包的环境.为了方便发布,编写了这个dockerfile,作为基础镜像. #this docker file is used to build runt ...

  3. JMM(Java内存模型)是什么?为什么使用并发?

    1.计算机 首先我们需要讲解下计算机的模型:现代计算机模型是基于-冯诺依曼计算机模型 我们不用管输入和输出设备,最主要的就是中间计算器和存储器之间的交互,也就是CPU与主内存之间取数.存数. 大家会看 ...

  4. hdu 2609 字符串最小表示法 虽然不是很懂 还是先贴上来吧。/,。/

    还需要再消化一下这个算法.. 今天没有时间了,, 六级过了 就有大把时间 快活啊!#include<iostream> #include<cstdio> #include< ...

  5. 11-MySQL DBA笔记-MySQL的监控

    第11章 MySQL的监控 为什么我们需要监控呢?因为如果没有了监控,那么我们的服务可用性就无从度量,我们也无法及时地发现问题和处理问题.一个完善的监控体系,不仅需要进行实时的监控,也需要分析历史的监 ...

  6. Oracle导入数据后中文乱码的解决方法

    解决方法: 方法一. 1.在运行命令行输入regedit,打开注册表编辑器 2.找到HKEY_LOCAL_MACHINE\SOFTWARE\ORACLE\KEY_OraDb11g_home1 3.看N ...

  7. tinymce富文本是在modal框中弹出显示的问题

    记录一下,在用tinymce富文本的时候,由于是用在modal 上的,始终无法获取焦点,后来才发现问题出在tinymce在modal前创建了,所以导致这个问题,解决方案就是用 v-if="v ...

  8. C++ STL 之 deque

    deque 和 vector 的最大差异? 一在于 deque 允许常数时间内对头端进行元素插入和删除操作. 二在于 deque 没有容量的概念,因为它是动态的以分段的连续空间组合而成,随时可以增加一 ...

  9. Category与Extension详解

    自己做笔录 用来后来回顾.. (一) Category 1.什么是category category是objective-C 2.0之后添加的语言特性,别人口中的分类.类别其实都是指category. ...

  10. cent os 7.0 出现的问题解决方法

    https://www.jb51.net/article/34012.htm       python重编译,并进行安装 https://www.jb51.net/os/RedHat/211444.h ...