JavaScript深入浅出补充——(一)数据类型,表达式和运算符
项目基本做完,在进行下一阶段学习之前先看视频学习回顾一下JavaScript
一、数据类型
JavaScript中有五种原始类型和一种对象类型

JavaScript弱类型语言中隐式转换
num-0
字符串减去0,可以将字符串变量num转化为数字
num+“”
数字变量串变量加上空字符串,可以将数字num转化为字符串
等于==

当==两边是字符串和数字的时候会尝试把字符串转化为数字
严格等于===
两边类型不同返回false
两边相同:
需要注意NaN和任何东西比较都不等于,和自己也不等于,NaN≠NaN
JavaScript中的比较是用引用去比较,而不是用值去比较,所以new Object≠new Object,即使他们长度和内容完全相同也是不相等的,因为他们不是完全相等的对象,只有定义一个对象x,让他和x去比较才是true,即使两个空对象也不是true

包装对象
首先我们定义一个字符串变量,然后定义一个变量对象,查看字符串,查看变量

尝试访问字符串的长度,给字符串加一个属性,成功,访问这个属性,找不到


JavaScript中有一个隐藏机制,当把一个基本类型尝试以对象的方式去使用它的时候,比如去访问他的长度属性,或者给他增加一些属性,JavaScript会把这样的基本类型转化为对应的包装类型对象,当完成这个访问后,这个临时对象会被销毁
类型检测
JavaScript中类型检测的方法有很多,比如

最常见的typeof,会返回字符串,适合函数对象和基本类型

需要注意的是typeof null会返回object,这是由于某些历史原因,因为曾经尝试让他返回null后造成了很多问题
typeof在判断基本类型或者函数对象时非常方便,但是在其他一些情况就会没有办法了,比如我们要判断一个对象是不是数组,用typeof会返回Object,对于判断对象类型我们更常用的是instanceof
instanceof是基于原型链去操作的一个运算符
instanceof期望 左侧是一个对象,如果不是对象,是基本类型会返回false,期望右侧是一个函数对象或者说函数构造器,如果不是会抛出异常
instanceof的大概原理:判断左操作数的对象的原型链上是否有右边构造函数的prototype属性
任何一个构造函数都会有一个prototype对象属性,Javascript中对象的prototype属性的解释是:返回对象类型原型的引用。
instanceof 方法要求开发者明确地确认对象为某特定类型
实例:
//instanceof 示例
var oStringObject = new String("hello world");
console.log(oStringObject instanceof String); // 输出 "true"
//这段代码问的是“变量 oStringObject 是否为 String 对象的实例?”oStringObject 的确是 String 对象的实例,因此结果是"true"。尽管不像 typeof 方法那样灵活,但是在 typeof 方法返回 "object" 的情况下,instanceof 方法还是很有用的。 //instanceof 常规用法
// 判断 foo 是否是 Foo 类的实例
function Foo(){}
var foo = new Foo();
console.log(foo instanceof Foo)//true //instanceof 在继承中关系中的用法
// 判断 foo 是否是 Foo 类的实例 , 并且是否是其父类型的实例
function Aoo(){}
function Foo(){}
Foo.prototype = new Aoo();//JavaScript 原型继承
var foo = new Foo();
console.log(foo instanceof Foo)//true
console.log(foo instanceof Aoo)//true //instanceof 复杂用法
console.log(Object instanceof Object);//true
console.log(Function instanceof Function);//true
console.log(Number instanceof Number);//false
console.log(String instanceof String);//false console.log(Function instanceof Object);//true console.log(Foo instanceof Function);//true
console.log(Foo instanceof Foo);//false


补充:原型法
JavaScript中的方法可以分为三类:
a 类方法
b 对象方法
c 原型方法
调用Object.prototype.toString判断类型

constructor
任何一个对象都有一个constructor属性是继承自原型的,constructor会指向构造这个对象的构造器或者说函数,constructor是可以被改写的所以使用要小心
duck type(鸭子类型)
如果我们不知道这个对象是不是数组,我们判断它的length是不是数字,是否有push()这样的,通过一些特征来判断是不是某些类型

注意:不能用typeof判断某一个变量的值是不是null,可以使用严格等于===
二、表达式和运算符
JavaScript中的表达式









JavaScript中的运算符

条件运算符:

,运算符
从左到右计算表达式的值并取最右边的

delete运算符


configurable为true才会被delete掉
in运算符
判断x在window中返回true

instanceof,typeof

new运算符
比如我们创建一个空函数Foo()
用new运算符可以创建一个新的对象obj
根据obj.x可以从函数的prototype属性拿到1
可以通过hasOwnPropetry判断是对象上的还是对象的原型的
用._proto_.拿到对象的原型发现x是对象原型上的属性而不是对象本身的属性

this运算符

void运算符
不管操作数是多少后会返回undefined

运算符优先级

JavaScript深入浅出补充——(一)数据类型,表达式和运算符的更多相关文章
- javascript 核心语言笔记 4 - 表达式和运算符
表达式(expression)是 JavaScript 中的一个短语(phrases),JavaScript 解释器会将其计算(evaluate)出一个结果.程序中的常量.变量名.数组访问等都是表达式 ...
- Javascript基础学习(2)_表达式和运算符
1.==和===的区别(!=和!==是相反的比较) 它们采用了同一性的两个不同定义.==是相等性,===是等同性. ①“===”进行两个值的比较 两个值的类型不同,就不相等 两个值是数字,并且值相同, ...
- Javascript权威指南——第二章词法结构,第三章类型、值和变量,第四章表达式和运算符,第五章语句
第二章 词法结构 一.HTML并不区分大小写(尽管XHTML区分大小写),而javascript区分大小写:在HTML中,这些标签和属性名可以使用大写也可以使用小写,而在javascript中必须小写 ...
- 笔记《JavaScript 权威指南》(第6版) 分条知识点概要3—表达式和运算符
[表达式和运算符]原始表达式,初始化表达式(对象和数组的),函数定义表达式,属性访问表达式,调用表达式,对象创建表达式,运算符概述,算术表达式,关系表达式,逻辑表达式,赋值表达式,表达式计算,其他运算 ...
- Javascript学习2 - Javascript中的表达式和运算符
原文:Javascript学习2 - Javascript中的表达式和运算符 Javascript中的运算符与C/C++中的运算符相似,但有几处不同的地方,相对于C/C++,也增加了几个不同的运算符, ...
- C#图解教程 第八章 表达式和运算符
表达式和运算符 表达式字面量 整数字面量实数字面量字符字面量字符串字面量 求值顺序 优先级结合性 简单算术运算符求余运算符关系比较运算符和相等比较运算符递增运算符和递减运算符条件逻辑运算符逻辑运算符移 ...
- Python基础0:变量 赋值 表达式和运算符
变量: 前面我们在使用print()输出内容的时候,如果内容很长,后面要再次输出的时候,就需重新在输入一遍. 如果给输出的内容起个简单的别名.这样我们用简短的别名来代替长内容,下次要输出的时候就直接使 ...
- Python3基础-表达式和运算符
表达式和运算符 什么是表达式? 1+2*3就是一个表达式,这里的加号和乘号叫做运算符,1.2.3叫做操作数. 1+2*3经过计算后得到的结果是7,我们可以将计算结果存放在一个变量里,result=1+ ...
- 第四章:Javascript表达式和运算符
表达式是javascript中的一个短语,javascript解释器会将其计算出一个结果.程序中常用量是最简单的一类表达式就是变量.变量名也是一种简单的表达式,它的值就是赋值给变量的值.复杂的表达式是 ...
随机推荐
- vue、rollup、sass、requirejs组成的vueManager
近段时间本人一直在思考如何基于vue搭建一个中后端管理系统的通用基础前端解决方案.思考的主要问题点如下: 如何使各个子业务模块的按需加载 css预处理方案的选择 如何引入现代的前端工程思想,也就是工程 ...
- 多人合作开发启动activity-----规范问题
A----FirstActivity button1.setOnClickListener(new OnClickListener() { @Override public void ...
- php中for循环的应用1
for 循环是 PHP 中最复杂的循环结构.它的行为和 C 语言的相似.在PHP中使用的是执行相同的代码集的次数. for 循环的语法是: for (expr1; expr2; expr3)state ...
- 对JVM运行时常量池的一些理解
1.JVM运行时常量池在内存的方法区中(在jdk8中,移除了方法区) 2.JVM运行时常量池中的内容主要是从各个类型的class文件的常量池中获取,对于字符串常量,可以调用intern方法人为添加,而 ...
- Servlet路径映射
Serlvlet路径映射 当一个请求发送到servlet容器的时候,容器先会将请求的url减去当前应用上下文的路径作为servlet的映射url. 容器默认请求的是一个Servlet,所以不会直接根据 ...
- 12款Linux系统恢复工具
电脑死机,硬盘崩溃,花巨大的money搞个急救保护器……这都是计算机的阴暗面.时间一直这样走着,走着,不定哪天背点儿.对于电脑损坏造成的损失,着急抓狂毫无意义.相反,使用恰当的工具反而会最小化损失.你 ...
- 360你吃屎啊你,hao123,12345等等
请看到这个文章的小伙伴将文章看完,看看我的感受是有多深,谢谢了 现在浏览器已经是人们经常用的东西,相信都有时不时就差度娘的习惯吧 也就是说每个人都有自己喜欢的主页 可电脑有时候就是遭不住,360什么的 ...
- (数字IC)低功耗设计入门(七)——门级电路低功耗设计优化(续)
前面讲解了门级功耗的优化方法,包括静动态和总体的功耗.现在来记录一下门级层次(有点书也说是在系统级)常用的一种低功耗方法--电源门控. ①电源门控概述与原理 电源门控是指芯片中某个区域的供电电源被关掉 ...
- ECS_8080端口连接拒绝问题排查
原文链接 用户ECS网络设置 上图是用户ECS的网络示意图: ecs处于vpc网络下 ecs加入了一个安全组,该安全组出入方向均开放8080端口 ecs有两个网卡,一个私网主网卡(有虚线的网卡),一个 ...
- pick off your glasses
我一直在想,为什么带眼镜时间长了机不愿意再摘下来呢,或者说摘下来感觉很不舒服.当然了,这更多的是内心里的一种感觉而已. 其实,我突然认为这是一种不自信,在这样一个物欲横流的社会中,当你眼前模模糊糊,而 ...