javaScript 数据类型

数据类型分类

  1. 基础数据类型

    undefined

    Undefined 类型只有一个值,即特殊的 undefined。在使用 var 声明变量但未对其加以初始化时,这个变量的值就是 undefined

    /*
     在未申明的请求下直接使用会报错, 在使用未声明的变量时,
    可以使用typeof,这样操作是安全的
     */
    console.log(a); // undefined 因为var 声明会出现变量提升
    var a;
    console.log(b); // 报错 因为const声明会产生一个暂时性死区,不可以在申明前调用
    let b;
    
    null

    类似于空指针(typeof null 返回 object),值为null,更多的情况下来表示这个变量为空,语义上跟undefined有明显区别。

    /*
     null 在值判断时候跟undefined 是相等的,是因为,都转成了number,值均为0。
     尽管 null 和 undefined 有这样的关系,但它们的用途完全不同。无论在什么情况下 都没有必要把一个变量的值显式地设置为 undefined(因为如果使用typeof 返回 undefined,没法判断是未定义还是未赋值),可是同样的规则对 null 却不适用。换句话说, 只要意在保存对象的变量还没有真正保存对象,就应该明确地让该变量保存 null 值。这样做不仅可以 体现 null 作为空对象指针的惯例,而且也有助于进一步区分 null 和 undefined。
     */
     null == undefined // true
     null === undefined // false
    
    Boolean
    据类型转发为true的值转换为falsede zhi
    Booleantruefase
    String任何非空字符串“”
    Number任何非零数字(包含Infinity0 和 NaN
    Object任何对象null
    undefinedundefined
    Number
    // 二进制 8进制 十进制 16进制
    var a = 010; // 8
    var b = 0x12 // 18
    
    // 浮点数 由于浮点数存储的空间比整数大 ECMA 会适机将浮点转换为整数
    // 关于浮点数值计算会产生舍入误差的问题,感兴趣可以查一下 JavaScript 浮点进度问题
    var c = 10.0 // 会变成整数10
    // 科学计数法
    var d = 3e2; // 3 * 10的2次方即为300
    
    // 数字中的特殊类型 NaN not a number
    NaN === NaN // false
    window.isNaN(NaN) // true
    Number.isNaN(NaN) // true
    window.isNaN('a') // true 因为 会先将`a`执行Number(a)
    Number.isNaN('a') // false 只有NaN才是ture
    // 常用的数值转换方法Number parseInt parseFloat
    var num1 = Number("Hello world!");// NaN
    var num2 = Number(''); // 0
    var num3 = Number("000011"); // 11
    var num4 = Number(true);
    
    // parseInt 跟看开头是否为数字如果是那么取到数字最后一位
    var num1 = parseInt("1234blue"); // 1234
    var num2 = parseInt(""); // NaN
    var num3 = parseInt("0xA"); // 10 16进制
    var num4 = parseInt(22.5); // 22
    var num5 = parseInt("070"); // 56 8进制
    var num6 = parseInt("70"); // 70
    // parseInt 第二个参数为进制
    var num1 = parseInt("AF", 16); //175
    var num1 = parseInt("AF"); // NaN
    // parsefloat 同上 不同点在于可以取浮点数
    
    String

    字符串的内容是不可以变的,一旦创建,它的值就不能改变,要改变的话需要先销毁当前的,再创建

    var lang = "Java";
    lang = lang + "Script";
    // 首先创建一个能容纳 10 个字符的 新字符串,然后在这个字符串中填	充"Java"和"Script",
    // 最后一步是销毁原来的字符串"Java"和字 符串"Script",因为这两个字符串已经没用了。
    
  2. 引用数据类型

    Object

    存储的为地址的引用

    // 实例化
    var person  = new Object;
    person.name = 'javascript';
    // 对象字面量表示法
    var person2 = {
    	name: 'javascript'
    };
    var obj1 = { x:2 }
    var obj2 = obj1;
    obj2.x = 3;
    console.log(obj1, obj2); // { x:3 } { x:3 }
    

    使用defineProperty 来定义对象属性

    Object.defineProperty(obj, prop, descriptor)

    • value
    • writable 为true 才可以赋值,默认为false
    • configurable 当且仅当该属性的 configurable 为 true 时,该属性描述符才能够被改变,同时该属性也能从对应的对象上被删除。默认为 false
    • enumerable 当且仅当该属性的enumerable为true时,该属性才能够出现在对象的枚举属性中。默认为 false。
    • get 一个给属性提供 getter 的方法,如果没有 getter 则为 undefined。当访问该属性时,该方法会被执行,方法执行时没有参数传入,但是会传入this对象
    • set 一个给属性提供 setter 的方法,如果没有 setter 则为 undefined。当属性值修改时,触发执行该方法。该方法将接受唯一参数,即该属性新的参数值。
    Array

    常见的数组方法参见 数组方法

    Date

    时间对象

    var date = new Date();
    // 日期格式化方法
    // toDateString()——以特定于实现的格式显示星期几、月、日和年;
    date.toDateString(); // Sun May 26 2019
    // toTimeString()——以特定于实现的格式显示时、分、秒和时区; 
    date.toTimeString(); // 15:27:53 GMT+0800 (中国标准时间)
    // toLocaleDateString()——以特定于地区的格式显示星期几、月、日和年;
    date.toLocaleDateString(); // 2019/5/26
    // toLocaleTimeString()——以特定于实现的格式显示时、分、秒;
    date.toLocaleTimeString(); // 下午3:27:53
    // toUTCString()——以特定于实现的格式完整的 UTC 日期。
    date.toUTCString(); // Sun, 26 May 2019 07:27:53 GMT
    
    RegExp
    1. 模式
      g:表示全局(global)模式,即模式将被应用于所有字符串,而非在发现第一个匹配项时立即 停止
      i:表示不区分大小写(case-insensitive)模式,即在确定匹配项时忽略模式与字符串的大小写;
      m:表示多行(multiline)模式,即在到达一行文本末尾时还会继续查找下一行中是否存在与模式匹配的项。
    Function

    函数实际 上是对象。每个函数都是 Function 类型的实例,而且都与其他引用类型一样具有属性和方法。由于函 数是对象,因此函数名实际上也是一个指向函数对象的指针,不会与某个函数绑定。

问题

关于数据类型的深拷贝操作,给定一个输入,将输入的内容深拷贝一份返回 ?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值