第一部分:Javascript中的数据类型

javascript中 基本数据类型有 五种, 数字 number 字符串 string  布尔 boolean  未定义 undefined 空值 null

另外有引用数据类型三种: 对象 object   数组 array  函数 function

在ES6中,新增了三种数据类型  Set Map 和 Symbol

第二部分:如何判断一个数据的数据类型呢?

方法一:使用typeof 方法

示例表明,使用typeof 方法可以判断出 number, string, boolean, undefined, object, symbol, function这7种结果,二话不说 上代码

typeof 1  // number

typeof 'a' //  string

typeof false // boolean

typeof undefined  // undefined

typeof [] // object

typeof {} // object

typeof null // object

const a = function(){}

typeof a // function 

typeof new Set()  // object

typeof new Map() // object

typeof Symbol // function

typeof Symbol() // symbol

方法二: 利用instanceof 用来判断构造函数,注意 只有引用类型的数据才可以使用 instanceof 方法,

基本类型中的 数字 字符串 布尔值 可以利用 new 方法生成对象

比如 new Number(1) 就是一个对象了,就可以使用instanceof 方法

new Number(1) instanceof Number // true

new String('str') instanceof String  // true 

new Boolean(false) instanceof Boolean // true

[] instanceof Array // true

{} instanceof Object // true

console.log instanceof Function // true

console.log instanceof Function // true

new Map() instanceof Map // true

new Set() instanceof Set() // true

那么以此就可以编写一个判断数据类型的方法啦

function getType(param) {
if( arguments.length === 0 ) {
return '请传入参数'
} if(param === null) {
return 'null'
} const type = typeof param if( type !== 'object') { // 基本类型数据或symbol或function
return type
} else { // 引用类型
if(param instanceof Array){
return 'array'
} else if(param instanceof Set ) {
return 'set'
} else if(param instanceof Map) {
return 'map'
} else if(param instanceof Object) {
return 'object'
}
}
}

附上测试结果:

getType(1) // number

getType('a') // string

getType(false) // boolean

getType([]) // array

getType(null) // null

getType(undefined) // undefined

getType({}) // object

getType(new Set()) // set

getType(new Map())  // map

getType(Symbol())  // symbol

getType(Symbol) // function

getType(console.log)  // function

3.下面来讲讲 数据类型及其对应的构造函数

在Javascript的数据类型中,除了 null ,undefined其他都有自己的构造函数

比如 数字的构造函数 Number, 字符串构造函数 String, 布尔 Boolean   , 对象 Object, 函数 Function , Set()    Set, Map()  Map

在基本类型中  可以使用 Number(1)  === 1 , String('a') === 'a',  Boolean(false) === false

而 new Number(1) 会得到一个对象,这个对象只有一个属性__proto__ 这个属性指向构造函数 Number

const num = new Number(1) 

typeof num // 'object'

typeof Number(1) //  number

num.__proto__ === Number.prototype

// Number.ptototype 下有多个方法 valueOf, toString,toFixed等,实际上对数字调用这些方法其实是调用Number.prototype上的方法

num.toString() //

Number(1) === 1

Number(1) === new Number(1)  // false

Number(1) == new Number(1)  // true

1.toSting()  // 该方法会报错,因为JS无法分别.是小数点还是操作符

正确做法是 const a = 1, a.toString()

或者1['toString']()

或者(1).toString()
 

字符串和 布尔中道理也是一样的

const  bol = new Boolean(false) 

console.loog(bol) // Boolean{false}

typeof bol // 'object'

typeof Boolean(false) // 'boolean'

Boolean(false) === false // true

Boolean(false) === new Boolean(false) // false

Boolean(false) == new Boolean(false) // true

bol上同样有一个__proto__属性,指向Boolean.prototype,上面有valueOf, toString,constructor三个属性

字符串当中

const str = new String('str')

console.log(str) // String{0: 's', 1: 't', 2: 'r'}

String('str') === 'str' // true

String('str') === str // false 

String('str') ==  str // true

str[0] === String('str')[0]

str实际上是一个对象,该对象中有三个属性,还有长度属性,

str.__proto__ === String.prototype 

String('str').__proto__ === String.prototype

第三部分:接下来再谈原型和原型链,就简单地多啦

在 Javascript中,除了null,和 undefined这两个特殊的值,其他的一切都可以看做是实例对象,只是数字,字符串,布尔,symbol这样的一般不称他们为对象,

除了null, undefined以外,所有的值都有自己的隐式原型属性__proto__,该属性指向这个值得构造函数的prototype

看代码

const num = 1

const str = 'a'

const bol = false

const obj = {}

const arr = []

const sym = new Symbol()

const set = new Set()

const map = new Map()

const fun = function() {}

num.__proto__  ===  Number.prototype // true

str.__proto__ === String.prototype // true

bol.__proto__ == Boolean.prototype // true

obj.__proto__ == Object.prototype // true

arr.__proto__ === Array.prototype // true

sym.__proto__ === Symbol.prototype // true

map.__proto__ === Map.prototype // true

set.__proto__ === Set.prototype // true

fun.__proto__ === Function.prototype // true

也就是说,任意一个数字,字符串,布尔,数组,对象,函数,set, map, symbol,都有一个__proto__属性,指向他们各自对应的构造函数

那么 构造函数的__proto__属性会指向哪里呢?

Number.__proto__ === Function.prototype

Boolean.__proto__ === Function.prototype

String.__proto__ === Function.prototype

Array.__proto__ === Function.prototype

Map.__proto__ === Function.prototype

Set.__proto__ === Function.prototype

Symbol.__proto__ === Function.prototype

// 也就是说所有构造函数的原型,最终指向Function的显式原型对象

那么Function.__proto__ 会指向谁呢,
因为Function本事也属于构造函数,他的隐式原型,当然指向自身的显示原型对象 Function.__proto__ === Function.prototype

最后来讲一个特殊的,对象的__proto__属性,

普通实例对象的__proto__属性,指向他的构造函数的prototype

const obj = {}

实际上相当于

const obj = new Object()

那么

obj.__proto__ === Object.prototype

最终问题来了,构造函数的显式原型对象,本身也是一个对象,他的__proto__会指向哪里呢?

结果是

除了Object构造函数以外,任意构造函数的显式原型属性的__proto__,都指向Object.prototype

也就是说
Array.prototype.__proto__ === Object.prototype Number.prototype.__proto__ === Object.prototype 所有其他数据Boolean, Set, Map, Symbol, Promise等类型同理 特殊的
Function.prototype.__proto__ === Object.prototype 而原型链的顶端: Object.prototype.__proto__ === null 因为对象的显式原型对象也是一个对象,也该指向Object.prototype,
单位了防止死循环,就把Object.prototype.__proto__ 指向了null, 也就到达了
原型链的最顶端

作用域链的原理:

当一个非null, undefined类型的Javasrcipt数据想要获取某个属性值,或者调用某个方法时,如果没有该属性或者方法,那么就会向这个数据的__proto__属性中去查找,

如果一层还没有,就回继续向上查找,最终查到Object.prototype.__proto__ 因为原型链顶端指向了null,那么就会停止。最终会返回一个undefined

这个就是原型链的原理

function Animal() {
this.name = '猫'
} Animal.name = '狗' Function.prototype.name1 = '猪' Object.prototype.name2 = '羊' const animal = new Animal() console.log(animal.name ,animal.name1, animal.name2) // 猫, undefined, 羊

注意事项,尽量减少在prototype上增加属性或者操作,那样会修改整个作用域链, 对于JS的运行性能是一种损耗

Javascript中的基本数据类型,如何判断数据类型,作用域链的理解的更多相关文章

  1. 对 JavaScript 中的5种主要的数据类型进行值复制

    定义一个函数 clone(),可以对 JavaScript 中的5种主要的数据类型(包括 Number.String.Object.Array.Boolean)进行值复制 使用 typeof 判断值得 ...

  2. js中的数据类型和判断数据类型

    js中的数据类型和判断数据类型 基本数据类型,六大基本数据类型:字符串(String).数字(Number).布尔(Boolean).对象(Object).空(Null).未定义(Undefined) ...

  3. 实现一个函数clone,使JavaScript中的5种主要的数据类型(包括Number、String、Object、Array、Boolean)进行值复制

    实现一个函数clone,可以对JavaScript中的5种主要的数据类型(包括Number.String.Object.Array.Boolean)进行值复制. 1 /** 对象克隆 2 * 支持基本 ...

  4. C#保留2位小数几种场景总结 游标遍历所有数据库循环执行修改数据库的sql命令 原生js轮盘抽奖实例分析(幸运大转盘抽奖) javascript中的typeof和类型判断

    C#保留2位小数几种场景总结   场景1: C#保留2位小数,.ToString("f2")确实可以,但是如果这个数字本来就小数点后面三位比如1.253,那么转化之后就会变成1.2 ...

  5. javascript篇-typeof,instanceof,constructor,toString判断数据类型的用法和区别

    javascript基本数据类型有:string,number,Boolean,undefined,null 引用类型(复杂类型):object, ES6中新增了一种数据类型:Symbol 以上数据类 ...

  6. javascript中对变量类型的判断

    本文正式地址:http://www.xiabingbao.com/javascript/2015/07/04/javascript-type 在JavaScript中,有5种基本数据类型和1种复杂数据 ...

  7. javascript中apply、call和bind的区别,容量理解,值得转!

    a)  javascript中apply.call和bind的区别:http://www.cnblogs.com/cosiray/p/4512969.html b)  深入浅出 妙用Javascrip ...

  8. JavaScript学习笔记——JS中的变量复制、参数传递和作用域链

    今天在看书的过程中,又发现了自己目前对Javascript存在的一个知识模糊点:JS的作用域链,所以就通过查资料看书对作用域链相关的内容进行了学习.今天学习笔记主要有这样几个关键字:变量.参数传递.执 ...

  9. JavaScript之一: 闭包、执行环境、作用域链

    这是大虾的第一篇博文,大虾试图用最直白的语言去描述出所理解的东西,大虾是菜鸟,水平有限,有误的地方希望路过的朋友们务必指正,谢谢大家了. 从读书时代一路走来,大虾在学习的时候逐渐喜欢上了去追寻根源,这 ...

随机推荐

  1. 利用jenkins实现自动构建、部署,提升团队开发效率

    一大早就被群里的同学刷银川下雪的消息,看着我都发冷,突觉一阵凉风裹身,是不是该考虑秋裤了. 偏离主题,正文走起...... 使用jenkins目标:利用其结合maven完成自动构建,并部署到tomca ...

  2. 剑指offer第二版-3.数组中重复的数

    面试题3:数组中重复的数 题目要求: 在一个长度为n的数组中,所有数字的取值范围都在[0,n-1],但不知道有几个数字重复或重复几次,找出其中任意一个重复的数字. 解法比较: /** * Copyri ...

  3. VS2012 BIDS之Reporting Service/SSRS 项目2--开发过程问题总结(全)

    由刚开始的接触到现在做出来一个基本完整的SSRS的项目,学到了比较多的知识,和大家共享. 上一篇学习总结可能有些问题,一起修正和总结. ================================ ...

  4. Excel催化剂开源第29波-在Winform上使用富文本编辑器控件

    富文本编辑器,一般都是BS架构专利一般,好像百度有一个开源的比较出名,但无奈这些都只能用在JS上,在BS网页端开发上使用.像Winform开发的VSTO,只能羡慕的份.和一般Winform上用的Ric ...

  5. 通过自研数据库画像工具支持“去O”评估

    “去O”,是近些年来一直很火的一个话题,随之也产生了各种疑惑,包括现有数据库评估.技术选型等.去O是项系统工程,需要做好充分的评估.本文通过自研工具,生成数据库画像,为去O评估提供一手数据,希望给大家 ...

  6. SpringMVC面试题:什么是Servlet?

    一.什么是servlet? servlet是一个Java编写的程序,此程序是基于http协议的,在服务器端(如Tomcat)运行的,是按照servlet规范编写的一个Java类.客户端发送请求至服务器 ...

  7. 【HDOJ】2104 hide handkerchief

    Problem Description The Children’s Day has passed for some days .Has you remembered something happen ...

  8. dede:channelartlist currentstyle高亮显示

    我们在用DEDECMS建站时,常常会做二级栏目的功能,既要用到二级栏目,也就要通过DEDE标签再套标签的方式来实现调用,而DEDECMS多层标签调用只支持channelartlist,也就是说我们只能 ...

  9. 第一个C# Winform实例

    前面我们准备好了相关的库,现在开始搭建环境,本人自动化行业,就用Windorm开发吧,例子仅仅做引导,希望大家能深入.VS版本VS2017 1:打开VS建立一个WInform 项目.拉入两个控件,gr ...

  10. java练习---7

    //程序员:罗元昊 2017.10.7 import java.util.Scanner; public class L { public static void main(String[] args ...