>웹 프론트엔드 >JS 튜토리얼 >js 연산자 우선순위 비교 및 ​​js 논리 연산자 분석

js 연산자 우선순위 비교 및 ​​js 논리 연산자 분석

php是最好的语言
php是最好的语言원래의
2018-08-08 17:19:543042검색

이 글에서는 연산자의 다양한 범주에 대해 자세히 설명하고 js 연산자의 우선순위에 대해 설명합니다. 우선순위는 계산된 연산자의 우선순위 수준을 의미하며 이에 대해 아래에서 자세히 소개합니다.

JS에서 연산자를 비교하는 방법은 무엇입니까? JavaScript 언어의 비교 연산자는 주로 두 피연산자의 값이 같은지, 크기가 같은지 비교하는 데 사용됩니다. 기사에는 참고 가치가 있으며 필요한 경우 수집할 수 있습니다.

연산자 개요

JavaScript는 데이터 값을 연산하기 위한 연산자 집합(연산자라고도 함)을 제공합니다.
연산자는 다양한 기능이나 연산 변수의 수에 따라 분류할 수 있습니다.

  • 산술 연산자

1. 또는 피연산자 중 두 개가 문자열 유형이면 JavaScript는 계산 전에 자동으로 숫자 값으로 변환합니다.
2. 피연산자 중 하나 또는 두 개가 문자열 유형이지만 그 안에 있는 문자가 숫자가 아닌 경우 JavaScript는 자동으로 숫자 값으로 변환합니다. 값을 NaN 결과로
3. 모든 피연산자는 NaN이고 결과는 NaN입니다.
4. 부울 값은 false이고 true는 계산을 위해 0과 1로 변환됩니다

  • 덧셈 연산자

1. 두 피연산자가 모두 숫자 값이면 덧셈이 수행됩니다
2. 문자열이 추가되는 경우 - 문자열 연결 연산자(문자열 문자열)
3. 불리언 유형이 추가되는 경우 - 불리언 유형 변환 숫자 값에 대한 덧셈 계산 수행

  • 뺄셈 연산자

1. 뺄셈 연산 전 다른 유형을 숫자 유형으로 변환한 후 계산
2. 문자열을 뺄셈하는 경우 - 문자열 유형으로 변환 숫자 값에 대해 뺄셈 계산을 수행하는 경우 - 부울형을 숫자값으로 변환한 후 뺄셈 계산을 수행합니다

  • 나머지 연산자

나머지 연산자는 2를 계산하는 데 사용됩니다. 피연산자를 나눈 후의 나머지

결과가 양수인지 음수인지는 첫 번째 피연산자는 양수 또는 음수입니다(두 번째 피연산자와는 아무 관련이 없습니다)

    console.log(100 % 3);//1
    console.log(8 % 4);//0

    console.log(100 % -3);//1
    console.log(8 % 4);//0

    console.log(-100 % 3);//-1
    console.log(-8 % 4);//0

    console.log(-100 % -3);//-1
    //与减法的情况保持一致
    console.log('卧龙学苑' % 2);//NaN

  • 증가 연산자 및 감소 연산자

자동 증가 연산자는 정수 값을 연속적으로 +1하는 데 사용되며 다음과 같이 나뉩니다.

a. 전치사 유형: 자동 증가 연산자가 피연산자 앞에 배치된 다음 값을 할당하기 전에 1을 추가합니다.

前置自增运算符 - ++变量名

b 후치형: 자동 증가 연산자가 피연산자 뒤에 위치하여 값을 먼저 할당하고 추가합니다. 1

后置自增运算符 - 变量名++

감소 연산자는 정수 값 ​​-1에 연속적으로 사용됩니다.

a 전치사 유형: 감소 연산자는 피연산자 앞에 위치하며 후치 유형을 할당하기 전에 먼저 1을 감소시킵니다. : 자기 감소 연산자를 피연산자 앞에 할당하고 1을 뺍니다

  • 연산자의 우선순위 수준 연산자에는 우선순위 수준이 계산됩니다 1. 우선순위가 높은 연산자부터 먼저 계산됩니다
    2. 연산자 수준 동일합니다. 왼쪽에서 오른쪽으로 계산됩니다.
    3. 우선순위가 가장 높은 연산자는 "()"입니다.
    4. 먼저 계산되는 표현식은 "()"로 래핑됩니다.

        console.log(100 + 200 - 150 * 3);// -150
        console.log(100 + 200 % 3);// 102
        console.log(2 * 200 % 3);// 1
    
        var num = 10;
        console.log(5 + ++num);// 16
  • 비교 연산 기호

  • JavaScript 언어의 비교 연산자는 주로 두 피연산자의 값이 같은지 또는 크기인지 비교하는 데 사용됩니다.
一.大于与小于比较运算符
    console.log(10 > 11);//false
    console.log(11 > 10);//true
    console.log(10 >= 10);//true
    // 2.boolean类型 - 将boolean类型转换为number类型
    console.log(true > false);//true
    console.log(true > 0);//true
/*
    3.string类型 - a.英文; b.中文
    * 英文或中文 - 将文本转换成Unicode码 - 对应具有数字值
    * 英文单词 - 从左至右的一次比较字母 Unicode 码的大小
*/
    console.log(&#39;a&#39; < &#39;b&#39;);//true
    console.log(&#39;a&#39; > &#39;A&#39;);//true
    console.log(&#39;abc&#39; > &#39;cba&#39;);//false
    console.log(&#39;abc&#39; > &#39;acd&#39;);//false

    console.log(&#39;我&#39; > &#39;你&#39;);//true
二.相等与不等比较运算符

동등 비교 연산자

*와 대입 연산자

* 대입 연산자(=)
*의 차이점 상등 비교 연산자(==)
불등 비교 연산자
*기호는 "!="
*"a8093152e673feb7aba1828c43532094"가 아님
상등 및 부등 비교 연산자는 피연산자의 값만 비교하고 비교형은 하지 않습니다

    // 1.number类型
    console.log(10 == 10);// true
    console.log(10 == 11);// false
    // 2.boolean类型
    console.log(true == true);// true
    console.log(true == false);// false

    console.log(true == 1);// true

    // 3.string类型
    console.log(&#39;a&#39; == &#39;a&#39;);// true
    console.log(&#39;a&#39; == &#39;b&#39;);// false
    
    console.log(&#39;100&#39; == 100);// true

三.全等与不全等运算符 
全等与不全等运算符 不仅比较值 还比较类型
    console.log(10 === 10);// true

    console.log(&#39;10&#39; === 10);// false
    console.log(&#39;10&#39; == 10);// true

    function
  • isNaN() 함수는 해당 매개 변수가 NaN 값(숫자가 아닌 값)인지 확인하는 데 사용됩니다.
Function: 현재 값이 NaN인지 확인

true - 현재 값이 NaN( 숫자 값이 아님)
false - 현재 값이 NaN이 아님을 나타냅니다(숫자 값 아님)
isFinite() 함수
함수 - 현재 값이 무한대인지 확인
false - 현재 값이 무한대임을 나타냄
true - 현재 값이 유한 값임을 나타냅니다.

    console.log(isNaN(100));// false
    console.log(isNaN(Number(&#39;卧龙学苑&#39;)));// true

    var result = 100/0;
    console.log(result);// Infinity
    //isFinite()函数
    console.log(isFinite(result));// false

    논리 AND 연산자
  • 자바스크립트 연산자의 기본 사용법은 부울 유형 계산입니다.
논리 AND 연산자 두 피연산자가 모두 부울 유형인 경우 둘 다인 경우에만 반환됩니다. 피연산자는 true 결과는 true, 그렇지 않으면 false입니다.

1. 논리 AND 연산자의 두 피연산자를 부울 유형으로 변환합니다.
2 왼쪽의 피연산자가 true인 경우 결과는 오른쪽의 피연산자의 값입니다.
3. 왼쪽 피연산자가 false일 때 결과는 왼쪽 피연산자의 값이 됩니다

    console.log(true && true);// true
    console.log(true && false);// false
    console.log(false && true);// false
    console.log(false && false);// false

    console.log(100 && 1);// 1
    console.log(1 && 0);// 0
    console.log(0 && 1);// 0
    console.log(0 && 0);// 0

    console.log(true && true);
    console.log(true && false);
    console.log(false && true);
    console.log(false && false);

    console.log(&#39;卧龙学苑&#39; && &#39;卧龙学苑&#39;);// 卧龙学苑
    console.log(&#39;卧龙学苑&#39; && &#39;&#39;);// &#39;&#39;
    console.log(&#39;&#39; && &#39;卧龙学苑&#39;);// &#39;&#39;
    console.log(&#39;&#39; && &#39;&#39;);// &#39;&#39;

    console.log(&#39;卧龙学苑&#39; && 1);// 1
    console.log(false && 0);// false

    논리 OR 연산자
  • 논리 OR 연산자를 사용할 때 두 피연산자가 모두 불리언 타입이면 , 피연산자 유형 숫자 중 하나가 다음인 경우에만 반환된 결과는 true일 때만 true이고, 그렇지 않으면 false입니다
    console.log(true || true);// true
    console.log(true || false);// true
    console.log(false || true);// true
    console.log(false || false);// false

    console.log(100 || 1);// 100
    console.log(1 || 0);// 1
    console.log(0 || 1);// 1
    console.log(0 || 0);// 0

    console.log(true || true);
    console.log(true || false);
    console.log(false || true);
    console.log(false || false);

    console.log(&#39;卧龙学苑&#39; || &#39;卧龙学苑&#39;);// 卧龙学苑
    console.log(&#39;卧龙学苑&#39; || &#39;&#39;);// 卧龙学苑
    console.log(&#39;&#39; || &#39;卧龙学苑&#39;);// 卧龙学苑
    console.log(&#39;&#39; || &#39;&#39;);// &#39;&#39;

    할당 확장 연산자
  • JavaScript 언어의 할당 연산자는 변수에 값을 할당하는 데 사용됩니다. 또는 속성
자바스크립트 언어의 할당 확장 연산자 실제로는 할당 연산자와 산술 연산자를 함께 사용하는 단축 모드입니다

자바스크립트 언어의 할당 확장 연산자는 실행 효율이 더 높습니다

    var b = 10, c = 20;

    var a = b + c;
    console.log(a);// 30

    // b = b + c;
    // 等价写法 - 赋值扩展运算符的性能要比赋值运算符更高
    b += c;
    console.log(b);// 30

  • 条件运算符

条件运算符 首先判断一个表达式是真是假 然后根据判断结果执行两个给指定指令中的一个

    var result = 8 > 9 ? &#39;对&#39; : &#39;错&#39;;
    console.log(result);

    var score = 95;
    score > 90 ? console.log(&#39;优秀&#39;) : console.log(&#39;及格&#39;);
  • 嵌套条件运算符

条件运算符中 每个表达式可以又是一个条件运算表达式 称为条件运算的嵌套
优点:扩展了条件运算符本身的计算能力
缺点:可读性比较差 性能随着嵌套的层级越多越差
建议:不要最多不要超过三层嵌套

    var score = 55;

    var result = score > 90 ? &#39;优秀&#39; : (score > 80 ? &#39;良好&#39; : (score > 60 ? &#39;及格&#39; : &#39;不及格&#39;));
    console.log(result);

相关推荐:

js比较和逻辑运算符的介绍

运算符优先级-PHP运算符优先级

위 내용은 js 연산자 우선순위 비교 및 ​​js 논리 연산자 분석의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.