zoukankan      html  css  js  c++  java
  • JS中的常量(基本数据类型)和内置对象

    JS中的基本数据类型:

    String 、number、null、boolean、undefined、symbol(ES6)

    object是复杂数据类型

    但是JS中的数据类型主要就是以上几种

    1、  利用typeof运算符时其中只有null是异常的,typeof(null)=object,所以在判断变量类型是否为null时要注意。同时利用typeof时对于没有声明的变量是不会报错的,返回值为undefined。全局变量和函数变量在没有声明时使用是会报错的,但是在对象中使用没有定义的属性是不会报错同样返回的是undefined。Function变量是具有length属性的,其长度为传入的参数的个数。

    2、  变量时弱类型的,即其本身是没有类型的,其值才是具有类型的。

    3、  对于number类型,

    (1)其中要注意的是NAN非数字的数字,用全局的函数isNAN()判断时会有问题,即对于非数字类型的变量其也会返回true,所以在使用时可以用以下方式判断NAN:

    ①a!=a

    ②利用ES6中的Number.isNAN();

    ③typeof(a)==’number’&&isNAN(a)

    (2)还有一个要注意的是+0,-0这两者在使用时是相等的但是在浏览器引擎上还是会有区别,区分二者可以利用:typeof(a)==typeof(b)&&1/a==1/b,+0、-0作为分母时会得到infinite和-infinite。在ES6中有Object.is()方法可用于判断两个变量是否相等。可用于上述情况。但是前者的方法的执行效率更好。

    (3)另外在JS中数字类型也是有最大和最小值的界定的安全范围的

    (4)判断变量是否为整数的方法:

         ①Number.isInteger(a),ES6中的方法

         ②typeof(a)==’number’&&a%1==0

         ③或者使用Mah.ceil(a)==a等类似的方法                                                            

    4、变量在复制和作为参数传递时会有引用传递和值传递之分:

       (1)值传递即普通的变量类型

       (2)引用传递,如对象和数组等幅值或者作为参数传递传递的是复制的引用会相会影响:

         Var a=[1,2,3];

         Var b=a;

         b.push(4);//a=[1,2,3,4];b=[1,2,3,4]

       

     但是当b重新赋值时:

      Var b=[4,5,6]//a=[1,2,3,4];b=[4,5,6]因为b的引用已经发生了改变不在是a数组的引用的复制。

    JS中的内置函数(对象)

    String()、Number()、Boolean()、RegExp()、Date()、Error()、Array()、

    Function()、Object()、symbol();类似于对象的构造函数

    1、这些内置函数构造的变量都是封装了基本类型值的对象如:

    Var a=new String(‘abb’); //typeof(a)=object

    除了利用Function()构造的变量通过typeof输出为function外其他均为object

    2、为了知道构造的变量的真实类型可以利用:

    Object.prototype.toString.call([1,2,3]);//”[object,array]”,后面的一个值即为传入参数的类型

    3、如果有常量形式(即利用基本数据类型)赋值给变量就不要用该方式来定义变量

  • 相关阅读:
    leetcode 10 正则表达式匹配(c++)
    基于.NetCore3.1系列 —— 日志记录之初识Serilog
    AspNetCore WebApi:Serilog(日志)
    .NET Core下的日志(3):如何将日志消息输出到控制台上
    Asp.Net Core用NLog记录日志操作方法
    .NET Core3.0 日志 logging-最好用的日志集合介绍
    .net core 3.1 使用nlog记录日志 NLog.Web.AspNetCore
    NetCore3.1 日志组件 Nlog的使用
    配置 ASP.NET Core 请求(Request)处理管道
    vue进入页面每次都调用methods里的方法
  • 原文地址:https://www.cnblogs.com/heshan1992/p/6250181.html
Copyright © 2011-2022 走看看