js基础知识--变量类型和变量计算

时间:2022-12-19 07:52:31

提问:

  1. JS中使用typeof能得到的哪些类型
  2. 何时使用===何时使用==
  3. JS中有哪些内置函数
  4. JS变量按照存储方式区分为哪些类型,并描述其特点
  5. 如何理解JSON

涉及知识点:(1)变量类型

      • 值类型 和 引用类型
      • typeof运算符详解  

    ====》值类型:  

      js基础知识--变量类型和变量计算

      【如上栗子,值类型的特点:每个变量都会存储一个地址,不会相互影响】

    ====》引用类型:

      js基础知识--变量类型和变量计算

      【引用类型包括:对象,数组,函数】

      【如上栗子,a和b的指针指向同一个对象地址,共用内容,所以里面的内容会随着变化。  引用类型的特点:可以无限扩大属性(比如说,var a ={age:20,name:james,address:china....})】

  

      注意:  js中的数据类型有以下几种:

        基本类型:Number Boolean  String  undefined null

        引用类型:Object  Function Array

    ====》typeof运算符:

      js基础知识--变量类型和变量计算

      【typeof总共有6中形式(undefinend,string,number,boolean.object,function),比较特殊的是null,就算是空,也是一个object类型。如上,前4种值类型,typeof都区分的出来;针对上面的5-8,typeof只能区分出这个函数属于function类型】

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

      (2)变量计算-强制类型转换(值类型)

      • 字符串拼接
      • ==运算符
      • if语句
      • 逻辑运算

      

    ==》字符串拼接        

      js基础知识--变量类型和变量计算

      【如上,第二行代码,字符串拼接时,对数值进行强制类型转换,与后面一起合并成一个字符串】

    ==》==运算符

       js基础知识--变量类型和变量计算

      【如上,第一行代码:100和‘100’都会转换成true;第二行代码:0和‘ ’都会转换成false;第三行代码:null和undefined都会转换成false  ==要慎用,这里如果改为===,结果就不同了】

    ==》if语句

       js基础知识--变量类型和变量计算

      【如上,1-4行代码:a的值为true,所以会执行if语句里面的内容;5-8行代码:b的值为100,这里被强制转换成布尔值类型(true),所以也会执行if语句里面的内容;9-12行代码:c的值为空,这里被强制转换成布尔值类型(false),所以不会执行if语句里面的内容】

    ==》逻辑运算

      js基础知识--变量类型和变量计算

      【如上,第一行代码:与运算符,(10与0),这里会把10强制转换成布尔值(true),即(true与0),所以会执行后面的值0】

      【第二行代码:或运算符,(' '或'abc'),这里会把' '强制转换成布尔值(false),即(false或'abc'),所以也会执行后面的值'abc'】

      【第三行代码:非运算符,因为window.abc未定义,所以是个false值,而前面加个!号,就会把false值转换成true值】

解答:

  1. JS中使用typeof能得到的哪些类型

    答:undefined,string,number,boolean,object,function

   2.  何时使用===何时使用==

    答:

      js基础知识--变量类型和变量计算

      所以只有在判断对象中某个属性的时候用==,其他地方都使用===

    3.  JS中有哪些内置函数

      答:

      js基础知识--变量类型和变量计算

      【补充,Math是对象而不是函数】

    4.  JS变量按照存储方式区分为哪些类型,并描述其特点

    答:

      js基础知识--变量类型和变量计算

      【引用类型的值赋值只是一个变量指针的赋值,而不是真正的一个值的拷贝,他们的值的修改是相互干预的】

      

(1)值类型:1、占用空间固定,保存在栈中(当一个方法执行时,每个方法都会建立自己的内存栈,在这个方法内定义的变量将会逐个放入这块栈内存里,随着方法的执行结束,这个方法的内存栈也将自然销毁了。因此,所有在方法中定义的变量都是放在栈内存中的;栈中存储的是基础变量以及一些对象的引用变量,基础变量的值是存储在栈中,而引用变量存储在栈中的是指向堆中的数组或者对象的地址,这就是为何修改引用类型总会影响到其他指向这个地址的引用变量。)

2、保存与复制的是值本身

3、使用typeof检测数据的类型

4、基本类型数据是值类型

(2)引用类型:1、占用空间不固定,保存在堆中(当我们在程序中创建一个对象时,这个对象将被保存到运行时数据区中,以便反复利用(因为对象的创建成本通常较大),这个运行时数据区就是堆内存。堆内存中的对象不会随方法的结束而销毁,即使方法结束后,这个对象还可能被另一个引用变量所引用(方法的参数传递时很常见),则这个对象依然不会被销毁,只有当一个对象没有任何引用变量引用它时,系统的垃圾回收机制才会在核实的时候回收它。)

2、保存与复制的是指向对象的一个指针

3、使用instanceof检测数据类型

4、使用new()方法构造出的对象是引用型

   5.  如何理解JSON

     答:

      js基础知识--变量类型和变量计算

      第4行代码:把对象变成字符串;

      第5行代码:把字符串变成对象