javaScript的数据检测

1.typeof

1.1-第一题

检测数据类型的运算符

typeof 12;//'number'
typeof "ss"//'string'
...
typeof null;//object
typeof new RegExp('');//object 检测的结果又这六种: number string undefined object function boolean

设置b的默认值

方式一:

function(a,b){
if(typeof b==="undefined"){
b=0;
}else{
b=b;
}
}

方式2

	b=b||0

有区别

function(10,false);
//这个时候方式二的b的值也是0
//方式一的b的值是false

1.2第二题

function fn(callback){
//typeof callback==="function"?callback():null;
callback&&callback();
} fn(functtin(){
...
});

2.instanceof

检测某一个实例是否属于某个类

console.log([].instanceof Array);//true

局限性:

1 .不能用来处理和检测字面量方式创建出来的基本数据类型值

  • 对于基本数据类型来说,字面量创将建出来的结果和实例创建出来的结果是有一定区别的;

    1. 严格意义上讲,只有实例创建出来的结果才是标准数据类型值,也是标准的Number的一个实例
    2. 对于字面量方式创建出来的结果是基本数据类型,不是严谨的实例,但由于js的松散的特点,导致其可以使用 Number.prototype的方法

    console.log(1 instanceof Number);//false

    console.log(new Number(1) instanceof Number);//true


2.instanceof的特性:只要在当前实例的原型链上,其检测结果都为true

[] instanceof Array//true
[] instanceof Object//true fnunctin fn(){...}
fn instanceof Function//true
fn instanceof Object//true

3.在类的原型继承中,instanceof检测出来的结果未必准确

function Fn(){
...
}
Fn.prototype = new Array();//原型继承,让子类的原型指向父类的一个实例 let f =new Fn();
f instanceof Array;//true
f instanceof Function;//true

3.constructor

构造函数,作用和instanceof非常相似

let arr=[];
console.log(arr.constructor === Array);//true
console.log(arr.constructor === RegExp);//false

constructor可以用来检测基本数据类型

let a = 250;
console.log(a.constructor === Number);//true

constructor和instanceof检测Object的结果不一样

let reg =/\d/;
console.log(reg.constructor === RegExp);//true
console.log(reg.constructor === Object;//false
//false的原因是因为先找私有的,私有没有才会去找原型,私有已经有了,所以...

局限性:我们可以把类的原型进行重写,在重写的过程中很有可能把之前的constructor覆盖了,这样检测的结果就是不准确的

function Fn(){
...
}
let f =new Fn();
console,log(f.constructor);//返回的是当前类的本身Fn
//继承后
Fn.prototype = new Array();//原型继承,让子类的原型指向父类的一个实例
console,log(f.constructor);//变成了Array

null和undefined他们的所属类是Null和Undefined,但是浏览器不让用

4.Object.prototype.toString.call()--------- 一个神奇的方法

首先获取Object原型上的toSting方法,然后让其执行,并且改变方法中的this关键字

  • 1.对于Number、 String 、 Boolean 、 Array 、RegExp 、 Date 、 Function,他们的原型上的toString方法都是把当前的数据类型转为字符串

    (1).toString();//"1"

    [].troString();//''

    [1,2,3].toString()//"1,2,3"

    (false).toString();//"fales"

    ...

  • 2.Math和{ }的toString执行的是Object.prototype上的toString方法

    作用是:返回当前执行主体(方法中的this)所属类 的详细信息

    Math.toSting();//[object Math]

    {}.toString();//[object Object]

    //[..]中的第一个object代表大行前实例是对象类型的数据(固定死的)

    //第二个参数表示的是第一个参数所属类是谁

根据这些个特点就有了

Object.prototype.toString.call(要检测的类或实列);

 console.log(Object.prototype.toString.call([]));//[object Array]

javascript的数据检测总结的更多相关文章

  1. JavaScript数据检测

    前言: 随着编程实践的增加,慢慢发现关于数据类型的检测至关重要.我认为程序就是为了处理数据和展示数据.所以,数据的检测对于编程来说也至关重要.因为只有符合我们预期的输入,才可能产生正确的输出.众所周知 ...

  2. JavaScript中数据类型转换总结

    JavaScript中数据类型转换总结 在js中,数据类型转换分为显式数据类型转换和隐式数据类型转换. 1, 显式数据类型转换 a:转数字: 1)Number转换: 代码: var a = " ...

  3. 细读 php json数据和JavaScript json数据

    关于JSON的优点: 1.基于纯文本,跨平台传递极其简单: 2.Javascript原生支持,后台语言几乎全部支持: 3.轻量级数据格式,占用字符数量极少,特别适合互联网传递: 4.可读性较强 5.容 ...

  4. 应用层级时空记忆模型(HTM)实现对实时异常流时序数据检测

    应用层级时空记忆模型(HTM)实现对实时异常流时序数据检测 Real-Time Anomaly Detection for Streaming Analytics Subutai Ahmad SAHM ...

  5. 再谈JavaScript的数据类型问题

    JavaScript的数据类型问题已经讨论过很多次了,但许多人还有许多书仍然沿用着错误的.混乱的一些观点,所以就再细讲一回. 提及这个讨论的原因在于argb同学在我的MSN博客上的一段回复,又更早的起 ...

  6. JavaScript实现数据的双向绑定

    接触到Angulr.js和Vue.js后,提到最多的就是双向绑定 下面将用JavaScript实现数据的双向绑定 <!DOCTYPE html> <html> <head ...

  7. hisql 高级功能数据检测将错误数据拦截在系统外 一

    hisql github源码下载 git clone https://github.com/tansar/HiSql.git 在设计第二范式数据库时经常会把可能重复的数据单独做一种表关联,但是在写入表 ...

  8. Javascript之类型检测

    一.检测原始(基本数据:字符串.数字.布尔.null.undefined)类型. 用typeof检测原始类型:1.对于字符串,typeof返回"string"; 2.对于数字,ty ...

  9. JavaScript的数据类型问题总结

    一    JS中有哪些数据类型? -- 共 6 种数据类型,其中 5 种基本数据类型Undefined,Null,Boolean,Number和 String,1 种复杂数据类型Object.因为EC ...

随机推荐

  1. g++多文件编译

    头文件:A.h void test(); 源文件:A.cpp #include <iostream> #include<thread> #include<chrono&g ...

  2. iOS Xcode 调试技巧

    一 NSLog调试 官方文档:Logs an error message to the Apple System Log facility. 即NSLog不是作为普通的debug log的,而是err ...

  3. 长沙雅礼中学集训-------------------day3

    今天的收获还是蛮大的,终于体会了一波在知识的海洋中遨游的美滋滋的快感. T1:给你N个点的位置和他们的速度,这些点向一个方向移动,求前M次超越者的集合A和被超越者的集合B(集合为这些点的速度),以及从 ...

  4. Delphi Webbrowser使用方法详解(二)

    delphi如何用webbrowser模拟登录网站? 我们就以如何登录博客园来做示例: 1.要登入一个网站,首先要获取网页的源代码,我们可以通过网页菜单--查看--查看源代码来获取. 2.我们找到登录 ...

  5. spring-mvc注解配置小记

    Controller中注解Service时,Service的实现类需加@Service,dao的实现类需加@Repository. 另:配置文件中对应的包也需要扫描到!!! <context:a ...

  6. 哈希与位图(Hash and BitMap)

    Hash:哈希机制 BitMap:位图机制 目的:都是为了保证检索方便而设置的数据结构 对于大数据进行排序,由于内存限制,不可能在内存中进行,所以采取BitMap机制 为了在大数据中快速检索以及操作数 ...

  7. storm项目优化

    实现监控脚本监控topology运行状态

  8. NFS各个版本之间的比较

    NFS是一种网络文件系统,从1985年推出至今,共发布了3个版本:NFSv2.NFSv3.NFSv4,NFSv4包含两个次版本NFSv4.0和NFSv4.1.经过20多年发展,NFS发生了非常大的变化 ...

  9. Swift里的CAP理论和NWR策略应用

    http://blog.sina.com.cn/s/blog_57f61b490101a8ca.html 最近有人讨论到swift副本数是否能够调整,3副本成本过高,如果改成2副本怎么样?多聊了几句以 ...

  10. 动态html处理和及其图像识别

    爬虫(Spider),反爬虫(Anti-Spider),反反爬虫(Anti-Anti-Spider) 之间恢宏壮阔的斗争... Day 1 小莫想要某站上所有的电影,写了标准的爬虫(基于HttpCli ...