JavaScript学习笔记——运算符和表达式

javascript运算符

一、运算符和操作数的组合就称为表达式。

二、javascript运算符

(一) 算术运算符
  + - * / % var++ ++var var-- --var
  A. +
    (1) 用于数值的运算
    (2) 用于字符串的连接
  ***************************
  任何的数据类型和字符串相加都是等于相加以后的字符串
  *************************

  B. %
    (1)用于取余数,判断奇数或者是偶数
    (2)一般不用于小数,因为结果不确定。

  C. var++和++var
    ++在前面,自己先加,然后再赋值。
    ++在后面,先赋值,然后自己再加。

(二) 关系运算符(比较运算符)
  < > <= >= == === != !==
  (1)他运算的结果都是布尔值
  (2)都是字符串的时候,他会先转换成ASCII码然后进行比较他们的第一个字母。
  (3)都是数值的时候,他会正常比较
  (4)当一个字符串,另一个是数值的时候,把字符串尝试转换成数值类型,然后进行比较,如果不能转换成数值类型,则会返回NaN,然后返回假
  (5) undefined null
  (6)如果两个都是数值型字符串,那么他们也是只比较第一个
  (7)如果一个数值和布尔值进行比较,会把布尔值转换为数值再进行比较,true为1,false为 0

  A. == 只比较值是否相等
  (1) 比较字符串的时候是比较他们的ASCII码是否相等
  (2) 比较两个数值的时候是比较他们的数值是否相等
  (3) 比较函数的时候,判断他们的位置是否相等。

  B. === 不但比较值是否相等,还比较类型是否相等。

(三) 赋值运算符
  = += -= *= /= %=
  A. +=
  var a=1;
  a+=3; a=a+3
  (1) 用于数值的相加再赋值
  (2) 用于字符串的连接再赋值
  ***************************
  任何的数据类型和字符串相加都是等于相加以后的字符串
  *************************

(四) 逻辑运算符(布尔运算符)
与 and && 或 or || 非not !

A. &&
if(a && b){
alert("两个都是真的");
}else{
alert("至少有一个是假的")
}
运算符两边只要有一个是假,那么他的运算结果就是假,只有两个都为真的时候,运算结果
才是真的。

B.||
if(a || b){
alert("至少有一个是真的");
}else{
alert("两个都是假的")
}
运算符两边只要有一个是真的那么他就是真的,只有当两个都是假的时候,他才是假的。

C.not !
取反,假的变成真的,真的变成假的。

(1)逻辑运算符可以对任何类型的数据进行运算但是在运算的时候,可以转换为对应的布尔值
Undefined false
Null false
Boolean 就是本身的值
Number 除了0以外都是真的
String 除了空字符串意外都是真的
对象 真的

(2)类变量进行赋值
var a= b && c
如果一个运算数是对象,另一个是 Boolean 值,返回该对象。
如果两个运算数都是对象,返回第二个对象。
如果某个运算数是 null,返回 null。
如果某个运算数是 NaN,返回 NaN。
如果某个运算数是 undefined,发生错误。
var a=b ||c
如果一个运算数是对象,并且该对象左边的运算数值均为 false,则返回该对象。
如果两个运算数都是对象,返回第一个对象。
如果最后一个运算数是 null,并且其他运算数值均为 false,则返回 null。
如果最后一个运算数是 NaN,并且其他运算数值均为 false,则返回 NaN。
如果某个运算数是 undefined,发生错误。

(五) 一元运算符
typeof + - delete new ++ --

A. +
正号、正数

B.delete
删除对象的方法或是属性

C.new
用来创建一个对象

(六) 特殊的运算符

, () = ? :
A. ,
用来一次声明多个变量

B.()
(1) 运算的时候有优先级的作用
a*(b-c)
(2) 运行一段函数

C.根据表达式的计算结果有条件的为变量赋值
格式: var 变量= Boolean expression?真值:假值

(七) 位运算符

时间: 2025-01-02 18:06:34

JavaScript学习笔记——运算符和表达式的相关文章

javascript学习笔记-运算符

1:算术运算符    加减乘除   其中加号既是算术运算符  又是字符串连接运算符 2:赋值运算符           +=   /=   %= 3:比较运算符 4: 逻辑运算符 原文地址:http://blog.51cto.com/hudamao/2114776

JavaScript学习笔记【2】表达式和运算符、语句、对象

笔记来自<JavaScript权威指南(第六版)> 包含的内容: 表达式和运算符 语句 对象 表达式和运算符 数组直接量中的列表逗号之间的元素可以省略,这时省略的空位会填充值undefined.元素列表末尾可以留下单个逗号,这时并不会创建一个新的值为undefined元素. 属性访问表达式,.identifier的写法只适用于要访问的属性名称是合法的标识符,并且需要知道要访问的属性的名字.如果属性名称是一个保留字或者包含空格和标识符,或是一个数字(对于数组来说),则必须使用方括号的写法.当属性

javascript学习笔记---ECMAScript运算符(位运算符)

位运算符是在数字底层(即表示数字的 32 个数位)进行操作的. 位运算 NOT 位运算 NOT 由否定号(~)表示,它是 ECMAScript 中为数不多的与二进制算术有关的运算符之一. 位运算 NOT 是三步的处理过程: 把运算数转换成 32 位数字 把二进制数转换成它的二进制反码 把二进制数转换成浮点数 例如: var iNum1 = 25; //25 等于 00000000000000000000000000011001 var iNum2 = ~iNum1; //转换为 11111111

javascript学习笔记---ECMAScript运算符(逻辑运算符)

Boolean 运算符非常重要,它使得程序语言得以正常运行. Boolean 运算符有三种:NOT.AND 和 OR. ToBoolean 操作 在学习各种逻辑运算符之前,让我们先了解一下 ECMAScript-262 v5 规范中描述的 ToBoolean 操作. 抽象操作 ToBoolean 将其参数按照下表中的规则转换为逻辑值: 参数类型 结果 Undefined false Null false Boolean 结果等于输入的参数(不转换) Number 如果参数为 +0, -0 或 N

javascript学习笔记---ECMAScript语法(引用类型)

引用类型通常叫做类(class). 本教程会讨论大量的 ECMAScript 预定义引用类型. 引用类型 引用类型通常叫做类(class),也就是说,遇到引用值,所处理的就是对象. 本教程会讨论大量的 ECMAScript 预定义引用类型. 从现在起,将重点讨论与已经讨论过的原始类型紧密相关的引用类型. 注意:从传统意义上来说,ECMAScript 并不真正具有类.事实上,除了说明不存在类,在 ECMA-262 中根本没有出现"类"这个词.ECMAScript 定义了"对象定

JavaScript学习笔记【3】数组、函数、服务器端JavaScript概述

笔记来自<JavaScript权威指南(第六版)> 包含的内容: 数组 函数 服务器端JavaScript概述 数组 数组是动态的:根据需要它们会增长或缩减,并且在创建数组时无须声明一个固定的大小或在数组大小变化时无须重新分配空间. 数组可能是稀疏的:索引不一定要连续的,它们之间可以有空缺. 通常,数组的实现是经过优化的,用数字索引来访问数组元素一般来说比访问常规的对象属性要快很多. 数组继承自Array.prototype中的属性,它定义了一套丰富的数组操作方法. 如果省略数组直接量中的某个

javascript学习笔记---ECMAScriptECMAScript 对象----定义类或对象

使用预定义对象只是面向对象语言的能力的一部分,它真正强大之处在于能够创建自己专用的类和对象. ECMAScript 拥有很多创建对象或类的方法. 原始的方式 因为对象的属性可以在对象创建后动态定义(后绑定),类似下面的代码: var oCar = new Object; oCar.color = "blue"; oCar.doors = 4; oCar.mpg = 25; oCar.showColor = function() { alert(this.color); };不过这里有一

JavaScript学习笔记——js变量的布尔值

typeof(1): numbertypeof(NaN): numbertypeof(Number.MIN_VALUE): numbertypeof(Infinity): numbertypeof("123"): stringtypeof(true): booleantypeof(window): objecttypeof(Array()): objecttypeof(function(){}): functiontypeof(document): objecttypeof(null)

Java程序猿的JavaScript学习笔记(12——jQuery-扩展选择器)

计划按例如以下顺序完毕这篇笔记: Java程序猿的JavaScript学习笔记(1--理念) Java程序猿的JavaScript学习笔记(2--属性复制和继承) Java程序猿的JavaScript学习笔记(3--this/call/apply) Java程序猿的JavaScript学习笔记(4--this/闭包/getter/setter) Java程序猿的JavaScript学习笔记(5--prototype) Java程序猿的JavaScript学习笔记(6--面向对象模拟) Java程