语言类型:

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

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

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

  编译型:先编译再执行(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,则一定返回右边

        var a = 1;
a = --a || ++a;// 左边是false,看右边,右边是true,返回右边左边已经进行了运算
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. JQuery/JS插件 jsTree加载树,普通加载,点一级加载一级

    前端: <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <tit ...

  2. Ztree使用教程

    这两天项目需要写一个树形帮助,学习了我们项目组的老师的Ztree的树的写法,实现了这个帮助,下面来总结一下Ztree的用法. (也是参考的一篇csdn上的博客了) zTree 是一个依靠 jQuery ...

  3. Android开发实战——记账本(2)

    开发日志(2)——Bean目录以及数据库 首先编写一些自己生成的数据进行测试,看一下能否显示在模拟器上.那前提就是先写出bean目录,这和之前学的Javaweb步骤差不多.bean目录有三个变量事件. ...

  4. Go_CSP并发模型

    go语言的最大两个亮点,一个是goroutine,一个就是chan了.二者合体的典型应用CSP,基本就是大家认可的并行开发神器,简化了并行程序的开发难度,我们来看一下CSP. 11.1.CSP是什么 ...

  5. LVM逻辑卷:创建LVM分区实例

    一.概述 LVM(Logical Volume Manager)是基于内核的一种逻辑卷管理器,LVM适合于管理大存储设备,并允许用户动态调整文件系统的大小.此外LVM快照功能可以帮助我们快速备份数据. ...

  6. 【C语言】输入三个正整数a,b,c,求最大值,要求定义一个计算最大值的函数max(a,b),返回a,b的值

    #include<stdio.h> int max(int a, int b)/*定义函数*/ { if (a > b) return a; else return b; } int ...

  7. Abp中打开错误信息输出

    Abp默认是不向客户端输出错误日志的,导致有些内部报错既不能中断,也没有信息输出.此时打开日志输出开关即可.在xxModule类中PreInitialize()方法里 Configuration.Mo ...

  8. 边双连通分量 jarjan (poj 3177)

    大意:给定一个无向连通图,判断至少加多少的边,才能使任意两点之间至少有两条的独立的路(没有公共的边,但可以经过同一个中间的顶点). 思路:在同一个双连通分量里的所有的点可以看做一个点,收缩后,新图是一 ...

  9. 生成树计数 UVA 10766

    //本题题意:首先每个点之间都可达,然后m列举出不可达的,求出最多的生成树方案: //k这个变量是没用的. //公式:ans矩阵=度矩阵-建边矩阵: //度矩阵是当i==j时的,建边矩阵于平时定义可达 ...

  10. opencv编译静态库时选择MD模式无效的原因

    在Cmake-gui上看到的明明是MD运行库依赖,生成MS项目时却变成了MT运行库依赖. 原因在于编译静态库时内部做了自动替换.