表达式和运算符详解-创新互联

表达式

表达式是ECMAscript中的一个‘短语’,解释器会通过计算把它转化成一个值,最简单的表达式是字面量或者变量名。

站在用户的角度思考问题,与客户深入沟通,找到方山网站设计与方山网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:做网站、成都网站建设、企业官网、英文网站、手机端网站、网站推广、域名注册、网络空间、企业邮箱。业务覆盖方山地区。

例如:5 //数字字面量

“xiongbao”//字符串字面量

{x1,y2}对象字面量,对象表达式

[1,2,3]数组字面量,数组表达式

funciton(N)(return x+y) 函数字面量,函数表达式

合并简单表示创建复杂表示是

box+5 //加法运算符表达式

typeof(box)查看数据类型的表达式

box>8 逻辑运算表达式

1 一元运算符

(1)递增++和递减 - -

  var box = 100;

     ++box       //box = box + 1 ;

     box++        //box= box +1 ;

(2) 前置和后置的区别

   前置 运算先累加或者累减再赋值;

   后置 先赋值再累加或者累减

     var box = 100;

     var age = box++        //box = 100+1 赋值给age

     var age = ++box       // age = box;然后box+1;

 (3)其他类型运用一元运算符

   字符串类型

  A:  var box = “89”;

       box++          // 对于数字字符串  有隐形的转换功能,自动转化成数字类型

 B:var box = “ab”;

       box++          // 字符串包含非数字值转换为NaN

   布尔类型

    var box =false;

       box++          //false转换成数值是0,累加1 结果为1;

   对象类型

     var box = {

           toString:function(){ return}

       };

     box++          //结果为1  不执行toString()或者value() 方法为NaN

(4)一元加减运算符

1.用于类型转换

2.用于算术运算

3.加法用于取整,减法用于取负。

var box = 1;

-box ;

+box;

2.算术运算符

ECMAscript定义了五个算术运算符,加(+)减(-)乘(*)除(/)求模(取余)。

如果在算术运算的值不少数值,那么后台会自动调用number()函数将其转化成数值。

(1) 加法

a如果都是数值

var  box = 1+2;             //结果为3

var  box = 1+NaN            //结果为NaN  只要一个数值是NaN 就为NaN

var box = Infinity 加 Infinity      //结果为 Infinity

var box = -Infinity 加 - Infinity   //结果为 -Infinity

var box = Infinity 加 -Infinity    // 结果为 NaN  正无穷和负无穷为非负数

var box = +0 加 +0 ;        //  结果为+0

var box = -0 加 -0 ;       // 结果为-0

var box = +0 加 -0 ;       // 结果为+0

b如果一个操作数是字符串

b1: 如果两个数都是字符串,则讲两个字符串拼接起来

var  box = a + b ;        // 结果是ab

b2:如果只有一个是字符串,则将不是的字符串变成字符串,再拼接起来

var box = 7 + “9”;      // 结果是79

c 如果操作数 是对象和布尔值

调用他们的toString()获得相应的字符串值,再利用相关的字符串值

D 如果是undefined 和 null

则调用string()函数并取得字符串“undefined”和“null”。

(2) 减法

a如果都是数值

var  box = 1+2;             //结果为3  如果两个操作符都是数值,则执行常规的算术减法操作并返回结果。

var  box = 1-NaN            //结果为NaN  如果一个操作符是NaN 就为NaN

var box = Infinity 减 Infinity      //结果为 NaN

var box = -Infinity减 - Infinity  //结果为NaN

var box = Infinity 减 -Infinity    // 结果为Infinity

var box =- Infinity 减 Infinity   // 结果为-Infinity

var box = +0 减+0 ;        //  结果为+0

var box = +0 减 -0 ;       // 结果为-0

var box = -0 加 -0 ;       // 结果为+0

b如果一个操作数是字符串,布尔值,Null或者undefined

先在后台调用number()函数将其转化为数值,然后再根据前面规则执行减法计算。如果转换的结果是NaN,则减法的结果就是NaN。

c 如果一个操作数是对象

则调用对象的valueOf()方法以取得该对象的数值。

如果得到的结果是NaN,则减法的结果就是NaN。

如果对象没有valueOf()方法,则调用toString()方法并将得到的字符串转化为数值。

(3) 乘法 符合(*)

var  box = 10*70;             //结果为700

var  box = 1*NaN            //结果为NaN  如果一个操作符是NaN 就为NaN

var box = Infinity * Infinity      //结果为 Infinify

var box = -Infinity*- Infinity  //结果为Infinify

var box = Infinity * -Infinity    // 结果为-Infinity

var box = 10*true;        //  结果为100,true转成数值为1

var box = 10* “ ”;        // 结果为0  “ ”转成了0

var box = 10*null;        // 结果为0  null转成了0

var box = 10*“lee”;     // 结果为NaN  lee转成了NaN

var box = 10* 对象;     // 结果为NaN

小结

a如果操作数都是数值,执行常规的乘法计算,俩个正数或者两个负数相乘结果为正数,如果有一个操作符有符合,结果为负数。如果超过ECMAScript的数值范围,则返回Infinity或者-Infinity。

b如果一个操作符是NaN结果就是NaN

c 如果是Infinity与0相乘,则结果是NaN;

d 如果是Infinity与非0相乘,则结果是Infinity或者-Infinity,取决于符号操作数的符合。

e 如果Infinity * Infinity,结果是Infinity。

f 如果一个操作数不是数值,则在后台调用Number() 将其转换为数值,在应用上面的规则

(4) 除法(/)

var box = 10/7;            //结果为1.42

var  box = 1/NaN            //结果为NaN  如果一个操作符是NaN 就为NaN

var box = Infinity / Infinity     //结果为 NaN

var box = -Infinity/- Infinity  //结果为NaN

var box = Infinity /-Infinity   // 结果为NaN

var box = 10/true;       // 结果为100,true转成数值为1

var box = 10/ “ ”;       // 结果为Infinity

var box = 10/null;       // 结果为Infinity

var box = 10/“lee”;     // 结果为NaN lee转成了NaN

var box = 10/ 对象;     // 结果为NaN

小结

a如果操作数都是数值,执行常规的除法计算,俩个正数或者两个负数相除结果为正数,如果有一个操作符有符合,结果为负数。如果超过ECMAScript的数值范围,则返回Infinity或者-Infinity。

b如果一个操作符是NaN结果就是NaN

c 如果是Infinity被Infinity除,则结果是NaN

d 如果是零被零除,则结果是NaN

e如果是非零的有限数被零除,则结果是Infinity或者-Infinity,取决于符号操作数的符合

f如果是Infinity被任何非零数值除,则结果是Infinity或者-Infinity,取决于符号操作数的符合

f 如果Infinity * Infinity,结果是Infinity

d 如果一个操作数不是数值,则在后台调用Number() 将其转换为数值,在应用上面的规则

(5) 求模(取余%)

var box = 10%3;            //结果为1

var box = 1%NaN           //结果为NaN

var box = Infinity %Infinity     //结果为 NaN

var box = -Infinity%- Infinity  //结果为NaN

var box = Infinity%-Infinity   // 结果为NaN

var box = 10%true;       // 结果为0

var box = 10%“ ”;       // 结果为Nan

var box = 10%null;       // 结果为NaN

var box = 10%“lee”;     // 结果为NaN

var box = 10%对象;     // 结果为NaN

小结

a如果操作数都是数值,执行常规的除法计算,返回除得的余数

b如果被除数是无穷大值而除数是有限值,结果就是NaN

c 如果被除数是有限大的数值而除数是0,则结果是NaN

d 如果Infinity被Infinity除,则结果是NaN

e如果被除数是有限大的数值而除数是无穷大的数值,则结果是被除数

f如果被除数是零,则结果是零

d 如果一个操作数不是数值,则在后台调用Number() 将其转换为数值,在应用上面的规则

3.关系运算符

用于进行比较的运算符称为关系运算符:小于(<),大于(<),小于等于(<=),大于等于(>=),相等(==),不等(!=),全等【恒等】(===),不全等【不恒等】(!==)。

var  box = 3 < 2 ;         // 关系运算符大多返回一个布尔值

var box = “3” >22;        // 字符串会被转化成数值,再比较

var box = “3” >“22”;       // 如果两个都是字符串,会对第一个字符进行比较,3>2

var box  = 对象  ;         //false;

var box = 2 > {

  toString:funtion(){

      return 1;

   }

}

var  box  = "a">"b";        //97 >98  字符编码进行比较

var box = "a">"B";       //97 >66  字符编码进行比较

总结:

1.俩个操作数都是数值,则数值比较

2.两个操作数都是字符串,则比较两个字符串对应的字符编码值

3.如果一个操作数是数值,则将另外一个操作数转化为数值,然后进行数值比较

4.如果一个操作数是布尔值,则先将其转化成数值,然后再执行比较

5如果一个操作数是对象,则先调用valueof()方法或toString()方法,再用结果比较

相等和不相等------先转换再比较;全等和不全等------仅比较而不转换

var box = 2 == 1;           //true

var box = “2” == 2;         //true    “2”会转成数值2

var box = false==0;         //true     false转成数值就是0;

var  box =“a” == “A”;        //false    转换后的编码不一样

var  box = 2 =={}     ;        // false 执行toString()或 ValueOf()会改变

var box = 2 ==NaN;        //false , 只要有NaN,都是false

var box = { } == {}           // false 比较的是他们的地址,每个新建对象的引用地址都不同

var age = { };

var  height = age;

var box = age ==height;    // true,应用地址一样,所以相等

var box = “2”===2;        // false  值和类型都必须相等

var  box = 2!==2;       // false  值和类型都相等了

总结

1.如果一个操作数是布尔值,则先将其转换成数值,true是1,false是0

2.如果一个操作数是字符串,则将其转成数值再比较

3.如果一个操作数的对象,则先调用valueOf()或toString()方法再返回值比较

4.不转换的情况下,null等于undefined

5.如果有一个操作符是NaN,则相等操作符返回false,不相等操作符返回true;NaN不等于NaN

6.如果两个操作数都是对象,则比较透明是否是同一个对象,如果都指向同一个对象,怎返回true,否则返回false

7.在全等和不全等的比较中,值和类型都相等,才返回true,否则返回false。换句话,在操作数不转换的情况下相等才是全等。

3.布尔运算符

逻辑操作符:非(not)、与(and)、或(or)。

逻辑非

逻辑非由一个叹号(!)表示,应用于任何类型。这个操作符有转换功能,把操作数转换成布尔值,然后再对其求反。返回结果只有真true和假false。

例子

alert(!false)  ;      //true

alert(!“blue”);     //false

alert(!0);         //true

alert(!NaN);     //true

alert(!“”);        //true

alert(!12345);   //false

总结:

1.如果操作数是一个对象,返回false

2.如果操作数是一个非空字符串,返回false

3.如果操作数是任何非0数值(包括Infinity),返回false

4.如果操作数是一个空字符串,返回true

5.如果操作数是数值0,返回true

6.如果操作数是数值null,返回true

7.如果操作数是数值NaN,返回true

8.如果操作数是数值undefined,返回true

逻辑与

逻辑与操作符(&&)表示。逻辑与操作符,属于短路操作,如果第一个操作能够决定结果,那么就不会再对第二个操作数求值。如果第一个操作数是false,那么第二个值无论是什么,结果都是false。

var result = true && false

x == 0 && y == 0    //只有x和y都为0,才会返回true.

逻辑与操作适应任何类型的操作数,不仅是布尔操作。

规则如下

1.如果第一个操作数是对象,责返回第二个操作数

3.如果第二个操作数是对象,则只有在第一个数的数值结果为true的情况下才会返回该对象

4.如果俩个操作数都是对象,则返回第二个操作数

5.如果第一个操作数是null,则返回null

6.如果第一个操作数是NaN,则返回NaN

7.如果第一个操作数是undefined,则返回undefined

注意:不能在逻辑与操作中实用未定义的值,会报错

逻辑或

逻辑或操作符由(||)表示。逻辑或操作符也是短路操作符,如果第一个操作数的求值结果为true,就不会对第二个操作数求值了,俩个操作数都为false,才会返回false.

如果有一个操作数不是布尔值,逻辑或不一定返回布尔值。

规则如下:

1.如果第一个数是对象,则返回第一个操作数

2.如果第一个操作数的求值结果为false,则返回第二个操作数

3.如果两个操作数都是对象,则返回第一个操作数

4.如果俩个操作数都是null,则返回null

5.如果俩个操作数都是NaN,则返回NaN

6.如果俩个操作数都是undefined,则返回undefined

条件运算符

javaScript唯一一个三元运算符,写成“?:”。

例如:x > 0 ? x : -x        //求x的绝对值

解释:如果x大于0,返回x;如果x小于0,则返回-x。

var max = (num1 > num2) ? num1:num2

赋值操作符

简单的复制操作符(=)

复合赋值操作符

num += 10和 num = num+10一样

乘赋值(*=)

除赋值(/=)

加赋值(+=)

减赋值(-=)

另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


文章名称:表达式和运算符详解-创新互联
链接URL:http://pcwzsj.com/article/ghojj.html