28 JavaScript语言类型&运算符
语言类型:
弱类型:可以改变变量值和对象类型
强类型:可以改变变量值不能改变对象类型
解释型:边编译边执行,速度慢。解释型一般是弱类型
编译型:先编译再执行(C++\Java),速度快。编译型一般是强类型
JavaScript语言类型:
解释型弱类型的脚本语言。
加法运算:
任何类型加字符串或者对象(不包括undefined和null)相加,都变成字符串,空数组做加法运算时转换成空串
对象转成字符为object Object,数组[1,2,3]转换成字符串为'1,2,3'
如果没有字符类型或者undefined和null之外的对象类型,其他类型加法转换成数值进行运算
减法运算:
任何类型的减法运算都转换成数值运算
一元运算符
关系运算符:
任何关系运算符都有返回值
大小比较: <、<=、>、>=,返回的是布尔值
字符字母和字符字母比较:按顺序一一比较单个字母的ascll码值
字符字母和数字比较:false,相当于和NaN比较,这里'4a'也是NaN,而非按照parseInt转换成4
字符数字和数字比较:字符数字转换成数值再比较,而非ascll码
比较运算符:返回的是布尔值
空数组==空字符串==0是true , 空数组!== 0
0 == false,'' == 0, '' == false
对象与对象的比较判断的是引用地址,地址不同的对象为false
特殊情况:undefined == null 是true
[] == [] , 是false,因为是两个不同的对象
if(a == null)为真,那么a只能为null或者undefined
if(a == 0)为真, 那么a只能为0或’‘或false
[] == '' 为true,[]没办法转换成布尔值,会转换成空串
[1,2,3] = '1,2,3'是true,数组会转成字符串
数组与其他非对象类型比较时都会转换成字符串
数组中如何包含对象,转成字符串对象是object Object
逻辑运算符:返回值、熔断机制。会再判断的时候进行运算改变值
&&:
左右为true才为true
左true,则一定返回右
左false返回左,不进行右侧运算
|| :
左右都为false才为false
如果左为true,直接返回左边,不进行右边的判断
如果左为false,则一定返回右边
var a = 1;
a = --a || ++a;// 左边是false,看右边,右边是true,返回右边左边已经进行了运算
console.log(a);
28 JavaScript语言类型&运算符的更多相关文章
- 面向对象的JavaScript --- 动态类型语言
面向对象的JavaScript --- 动态类型语言 动态类型语言与面向接口编程 JavaScript 没有提供传统面向对象语言中的类式继承,而是通过原型委托的方式来实现对象与对象之间的继承. Jav ...
- javascript语言精粹
内容选自:<javascript语言精粹> 1.6种值会为假(==false),分别是false,null,undefined,' ',0,NaN 2.typeof有6种值,分别是'num ...
- 《JavaScript语言精粹》小记
一.前言 以下内容均摘自<JavaScript语言精粹>一书,本人在读这本书时,发现作者诠释JavaScript很犀利,特别是数组部分,固记录下来,想和大家分享下. 随笔主要包含两大部分: ...
- Javascript 语言精粹 代码片段合集
Javascript 语言精粹 代码片段合集 标签:Douglas-Crockford Javascript 最佳实践 原文链接 更好的阅读体验 使用一个method 方法定义新方法 Function ...
- 《JavaScript语言精粹》学习笔记
一.in的用法 for...in 枚举一个对象的所有可枚举属性 检测DOM/BOM属性 if ("onclick" in elem) { // 元素支持onclick } if ( ...
- 第一章:Javascript语言核心
本节是javascript语言的一个快速预览,也是本书的第一部分快速预览. 读此书之前,感谢淘宝技术团队对此javascript核心的翻译,感谢弗拉纳根写出此书.感谢你们无私的分享,仅以此笔记献给你们 ...
- JavaScript的类型、值和变量的总结
前言:JavaScript的数据类型分为两类:原始类型和对象类型.5种原始类型:数字.字符串.布尔值.null(空).undefined(未定义).对象是属性的集合,每个属性都由“名/值对”(值可以是 ...
- JavaScript语言精粹-读书笔记
前言:很久之前读过一遍该书,近日得闲,重拾该书,详细研究一方,欢迎讨论指正. 目录: 1.精华 2.语法 3.对象 4.函数 5.继承 6.数组 7.正则表达式 8.方法 9.代码风格 10.优美的特 ...
- JavaScript 语言精粹读书笔记
最近在看 赵泽欣 / 鄢学鹍 翻译的 蝴蝶书, 把一些读后感言记录在这里. 主要是把作者的建议跟 ES5/ES5.1/ES6 新添加的功能进行了对比 涉及到的一些定义 IIFE: Immediatel ...
随机推荐
- [Linux] Ubuntu18.04 安装之后配置过程
前言 最终还是安装了Ubuntu 虽然一开始想用Deepin 但是死活安装不上,我也很绝望(引导一直找不到 恢复BIOS默认设置也还是不行 所以 有些绝望啊....) 所以 为了让以后的我不再那么 ...
- 浏览器的主要构成High Level Structure
浏览器的主要组件包括: 1. 用户界面- 包括地址栏.后退/前进按钮.书签目录等,也就是你所看到的除了用来显示你所请求页面的主窗口之外的其他部分 2. 浏览器引擎- 用来查询及操作渲染 ...
- MySQL学习(五)事务隔离
文章部分图片和总结来自参考资料,侵删 概述 MySQL的可重复读隔离级别,事务T启动的时候会创建一个视图read-view,之后事务T执行期间,即使有其他事务修改了数据,事务T看到的仍然跟在启动时看到 ...
- 2019牛客多校第四场K number dp or 思维
number 题意 给一个数字串,问有几个子串是300的倍数 分析 dp写法:这题一看就很dp,直接一个状态dp[i][j]在第i位的时候膜300的余数是j左过去即可.这题比赛的时候样例老是少1,后面 ...
- socket 异步I/O
# 客服端 # -*- coding: utf-8 -*- import socket import threading # from collections import deque # q = d ...
- codeforces A. Zoning Restrictions Again
A. Zoning Restrictions Again ou are planning to build housing on a street. There are n spots availab ...
- mongo日常命令集锦
查询某个字段是否存在 db.student.findOne({name:{$exists:true}}) db.student.findOne({'department.name':{$exists: ...
- 对象析构谈—— delete this 的使用及注意事项
this对象是必须是用 new操作符分配的(而不是用new[],也不是用placement new,也不是局部对象,也不是global对象): delete this后,不能访问该对象任何的成员变量及 ...
- Python 多任务(进程) day1(2)
进程和线程的简单区别: 功能:进程:能够完成多任务,比如 在一台电脑上能够运行多个QQ一份资源有一个执行的剪头,有多份资源就可以执行多个语句线程:能够完成多任务,比如 在一个QQ中的多个聊天窗口一份资 ...
- 设置idea的快捷键组合 设置为默认
ubuntu中,idea的快捷键组合 为 “Default for GNOME”,和windows中不一样了,需要修改为“Default”: