语言类型:

  弱类型:可以改变变量值和对象类型

  强类型:可以改变变量值不能改变对象类型

  解释型:边编译边执行,速度慢。解释型一般是弱类型

  编译型:先编译再执行(C++\Java),速度快。编译型一般是强类型

JavaScript语言类型:

  解释型弱类型的脚本语言。

加法运算:

  任何类型加字符串或者对象(不包括undefined和null)相加,都变成字符串,空数组做加法运算时转换成空串

  对象转成字符为object Object,数组[1,2,3]转换成字符串为'1,2,3'

  如果没有字符类型或者undefined和null之外的对象类型,其他类型加法转换成数值进行运算

减法运算:

  任何类型的减法运算都转换成数值运算

一元运算符

    a++; // a = a+1;
    一元运算和累加赋值运算的区别:
       1 一元运算强制将值转换为数值+1
       2 打印a++,先 打印a,再自加。 打印a+=1;a+1,再打印a
       3 ++a,结果和a+=1一样
    从根本上来说,a的结果相同,返回的结果不同
    var x = 1;
    var y = x++ + x + x++ + x++ + x++; // 12,5
    var y = x+ ++x + x + + +x++ + x++; //12,5
  一定要有一个单+号衔接,(x + x ++x报错,右边没有衔接),前断后断都一样
 

关系运算符:

  任何关系运算符都有返回值

大小比较: <、<=、>、>=,返回的是布尔值

  字符字母和字符字母比较:按顺序一一比较单个字母的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,则一定返回右边

  1. var a = 1;
  2. a = --a || ++a;// 左边是false,看右边,右边是true,返回右边左边已经进行了运算
  3. console.log(a);

28 JavaScript语言类型&运算符的更多相关文章

  1. 面向对象的JavaScript --- 动态类型语言

    面向对象的JavaScript --- 动态类型语言 动态类型语言与面向接口编程 JavaScript 没有提供传统面向对象语言中的类式继承,而是通过原型委托的方式来实现对象与对象之间的继承. Jav ...

  2. javascript语言精粹

    内容选自:<javascript语言精粹> 1.6种值会为假(==false),分别是false,null,undefined,' ',0,NaN 2.typeof有6种值,分别是'num ...

  3. 《JavaScript语言精粹》小记

    一.前言 以下内容均摘自<JavaScript语言精粹>一书,本人在读这本书时,发现作者诠释JavaScript很犀利,特别是数组部分,固记录下来,想和大家分享下. 随笔主要包含两大部分: ...

  4. Javascript 语言精粹 代码片段合集

    Javascript 语言精粹 代码片段合集 标签:Douglas-Crockford Javascript 最佳实践 原文链接 更好的阅读体验 使用一个method 方法定义新方法 Function ...

  5. 《JavaScript语言精粹》学习笔记

    一.in的用法 for...in 枚举一个对象的所有可枚举属性 检测DOM/BOM属性 if ("onclick" in elem) { // 元素支持onclick } if ( ...

  6. 第一章:Javascript语言核心

    本节是javascript语言的一个快速预览,也是本书的第一部分快速预览. 读此书之前,感谢淘宝技术团队对此javascript核心的翻译,感谢弗拉纳根写出此书.感谢你们无私的分享,仅以此笔记献给你们 ...

  7. JavaScript的类型、值和变量的总结

    前言:JavaScript的数据类型分为两类:原始类型和对象类型.5种原始类型:数字.字符串.布尔值.null(空).undefined(未定义).对象是属性的集合,每个属性都由“名/值对”(值可以是 ...

  8. JavaScript语言精粹-读书笔记

    前言:很久之前读过一遍该书,近日得闲,重拾该书,详细研究一方,欢迎讨论指正. 目录: 1.精华 2.语法 3.对象 4.函数 5.继承 6.数组 7.正则表达式 8.方法 9.代码风格 10.优美的特 ...

  9. JavaScript 语言精粹读书笔记

    最近在看 赵泽欣 / 鄢学鹍 翻译的 蝴蝶书, 把一些读后感言记录在这里. 主要是把作者的建议跟 ES5/ES5.1/ES6 新添加的功能进行了对比 涉及到的一些定义 IIFE: Immediatel ...

随机推荐

  1. C++11 auto的用法

    参考博客:https://www.cnblogs.com/KunLunSu/p/7861330.html

  2. java_获取指定ip的定位

    因为自己网站后台做了一个进站ip统计,之前只是获取了ip,这次优化了下,把ip的大致区域弄出来了 废话不多说,进正题 首先要用到几个网络大头的api 淘宝API:http://ip.taobao.co ...

  3. emoji大全_如何明智地使用emoji: &#128516;

    官网 https://www.webfx.com/tools/emoji-cheat-sheet/ emoji那么多,如何准确地使用到自己想要到呢?

  4. 【vue store的使用方法】(this.$store.state this.$store.getters this.$store.dispatch this.$store.commit)

    vue 页面文件 <template> <div> {{this.$store.state.count}}<br/> {{count}}<br/> {{ ...

  5. 【做题笔记】P2871 [USACO07DEC]手链Charm Bracelet

    就是 01 背包.大意:给您 \(T\) 个空间大小的限制,有 \(M\) 个物品,第 \(i\) 件物品的重量为 \(c_i\) ,价值为 \(w_i\) .要求挑选一些物品,使得总空间不超过 \( ...

  6. 第二十篇 Linux条件测试语句相关知识点介绍

      条件测试语句的格式如下: [ 条件表达式 ]        # 条件表达式两侧各有一个空格 按测试对象不同,条件测试语句共分为4中类型: 文件测试语句 逻辑测试语句 整数值比较语句 字符串比较语句 ...

  7. 2019 徐州网络赛 center

    题意:n个点,求最小加上几个点让所有点关于一个点(不需要是点集里面的点)中心对称 题解:双重循环枚举,把中点记录一下,结果是n-最大的中点 #include <bits/stdc++.h> ...

  8. mybatis重新回顾

    此次在项目中相遇了mybatis,重新回顾下. 1.resulMap解决了结果集的列名字跟实体setter和getter不匹配的问题 其中property是实体的setter和getter对象,col ...

  9. 每日扫盲(一):java的rmi

    JAVA RMI 原理和使用浅析 本地对象调用 我们先看看本地对象方法的调用: ObjectClass objectA = new ObjectClass(); String retn = objec ...

  10. centos7的netca命令和netmgr命令、dbca命令等基础知识点

    netca命令: netmgr命令: dbca命令: database assistant  configuration 中的SGA 和PGA SGA:System Global Area是Oracl ...