JavaScript 기본 유형 및 참조 유형에 대한 간략한 분석_기본 지식
JavaScript 유형의 경우 다음과 같이 간단히 요약할 수 있습니다. 강력한 유형의 언어에 비해 약한(느슨한) 유형의 언어이며 기본 유형과 참조 유형이 있으며 차이점은 고정된 공간이 있다는 것입니다. 스택 메모리에서는 고정되지 않은 공간이 힙 메모리에 저장되고 구현 위치에 대한 포인터가 스택 메모리에 저장됩니다.
시중에 나와 있는 많은 책에는 이야기할 공간이 많습니다. 이 기사에서는 JavaScript, 특히 JavaScript 유형에 대한 기본적인 이해가 필요한 여러 측면을 다룰 것입니다. 아직도 이해가 되지 않는다면 이 글을 읽기 전에 JavaScript에 관한 책을 먼저 읽어보세요.
1. 기본 유형과 참조 유형
1. 기본 유형: 정의되지 않음/Null/부울/숫자/문자열
2. 참조 유형: 객체/배열/함수/날짜/RegExp/오류/맵/설정…
왜 참조 유형을 열거하지 않았나요? 적어도 제가 말하는 이 글에서는 이 정도만 알아도 충분하니까요. 다른 것들은 거의 사용되지 않을 수 있으며 Map 및 Set과 같은 것조차도 모든 브라우저에서 지원되지 않습니다.
2. 자바스크립트 유형 판단
JavaScript에는 유형을 결정하는 데 사용할 수 있는 두 가지 연산자가 있습니다. 이들은 typeof와 instanceof이지만 원이 매우 작고 잘 섞이지 않으며 매우 신뢰할 수 없습니다. 몇몇 경우에는 정확하지만 많은 경우에는 신뢰할 수 없습니다. 한 번 살펴보면 알 수 있습니다.
// 신뢰할 수 있는 경우:
typeof ' sofish' // string
new String('sofish') instanceof String // true
// 신뢰할 수 없는 경우:
typeof [] // object
typeof null // object
'sofish' instanceof String // false
흠~ 어쩌면 많은 초보 JavaScript 프로그래머들이 이 때문에 욕을 하게 될지도 모르겠습니다. 대부분의 사람들은 JS를 사용해야 할 때 이미 jQuery와 같은 라이브러리를 가지고 있으므로 유형을 쉽게 감지할 수 있습니다. 물론 실제로는 "JavaScript에서는 모든 것이 객체입니다"라는 말이 많은 문서에서 언급된 것처럼 undefed는 실제로는 NaN 및 Infinity와 같은 전역 속성일 뿐이므로 감지하는 것이 번거롭지 않습니다. 아마 당신도 알고 있을 겁니다. 하지만 "객체"가 도움이 될 수 있습니다.
/ * 탐지 객체 유형
* @param: obj {JavaScript Object}
* @param: type {String} 대문자로 시작하는 JS 유형 이름
* @return: {Boolean}
*/
함수는(obj, type) {
return Object.prototype.toString.call(obj).slice(8, -1) === type;
}
이 경우 is 함수를 사용하면 유형을 결정하는 데 도움이 될 수 있으며 이 간단한 함수는 호환성이 좋고 프로젝트에서 사용할 수 있습니다. 예:
is('sofish', 'String' ) // true
is(null, 'Null') // true
is(new Set(), 'Set') // true
3. 자바스크립트 유형 변환
자바스크립트에서는 변수(속성)의 유형을 변경할 수 있습니다. 가장 일반적인 것은 문자열과 숫자 간의 변환입니다. 1 '2'를 12로 바꾸는 방법은 무엇입니까? JavaScript의 수학 연산자이자 문자열 하이픈인 연산자에 대한 이해가 필요합니다. 따라서 초보자는 기호를 사용할 때 때때로 계산이 원하는 것과 다르지만 - 기호를 사용하면 항상 "올바른" 답을 얻을 수 있다는 흥미로운 현상을 보게 됩니다.
1 '2' // '12'
1 ( '2') // 3
1 - '2' // -1
이는 실제로 의 이중 역할로 인해 발생합니다. 위 코드에서 두 번째 표현식은 String 앞에 숫자를 사용하여 해당 클래스가 Number로 변환되도록 하는 것을 알 수 있습니다. JavaScript 유형 변환에 대한 이해는 대부분의 경우 이중 역할이 있다는 점만 이해하면 충분합니다. 이해 가능한 다른 클래스는 할당/오버로딩을 사용하여 수정할 수 있습니다. 오류:
var err = new Error();
console .log(err instanceof Error) // true
err = 'sofish';
console.log(err) // 'sofish'
4. JavaScript 참조 유형
이 글에서는 이것이 난점입니다. 기본 유형과 비교하여 참조는 속성과 메서드를 추가할 수 있습니다. 참조와 유사한 값은 참조이며 참조 유형의 값은 변수에 할당되며 힙 메모리에 저장된 동일한 값을 가리킵니다. 변수(속성)는 오버로드될 수 있지만 복사는 매우 흥미로운 일이 될 수 있습니다. 이에 대해서는 나중에 자세히 설명하겠습니다.
1. 속성 및 메소드 추가
다음 코드에서는 기본적으로 유사한 값을 할당하면 오류를 보고하지 않지만 가져올 때 유효하지 않음을 확인할 수 있습니다.
var arr = [1,2,3];
arr.hello = 'world';
console .log(arr.hello); // '세계'
var str = 'sofish';
str.hello = 'world';
console.log(str.hello) // 정의되지 않음
2. 참조 유형 값에 대한 연산
참조 유형은 참조로 스택 메모리에 저장되므로 동일한 원래 값을 가리키면 값에 대한 작업이 모든 참조에 영향을 미칩니다. 여기서는 재할당의 예입니다(값 작업이 아님). 직접 조작)은 원래 값을 변경하지 않고 객체를 다시 생성합니다. 예:
var arr = [1, 2,3] , sofish = arr;
sofish.push('hello world');
console.log(arr) // [1, 2, 3, 'hello world']
// 동일하지 않은 유형
sofish = ['not a fish']; // sofish가 유사하게 변경되면 원래 값은 변경되지 않습니다.
console.log(arr) // [ 1, 2, 3, 'hello world']
3. 참조 유형 값 복사
원래 값에 대한 작업은 모든 참조에 영향을 미치며, 이는 반드시 우리가 원하는 것은 아닙니다. 작업 중에 다른 참조에 영향을 주지 않고 새로운 개체를 복사해야 하는 경우도 있습니다. 일반적으로 Date/Function/RegExp...와 같은 특정 작업은 거의 없으며 주로 Array 및 Object에 항목 및 속성을 추가하는 작업과 같은 작업입니다. 따라서 우리가 이해해야 할 가장 중요한 것은 Array 및 Object 객체를 복사하는 방법입니다.
3.1 배열 복사
Array 객체에는 가로채는 배열을 반환하는 슬라이스 메서드가 있습니다. ES5에서는 필터 등도 새 배열을 반환하므로 이 메서드를 사용하여 복사할 수 있습니다.
var arr = [1, 2, 3 ];
var sofish = arr.slice();
// 새 배열에 대한 작업은 원래 배열에 영향을 주지 않습니다.
sofish.push('hello world');
console.log(arr) // [1, 2, 3]
3.2 객체 복사
Array를 복사하기 위해 슬라이스 메소드를 사용합니다. 실제로 Array와 Object 모두 for ... in 루프를 사용하여 복사할 값을 할당하고 순회할 수 있습니다.
var obj = { name: 'sofish' }, sofish = {}, p;
for (p in obj) sofish[p] = obj[p];
//새 객체에 대한 작업은 원래 값에 영향을 미치지 않습니다.
sofish.say = function() {};
console.log(obj); // { name: 'sofish' }
3.3 섀도우/딥카피
위와 같은 작업을 우리는 흔히 얕은 복사(Shadow Copy)라고 부릅니다. 그러나 Array와 Object는 모두 여러 레이어(차원)를 가질 수 있습니다. 이와 같은 복사본은 가능한 값 중 최상위 레이어의 값만 고려합니다. Array와 Object는 여전히 원본 객체를 가리킵니다. 예:
var arr = [1, { bio: '물고기 아님' } ], sofish = [], p;
for(p in arr) {
sofish[p] = arr[p];
}
// `sofish`에 포함된 `cat` 개체에 대한 작업은 원래 값에 영향을 미칩니다.
sofish[1].bio = 'hackable';
console.log(arr);// [1 , cat: { bio: 'hackable' } ]
그럼 어떻게 해야 할까요? 이 문제를 해결하기 위해 copy() 함수를 사용해 보겠습니다.
/* 복사 객체
* @param: obj {JavaScript Object} 원본 객체
* @param: isDeep {Boolean} 전체 복사 여부
* @return: {JavaScript Object} 새 객체 반환
*/
function copy(obj, isDeep) {
var ret = obj.slice ? [] : {}, p, prop;
// is와 함께 사용 함수
if(!isDeep && is(obj, 'Array')) return obj.slice();
for(p in obj) {
if(!obj.hasOwnProperty(p)) continue;
prop = obj[p];
ret[p] = (is(prop, 'Object') || is(prop, 'Array')) ?
copy(prop, isDeep) : prop ;
}
return ret;
}
이런 방식으로 copy(obj, isDeep) 함수를 통해 배열이나 객체를 복사할 수 있습니다. 테스트할 수 있습니다.
var arr = [ 1, {bio : '물고기 아님'}];
var sofish = copy(arr);
// 첫 번째 레이어의 얕은 복사 작업은 원래 값에 영향을 주지 않지만 두 번째 레이어에는 영향을 줍니다.
sofish.push('cat')
console.log(arr) // [ 1, {bio: 'not a fish'}]
sofish[1].bio = 'hello world';
console.log(arr) // [1, {bio: 'hello world'}]
// 딥 카피는 원래 값에 영향을 미치지 않습니다
sofish = copy(arr, 1);
sofish[1].bio = 'foo or bar';
console.log(arr) ; // [1, {bio: 'hello world'}]
그렇습니다. 기본적으로 이해해야 할 유형에 대한 어려운 점을 모두 이해해야 합니다. 물론 복사가 가장 번거로운 점은 자주 연산해야 하는 Array, Object 외에 Date/Function/RegExp 복사도 있습니다.

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











WebSocket 및 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법 소개: 지속적인 기술 개발로 음성 인식 기술은 인공 지능 분야의 중요한 부분이 되었습니다. WebSocket과 JavaScript를 기반으로 한 온라인 음성 인식 시스템은 낮은 대기 시간, 실시간, 크로스 플랫폼이라는 특징을 갖고 있으며 널리 사용되는 솔루션이 되었습니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 음성 인식 시스템을 구현하는 방법을 소개합니다.

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

일반 함수가 Go에서 포인터 유형을 처리할 때 원래 변수에 대한 참조를 수신하여 변수 값을 수정할 수 있습니다. 전달되면 참조 유형이 복사되므로 함수가 원래 변수 값을 수정할 수 없습니다. 실제적인 예로는 일반 함수를 사용하여 문자열이나 숫자 조각을 비교하는 것이 포함됩니다.

JavaScript 및 WebSocket을 사용하여 실시간 온라인 주문 시스템을 구현하는 방법 소개: 인터넷의 대중화와 기술의 발전으로 점점 더 많은 레스토랑에서 온라인 주문 서비스를 제공하기 시작했습니다. 실시간 온라인 주문 시스템을 구현하기 위해 JavaScript 및 WebSocket 기술을 사용할 수 있습니다. WebSocket은 TCP 프로토콜을 기반으로 하는 전이중 통신 프로토콜로 클라이언트와 서버 간의 실시간 양방향 통신을 실현할 수 있습니다. 실시간 온라인 주문 시스템에서는 사용자가 요리를 선택하고 주문을 하면

WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법 오늘날의 디지털 시대에는 점점 더 많은 기업과 서비스에서 온라인 예약 기능을 제공해야 합니다. 효율적인 실시간 온라인 예약 시스템을 구현하는 것이 중요합니다. 이 기사에서는 WebSocket과 JavaScript를 사용하여 온라인 예약 시스템을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. WebSocket이란 무엇입니까? WebSocket은 단일 TCP 연결의 전이중 방식입니다.

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

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

사용법: JavaScript에서 insertBefore() 메서드는 DOM 트리에 새 노드를 삽입하는 데 사용됩니다. 이 방법에는 삽입할 새 노드와 참조 노드(즉, 새 노드가 삽입될 노드)라는 두 가지 매개 변수가 필요합니다.
