Maison >interface Web >js tutoriel >Explication détaillée des expressions JavaScript et des compétences opérateurs_javascript

Explication détaillée des expressions JavaScript et des compétences opérateurs_javascript

WBOY
WBOYoriginal
2016-05-16 15:29:041195parcourir

Le langage de script JavaScript décrit un ensemble d'opérateurs pour exploiter les valeurs de données, notamment les opérateurs unaires, les opérateurs booléens, les opérateurs arithmétiques, les opérateurs relationnels, les opérateurs ternaires, les opérateurs au niveau du bit et les opérateurs d'affectation.
Une expression est une « phrase » dans le langage JavaScript, comprenant un nom de variable (ou littéral) et un opérateur. Les expressions les plus simples sont des littéraux ou des noms de variables. Bien entendu, il existe également des moyens de combiner des expressions simples pour créer des expressions complexes.
1. Opérateur unaire
(1) Augmentation et diminution--

var box1=100; 
++box1;//相当于box=box+1 
document.write("box1="+box1+"<br/>");//输出box1=101 
var box2=100; 
--box2;//相当于box=box2-1 
document.write("box2="+box2);//输出box2=99 

La différence entre l'avant et l'arrière

var box=100; 
var age=++box;//box先累加1为101,再赋值给age为101 
var height=box++;//box先赋值给height为101,box再累加为102 
document.write("age="+age+"<br/>");//输出age=101 
document.write("height="+height+"<br/>");//输出height=101 
document.write("box="+box);//输出box=102,原因是box经过了两次累加,所以是102 

Lorsqu'il n'y a pas d'opération d'affectation, le préfixe et le suffixe sont identiques. Cependant, lors de l'opération d'affectation, si l'opérateur d'incrémentation ou de décrémentation est précédé, l'opérateur précédent sera d'abord accumulé ou décrémenté puis attribué. S'il s'agit d'un opérateur postpositionné, la valeur sera affectée d'abord puis accumulée ou décrémentée.
(2) Opérateurs d'addition et de soustraction
est utilisé pour les opérations positives ou négatives, et a également pour fonction de convertir des chaînes numériques en formes numériques.

var box = "20"; 
document.write(typeof box+"<br/>"); //输出string 
var age=-box; 
document.write(age+"<br/>");//输出-20 
document.write(typeof age); //输出number 

2. Opérateurs arithmétiques
Il existe cinq opérateurs arithmétiques spécifiés dans le langage JavaScript, à savoir , -, *, / et % (reste). Si la valeur d'un opérateur arithmétique n'est pas une valeur numérique, elle sera d'abord convertie en valeur numérique à l'aide de la fonction de conversion Number() (conversion implicite).

var box=100+"100"; 
document.write("box="+box+"<br/>");//输出100100 
document.write(typeof box);//输出string 

Pourquoi ça ? Lorsque vous effectuez des opérations arithmétiques dans le langage JavaScript, tant que l'une d'elles est une chaîne, le résultat sera converti en chaîne. Équivalent à l'opérateur de concaténation de chaînes et ne peut plus être considéré comme un opérateur arithmétique d'addition.

var box="100"-10; 
document.write("box="+box+"<br/>");//输出90 
var age=5/4; 
document.write("age="+age+"<br/>");//输出1.25 
var height=("你的年龄是:"+(10+10));//括号强制优先级 
document.write(height);//输出你的年龄是:20 

Obtenez le reste

var box=10%3; 
document.write("box="+box);//输出1 

3. Opérateurs relationnels
Les opérateurs utilisés pour la comparaison sont appelés opérateurs relationnels : 0d46f4c09d566506ef1667e3751fd349 (supérieur à), 8c696243fa2a77c2c84c301d4d0a36bd= (supérieur ou égal à), = = (relatif), != (non égal), === (identique ou congruent), !== (non congruent ou non identique). La plupart des opérateurs relationnels renvoient une valeur booléenne.
Comme les autres opérateurs, les règles suivantes doivent être respectées lorsque les opérateurs relationnels opèrent sur des valeurs non numériques :
​ ​ 1Les deux opérateurs sont des valeurs numériques, donc comparaison numérique
​ ​ 2Si les deux opérandes sont des chaînes, comparez les valeurs d'encodage des caractères correspondant aux deux chaînes
​ ​ 3Si l'un des deux opérandes est une valeur numérique, convertissez l'autre en valeur numérique et effectuez une comparaison numérique
​ ​ 4Si l'un des deux opérandes est un objet, appelez d'abord la méthode value() ou la méthode toString(), puis comparez les résultats.

var box1=3>2; 
document.write(box1+"<br/>");//输出true 
var box2="3">22; 
document.write(box2+"<br/>");//输出false 
var box3="3">"22"; 
document.write(box3+"<br/>");//输出true 
var box4="a">"B";//a为97,B为66 
document.write(box4+"<br/>");//输出true 
var box5= "Blue"<"alpha";//Blue的第一个字母是B,alpha的第一个字母是a,a为97,B为66 
document.write(box5) //输出true 

Dans les comparaisons d'égalité et d'inégalité, si l'opérande est une valeur non numérique, les règles suivantes s'appliquent :
​ ​ 1Si un opérande est une valeur booléenne, il est converti en valeur numérique avant comparaison, false est converti en 0 et true est converti en 1.
​ ​ 2Si un opérande est une chaîne, il sera converti en valeur numérique avant comparaison puis comparé.
​ ​ 3Si un opérande est un objet, appelez d'abord la méthode value() ou la méthode toString(), puis comparez.
​ ​ 4 Sans aucune conversion, null et indéfini sont égaux
​ ​ 5Si un opérande est NaN, alors == renvoie faux, != renvoie vrai et NaN n'est pas égal à lui-même
​ ​ 6Si les deux opérandes sont des objets, comparez s'il s'agit du même objet. S'ils pointent tous les deux vers le même objet, renvoyez vrai, sinon renvoyez faux
. ​ ​ 7Dans le jugement de congruence et de congruence, par exemple, si les valeurs​​et les types sont égaux, true sera renvoyé, sinon fasle sera renvoyé.

var box1='2'==2; 
document.write(box1+"<br/>");//输出true,比较的只是数值 
var box2={}=={}; 
document.write(box2+"<br/>");//输出false,因为比较的是它们的地址,每个新创建对象的引用地址都不同。 
var box3=null==undefined; 
document.write(box3+"<br/>");//输出true,因为均为空数值 
var box4='2'===2; 
document.write(box4+"<br/>");//输出false,两个操作数的数据类型不相等 
var box5=null===undefined; 
document.write(box5);//输出false,两个操作数的数据类型不相等 

四逻辑运算符
       JavaScript语言中的逻辑运算符通常作用于布尔值的操作,一般和关系运算符配合使用,有三个逻辑运算符:&&(逻辑与),||(逻辑或)和!(逻辑非)。
       (1)&&表示两边都必须是true,才返回true。
       如果两边的操作数有一个操作数不是布尔值的情况下,与运算就不一定返回布尔值,此时遵循下面的规则:
       1第一个操作数是对象,则返回第二个操作数
       2第二操作数是对象,则第一个操作数返回true,才返回第二个操作数,否则返回false
       3一个操作数是null,则返回null
       4一个操作数是undefined,则返回undefined
       5如果一个运算数是对象,另一个是 Boolean 值,返回该对象
      逻辑与运算符属于短路操作,如果有第一个操作数返回的是false,第二个不管是true还是false都返回false。

var box1={}&&(5>4); 
document.write(box1+"<br/>");//输出true 
var box2=(5>4)&&{}; 
document.write(box2+"<br/>");//输出[object Object] 
var box3=(3>4)&&{}; 
document.write(box3);//输出false 

      (2)||表示两边有一个是true,就返回true。
      如果两边的操作数有一个操作数不是布尔值的情况下,与运算就不一定返回布尔值,此时遵循下面的规则:
      1第一个操作数是对象,则返回第一个个操作数
      2第一个操作数的求值结果为fasle,则返回第二个操作数
      3两个操作数都是对象,则返回第一个操作数
      4两个操作数都是null,则返回null
      5两个操作数都是undefined,则返回undefined
      6两个操作数都是NaN,则返回NaN
      逻辑或运算符也属于短路操作,如果有第一个操作数返回的是true,第二个不管是true还是false都返回true。

var box1={}||(5>4); 
document.write(box1+"<br/>");//输出[object Object] 
var box2=(5>4)||{}; 
document.write(box2+"<br/>");//输出true 
var box3=(3>4)||{}; 
document.write(box3);//输出[object Object] 

      (3)!逻辑非运算符可以作用与任何值,无论这个值是什么数据类型,这个运算符都会返回一个布尔值,它的流程是:先将这个值转换成布尔值,然后取反,规则如下:
      1操作数是一个对象,返回false
      2操作数是一个空字符串,返回true
      3操作数是一个非空字符串,返回false
      4操作数是数值0,返回true
      5操作数是任意非0数值,返回false
      6操作数是null,返回true
      7操作数是NaN,返回true
      8操作数是undefined,返回true

var box=!{}; 
document.write(box);//输出false 

五、位运算符
      JavaScript语言中包括了七种位运算符:~(位非),&(位与),|(位或),^(位异或),07a9f8d2db86bbcbe97add37a18921f4>(有符右移号),>>>(无符号右移)
       (1)位非(~)运算把运算数转换成32位数字,然后把二进制数转换成它的二进制反码,最后把二进制数转换成浮点数。实质上是对数字求负,然后减去1即为所得值。

var box=~25; 
document.write(box);//输出-26 

       (2)位与(&)运算直接对数字的二进制形式进行运算,然后对上下同一位置的两个数位进行与运算,只有两个数位都为1时才得出1,其余的均为0.

var box=25&3; 
document.write(box);//输出1 

       (3)位或(|)运算也是直接对数字的二进制形式进行计算,然后对上下同一位置的两个数位进行或运算,只右两个数位都为0时才得出0,其余的均为1.

var box=25|3; 
document.write(box);//输出27 

       (4)位异或(^)也是直接对二进制形式进行运算。当只有一个数位存放的是1时,它才返回1。其余的返回0。也就是两个数位相同时返回0,不同时返回1.

var box=25^3; 
document.write(box);//输出26 

       (5)左移运算也是对二进制数进行操作,相等于第一个操作数乘以(2的左移位数次幂)的积。

var box=25<<3; 
document.write(box);//25左移3位相当于25乘以(2的3次幂),因此输出200 

        (6)有符号右移运算也是对二进制数进行操作,相等于第一个操作数除以(2的右移位数次幂)的商。

var box=24>>2; 
document.write(box);//输出6 

       (7)无符号右移运算也是对二进制数进行操作,对于正数,与有符号右移是相同的结果,但是对于负数,就会所不同。
     

六、赋值运算符
      赋值运算符包括:=(),+=(),-=(),*=(),/=(),%=(),0663d4763dbaf5863b4f59f6fe914354>=(),>>>=()。

var box=100; 
box+=100;//相当于box=box+100 
document.write("box="+box);//输出box=200 

七、其他运算符
1)、字符串运算符:“+”,它的作用是将两个字符串想加。规则:只要有一个字符串即可。

var box=100+"10"'; 
document.write("box="+box);//输出100100 

2)、逗号运算符,可以在一条语句中执行多个操作

var box=100,age=200,height=300; 
document.write("box="+box);//输出box=100 

3)、三元操作符:

var box=(3>4)&#63;"对":"错"; 
document.write(box);//输出错 

      如果想更详细的了解ECMAScript运算符的知识,可以访问JavaScript高级教程中的ECMASscript一元运算符这个系列中有详细的运算符教程。对于JS的运算符来说,我们可以对比着C++,C#和Java来学,这个还是相当的容易的。

以上就是关于JavaScript的表达式与运算符的全部内容,希望对大家的学习有所帮助。

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn