js学习之数据类型

  基础类型:number string boolean null undefined
  引用类型:object array function

  undefined值是派生自null值的(undefined == null); //true

  Boolean(message);
    数据类型 转换为true 转换为false
    Boolean true false
  String 任何非空字符串 ""(空字符串)
  Number 任何非零数字值 0和NaN
  Object 任何对象 null
  Undefined 不适用 undefined

  JavaScript 从左向右计算表达式。不同的次序会产生不同的结果:
    1、var x = 911 + 7 + "Porsche"; //918Porsche
    2、var x = "Porsche" + 911 + 7; //Porsche9117

  JavaScript 拥有动态类型。这意味着相同变量可用作不同类型:

  == 和 ===
    ==:称为等值符,当等号两边的类型相同时,直接比较值是否相等,若不相同,则先转化为类型相同的值,再进行比较;
    ===:称为等同符,当两边值的类型相同时,直接比较值,若类型不相同,直接返回false;

  null和undefined的区别
    undefined表示系统级的、出乎意料的或类似错误的值的空缺;表示缺少值,此处应该有值,但没有定义。例如:var a; a就会显示undefined
    null表示程序级的、正常的或在意料之中的值的空缺; 一般多使用null。

  Infinity和NaN
    都是number类型,
    Ifinity 表示无限大,超过JS的number所能够表示的最大值

    NaN 表示not a number,无法计算的结果。
      1.任何涉及NaN的操作(例如NaN*10,NaN/10)都会返会NaN。
      2.NaN与任何数值都不相等,包括NaN本身。
        NaN === NaN //false
        //唯一识别NaN的方法
          isNaN(NaN) //true
        isNaN():检测是否为非数字
          isNaN(null) //false
          null不是数值,该方法先尝试转为数值再判断,null转为数值是0,所以结果是false.
          isNaN(true); // false
          isNaN(null); // false
          isNaN(37); // false
          isNaN("37");// false
          isNaN("");// false: 空字符串被转换成0

  数值转换:

    number(),parseInt()和parseFloat()。 number()可以用于任何数据类型,而另外两个函数则专门用于把字符串转换为数值。

    console.log(0.1+0.2) //0.30000000000000004

    如果是Boolean,true和false将分别被转换为1和0。
    如果是数字值,只是简单传入和返回。
    如果是null值,返会0。
    如果是undefined,返回NaN。
    如果是字符串则较为复杂。
    parseInt()在转换字符串的时会忽略字符串前的空格,直至找到第一个非空格字符。如果第一个字符不是数字字符或者是负号,返回NaN。

    Boolean():他不会对引号里面的数字进行自动进行转换。
    Boolean(0);//false
    Boolean('');//false
    Boolean(' ');//true
    Boolean(null)//false

    String()和toString()的区别和应用
    String()和toString()都是将其他类型的变量转换为字符串类型。

    .toString()可以将所有的的数据都转换为字符串,但是要排除null 和 undefined

    console.log(1.toString());//这种写法会报错语法错误
      这是因为javascript引擎在解释代码时对于“1.toString()”认为“.”是浮点符号,但因小数点后面的字符是非法的,所以报语法错误;而后面的“1..toString()和1.2.toStirng()”写法,javascript引擎认为第一个“.”小数点,的二个为属性访问语法,所以都能正确解释执行;对于“(1).toStirng()”的写法,用“()”排除了“.”被视为小数点的语法解释,所以这种写法能够被解释执行;

数据类型的检测

  1、typeof:检测数据类型
    可以把数据类型当作字符串返回,返回值是一个字符串 所以 typeof(typeof(a)) //string
    typeof null; //"object" 因为特殊值null被认为是一个空的对象引用。
    局限:对于array、null和对象,typeof一律返回object。对此可以通过instanceof来区分。

    typeof对于基本数据类型判断是没有问题的,但是遇到引用数据类型(如:Array,返回abject)是不起作用的。

    instanceof:判断一个变量是否是某个对象的实例 返回一个boolean 值
    instanceof 运算符判断一个对象是否是另一个对象的实例。返回true或false
    instanceof 运算符用来检测 constructor.prototype 是否存在于参数 obj 的原型链上(或者说:检测obj的原型链上是否存在constructor.prototype )

    缺点:
      1.只适用于对象类型
      2.只要当前的这个类在实例的原型链上,检测出来的结果都是true

      console.log("1" instanceof String); //false(
      new Number(1) instanceof Number //true
      console.log(1 instanceof Number); //false
      console.log(true instanceof Boolean); //false
      console.log([] instanceof Array); //true
      console.log(function(){} instanceof Function); //true
      console.log({} instanceof Object); //true

  constructor :属性返回对创建此对象的数组函数的引用。
      var test=new Array();
      test.constructor==Array //true

      Object.prototype.toString.call()

      var a = Object.prototype.toString;

      console.log(a.call("aaa"));
      console.log(a.call(1));
      console.log(a.call(true));
      console.log(a.call(null));
      console.log(a.call(undefined));
      console.log(a.call([]));
      console.log(a.call(function() {}));
      console.log(a.call({}));

js学习之数据类型的更多相关文章

  1. JS学习笔记-数据类型

    最初的JS学习已经过去大半年的时间了,至此感觉对JS的使用与理解并非非常深入,因此在近期的工作之余也開始了新一轮的JS学习. 几天时间过去了,对于一些基础内容的学习还是非常有必要的,就从今天的又一次整 ...

  2. D3.js学习记录 - 数据类型【转】【新】

    1.变量 JAVASCRIPT的变量是一种类型宽松的语言.定义变量不用指定数据类型.而且还是动态可变的. var value = 100;value = 99.9999;value = false;v ...

  3. Javascript高级编程学习笔记(3)—— JS中的数据类型(1)

    前一段时间由于事情比较多,所以笔记耽搁了一段时间,从这一篇开始我会尽快写完这个系列. 文章中有什么不足之处,还望各位大佬指出. JS中的数据类型 上一篇中我写了有关JS引入的Script标签相关的东西 ...

  4. JS学习笔记(一)基本数据类型和对象类型

    js是一种弱类型的语言,所有的变量都用var进行声明,字符串用双引号或单引号括起来,常见基本数据类型为number,string,boolean等.如 var num = 123;或var num = ...

  5. Js学习(2)数据类型

    Js共有六种数据类型(ES6又增加了第七种Symbol类型的值): 原始类型:数值,字符串,布尔值 合成类型:对象(object):各种值组成的集合 其他undefined,null 对象又可以分成三 ...

  6. 【Knockout.js 学习体验之旅】(1)ko初体验

    前言 什么,你现在还在看knockout.js?这货都已经落后主流一千年了!赶紧去学Angular.React啊,再不赶紧的话,他们也要变out了哦.身旁的90后小伙伴,嘴里还塞着山东的狗不理大蒜包, ...

  7. JS 学习笔记--9---变量-作用域-内存相关

    JS 中变量和其它语言中变量最大的区别就是,JS 是松散型语言,决定了它只是在某一个特定时间保存某一特定的值的一个名字而已.由于在定义变量的时候不需要显示规定必须保存某种类型的值,故变量的值以及保存的 ...

  8. JS~JS里的数据类型

    JS里的数据类型,它虽然是个弱类型的语言,但它也有自己的规定的,它不会向其它语言那么,使用int来声明一个整形变量,而是使用 var,如果你是一个C#的开发者,你就会知道,原来C#现在也在和JS学,开 ...

  9. js基础--javaScript数据类型你都弄明白了吗?绝对干货

    欢迎访问我的个人博客:http://www.xiaolongwu.cn 数据类型的分类 JavaScript的数据类型分为两大类,基本数据类型和复杂数据类型. 基本数据类型:Null.Undefine ...

随机推荐

  1. Codeforces 777D:Cloud of Hashtags(水题)

    http://codeforces.com/problemset/problem/777/D 题意:给出n道字符串,删除最少的字符使得s[i] <= s[i+1]. 思路:感觉比C水好多啊,大概 ...

  2. 如何配置MySQL

    解压绿色版mysql,并改名为mysql5.7 运行CMD(管理员版本,否则没有权限) 运行完后 然后就把地址改为你存放mysql5.7下的bin目录 对于新版mysql5.7没有了data目录,我们 ...

  3. C++学习书籍推荐《C++编程思想第二版第一卷》下载

    百度云及其他网盘下载地址:点我 编辑推荐 “经典原版书库”是响应教育部提出的使用原版国外教材的号召,为国内高校的计算机教学度身订造的.<C++编程思想>(英文版第2版)是书库中的一本,在广 ...

  4. Vue快速学习_第三节

    过滤器 局部过滤器(组件内部使用的过滤器,跟django的很像, filters: {过滤器的名字: {function(val, a,b){}}} 全局过滤器(全局过滤器,只要过滤器一创建,在任何组 ...

  5. MyBatis:choose标签的用法

    <!-- 4.2 choose用法 需求: 在已有的sys_user表中,除了主键id外,我们认为user_name也是唯一的, 所有的用户名都不可以重复.现在进行如下查询:当参数id有值的时候 ...

  6. 【DFS的分支限界】(例题-算式等式)

    不知道DFS的请滚去 这里瞅一眼再说. -分支限界- 基本概念: 类似于回溯法,也是一种在问题的解空间树T上搜索问题解的算法.但在一般情况下,分支限界法与回溯法的求解目标不同.回溯法的求解目标是找出T ...

  7. list和list<map<String,object>>比较,不存在map的key赋值

    package com; import java.math.BigDecimal; import java.text.ParseException; import java.text.SimpleDa ...

  8. Loadrunner基本概念解析<一>

    学习性能测试前需要掌握的基本概念,以下做一个记录,本文会持续更新,我期望的是,用通俗简洁的语言来进行更好的理解. [基本概念如下:] ---并发用户数: 1️⃣错误的理解:    使用系统的全部用户数 ...

  9. dijkstra算法学习笔记

    dijkstra是一种单源最短路径算法,即求一个点到其他点的最短路.不能处理负边权. 最近某种广为人知的算法频繁被卡,让dijkstra逐渐成为了主流,甚至在初赛中鞭尸了SPFA(? dijkstra ...

  10. 洛谷P3877 [TJOI2010]打扫房间 解题报告

    首先整理一下条件: 1.恰好进出每个需打扫的房间各一次 2.进出每个房间不能通过同一个门 (其实前两个条件是一回事) 3.要求每条路线都是一个闭合的环线 4.每条路线经过的房间数大于2 让你在一个n* ...