웹 프론트엔드 JS 튜토리얼 JavaScript 표현식 및 Operators_javascript 기술에 대한 자세한 설명

JavaScript 표현식 및 Operators_javascript 기술에 대한 자세한 설명

May 16, 2016 pm 03:29 PM
javascript 표현 연산자

JavaScript 스크립팅 언어는 단항 연산자, 부울 연산자, 산술 연산자, 관계형 연산자, 삼항 연산자, 비트 연산자 및 할당 연산자를 포함하여 데이터 값을 조작하는 일련의 연산자를 설명합니다.
표현식은 변수 이름(또는 리터럴)과 연산자를 포함하는 JavaScript 언어의 "문구"입니다. 가장 간단한 표현식은 리터럴 또는 변수 이름입니다. 물론 간단한 표현식을 결합하여 복잡한 표현식을 만드는 방법도 있습니다.
1. 단항 연산자
(1) 증가 및 감소 --

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 
로그인 후 복사

전면과 후면의 차이

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 
로그인 후 복사

할당 연산이 없는 경우 접두어와 접미어는 동일합니다. 그러나 대입연산시 증감연산자가 앞에 있으면 선행연산자가 먼저 적산되거나 감소된 후 대입된다. 후치연산자라면 값이 먼저 대입되고 그 다음에 적산 또는 감소된다.
(2) 덧셈과 뺄셈 연산자
은 양수 또는 음수 연산에 사용되며, 숫자 문자열을 숫자 형식으로 변환하는 기능도 있습니다.

var box = "20"; 
document.write(typeof box+"<br/>"); //输出string 
var age=-box; 
document.write(age+"<br/>");//输出-20 
document.write(typeof age); //输出number 
로그인 후 복사

2. 산술 연산자
JavaScript 언어에는 5개의 산술 연산자, 즉 , -, *, / 및 %(나머지)가 지정되어 있습니다. 산술 연산자의 값이 숫자 값이 아닌 경우 먼저 Number() 변환 함수(암시적 변환)를 사용하여 숫자 값으로 변환됩니다.

var box=100+"100"; 
document.write("box="+box+"<br/>");//输出100100 
document.write(typeof box);//输出string 
로그인 후 복사

왜 그럴까요? JavaScript 언어로 산술 연산을 수행할 때 그 중 하나가 문자열이면 결과는 문자열로 변환됩니다. 문자열 연결 연산자와 동일하며 더 이상 덧셈 산술 연산자로 계산될 수 없습니다.

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 
로그인 후 복사

나머지 가져오기

var box=10%3; 
document.write("box="+box);//输出1 
로그인 후 복사

3. 관계 연산자
비교에 사용되는 연산자를 관계 연산자라고 합니다: <(보다 작음), >(보다 큼), <=(작거나 같음), >=(크거나 같음), = =(상대), !=(같지 않음), ===(동일 또는 일치), !==(일치 또는 동일하지 않음). 대부분의 관계 연산자는 부울 값을 반환합니다.
다른 연산자와 마찬가지로 관계 연산자가 숫자가 아닌 값에 대해 연산을 수행할 때는 다음 규칙을 따라야 합니다.
​ ​ 1두 연산자 모두 수치값이고 수치비교
​ ​ 2두 피연산자가 모두 문자열인 경우 두 문자열에 해당하는 문자 인코딩 값을 비교
​ ​ 3두 피연산자 중 하나가 숫자값이면 다른 하나를 숫자값으로 변환하여 수치비교
​ 4두 피연산자 중 하나가 객체인 경우 value() 메서드나 toString() 메서드를 먼저 호출한 후 결과를 비교합니다.

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 
로그인 후 복사

동등 및 불평등 비교에서 피연산자가 숫자가 아닌 값인 경우 다음 규칙이 적용됩니다.
​ ​ 1피연산자가 부울 값인 경우 비교 전 수치로 변환하고, false는 0, true는 1로 변환한다.
​ ​ 2피연산자 중 하나가 문자열인 경우 비교 전 수치로 변환한 후 비교한다.
​ ​ 3피연산자가 객체인 경우 value() 메서드나 toString() 메서드를 먼저 호출한 후 비교합니다.
​ ​ 4 변환하지 않으면 null과 undefine이 동일합니다
​ ​ 5피연산자가 NaN이면 ==는 false를 반환하고 !=는 true를 반환하며 NaN은 자신과 같지 않습니다
​ 6두 피연산자가 모두 객체이면 동일한 객체인지 비교하여 둘 다 동일한 객체를 가리키면 true를 반환하고, 그렇지 않으면 false를 반환합니다
​ ​ 7합동과 합동의 판단에서 예를 들어 값과 유형이 동일하면 true를 반환하고, 그렇지 않으면 fasle을 반환합니다.

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语言中包括了七种位运算符:~(位非),&(位与),|(位或),^(位异或),<<(左移),>>(有符右移号),>>>(无符号右移)
(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)无符号右移运算也是对二进制数进行操作,对于正数,与有符号右移是相同的结果,但是对于负数,就会所不同。

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

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的表达式与运算符的全部内容,希望对大家的学习有所帮助。

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

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

WebSocket 및 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 WebSocket 및 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 Dec 17, 2023 pm 05:30 PM

WebSocket과 JavaScript: 실시간 모니터링 시스템 구현을 위한 핵심 기술 서론: 인터넷 기술의 급속한 발전과 함께 실시간 모니터링 시스템이 다양한 분야에서 널리 활용되고 있다. 실시간 모니터링을 구현하는 핵심 기술 중 하나는 WebSocket과 JavaScript의 조합입니다. 이 기사에서는 실시간 모니터링 시스템에서 WebSocket 및 JavaScript의 적용을 소개하고 코드 예제를 제공하며 구현 원칙을 자세히 설명합니다. 1. 웹소켓 기술

C 언어에서 += 연산자의 의미와 사용법 분석 C 언어에서 += 연산자의 의미와 사용법 분석 Apr 03, 2024 pm 02:27 PM

+= 연산자는 왼쪽 피연산자의 값을 오른쪽 피연산자의 값에 더하고 그 결과를 왼쪽 피연산자에 할당하는 데 사용됩니다. 이는 숫자형에 적합하며 왼쪽 피연산자는 쓰기 가능해야 합니다.

JavaScript와 WebSocket: 효율적인 실시간 일기예보 시스템 구축 JavaScript와 WebSocket: 효율적인 실시간 일기예보 시스템 구축 Dec 17, 2023 pm 05:13 PM

JavaScript 및 WebSocket: 효율적인 실시간 일기 예보 시스템 구축 소개: 오늘날 일기 예보의 정확성은 일상 생활과 의사 결정에 매우 중요합니다. 기술이 발전함에 따라 우리는 날씨 데이터를 실시간으로 획득함으로써 보다 정확하고 신뢰할 수 있는 일기예보를 제공할 수 있습니다. 이 기사에서는 JavaScript 및 WebSocket 기술을 사용하여 효율적인 실시간 일기 예보 시스템을 구축하는 방법을 알아봅니다. 이 문서에서는 특정 코드 예제를 통해 구현 프로세스를 보여줍니다. 우리

간단한 JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법 간단한 JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법 Jan 05, 2024 pm 06:08 PM

JavaScript 튜토리얼: HTTP 상태 코드를 얻는 방법, 특정 코드 예제가 필요합니다. 서문: 웹 개발에서는 서버와의 데이터 상호 작용이 종종 포함됩니다. 서버와 통신할 때 반환된 HTTP 상태 코드를 가져와서 작업의 성공 여부를 확인하고 다양한 상태 코드에 따라 해당 처리를 수행해야 하는 경우가 많습니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법과 몇 가지 실용적인 코드 예제를 제공합니다. XMLHttpRequest 사용

Python 구문 마인드맵: 코드 구조에 대한 심층적인 이해 Python 구문 마인드맵: 코드 구조에 대한 심층적인 이해 Feb 21, 2024 am 09:00 AM

Python은 간단하고 읽기 쉬운 구문으로 다양한 분야에서 널리 사용됩니다. 프로그래밍 효율성을 높이고 코드 작동 방식을 깊이 이해하려면 Python 구문의 기본 구조를 숙지하는 것이 중요합니다. 이를 위해 이 기사에서는 Python 구문의 다양한 측면을 자세히 설명하는 포괄적인 마인드 맵을 제공합니다. 변수 및 데이터 유형 변수는 Python에서 데이터를 저장하는 데 사용되는 컨테이너입니다. 마인드맵은 정수, 부동 소수점 숫자, 문자열, 부울 값 및 목록을 포함한 일반적인 Python 데이터 유형을 보여줍니다. 각 데이터 유형에는 고유한 특성과 작업 방법이 있습니다. 연산자 연산자는 데이터 유형에 대한 다양한 작업을 수행하는 데 사용됩니다. 마인드맵은 산술 연산자, 비율 등 Python의 다양한 연산자 유형을 다룹니다.

JavaScript에서 HTTP 상태 코드를 쉽게 얻는 방법 JavaScript에서 HTTP 상태 코드를 쉽게 얻는 방법 Jan 05, 2024 pm 01:37 PM

JavaScript에서 HTTP 상태 코드를 얻는 방법 소개: 프런트 엔드 개발에서 우리는 종종 백엔드 인터페이스와의 상호 작용을 처리해야 하며 HTTP 상태 코드는 매우 중요한 부분입니다. HTTP 상태 코드를 이해하고 얻는 것은 인터페이스에서 반환된 데이터를 더 잘 처리하는 데 도움이 됩니다. 이 기사에서는 JavaScript를 사용하여 HTTP 상태 코드를 얻는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. HTTP 상태 코드란 무엇입니까? HTTP 상태 코드는 브라우저가 서버에 요청을 시작할 때 서비스가

Go 언어의 연산자 우선 순위 목록, 어떤 연산자의 우선 순위가 가장 높습니까? Go 언어의 연산자 우선 순위 목록, 어떤 연산자의 우선 순위가 가장 높습니까? Jan 03, 2024 pm 04:59 PM

Go 언어에는 다양한 수학적, 논리적 연산을 수행하는 데 자주 사용되는 많은 연산자가 있습니다. 각 연산자에는 표현식에서 평가되는 순서를 결정하는 고유한 우선 순위가 있습니다. 이 글에서는 Go 언어 연산자의 우선순위 순위를 소개하고 우선순위가 가장 높은 연산자를 알아봅니다. Go 언어의 연산자는 우선순위가 높은 것부터 낮은 것 순으로 괄호: ()입니다. 괄호는 연산자의 우선순위를 변경하는 데 사용됩니다. 표현식의 괄호가 먼저 평가됩니다. 단항 연산자: +, -, !. 단항 연산자는 단 하나만 의미합니다.

Python 연산자: 초보자부터 마스터까지 최고의 가이드 Python 연산자: 초보자부터 마스터까지 최고의 가이드 Mar 11, 2024 am 09:13 AM

Python 연산자 소개 연산자는 둘 이상의 피연산자 사이에서 연산을 수행하는 데 사용되는 특수 기호 또는 키워드입니다. Python은 기본적인 수학 연산부터 복잡한 데이터 조작에 이르기까지 광범위한 용도를 포괄하는 다양한 연산자를 제공합니다. 수학 연산자 수학 연산자는 일반적인 수학 연산을 수행하는 데 사용됩니다. 여기에는 다음이 포함됩니다. 연산자 연산 예 + 덧셈 a + b - 뺄셈 a-b * 곱셈 a * b / 나눗셈 a / b % 모듈로 연산(나머지 취함) a % b ** 거듭제곱 연산 a ** b // 정수 나눗셈(생략 나머지) a//b 논리 연산자 논리 연산자는 부울 값을 연결하고 조건을 평가하는 데 사용됩니다. 여기에는 다음이 포함됩니다. 연산자 연산 예제 및 논리 및 a및b논리 또는 aorbnot논리 nota비교 연산

See all articles