> 웹 프론트엔드 > JS 튜토리얼 > TypeScript를 사용하여 스크립트에 추가

TypeScript를 사용하여 스크립트에 추가

Barbara Streisand
풀어 주다: 2025-01-08 07:01:13
원래의
900명이 탐색했습니다.

Adding to the Script with TypeScript

표지 이미지 출처: Daria Kraplak

목차

소개
TypeScript의 목적
JavaScript와 TypeScript 비교
결론

소개

TypeScript가 무엇인지 알아보기 전에 먼저 JavaScript에 대해 이야기해 보겠습니다! JavaScript가 1995년에 발명되었다는 사실을 알고 계셨나요? 나도 마찬가지였다.

이 기간 동안 사람들의 브라우저에서 간단한 웹페이지를 처리해야 하는 요구를 충족했습니다. 1999년 이후 JavaScript는 개선되었으며 오늘날 우리가 구축하고 있는 재미있고 역동적인 웹 페이지를 처리할 수 있습니다. 또한 데이터 유형(여기서 약간의 스포일러)이 유연하기 때문에 상당히 사용하기 쉬운 프로그래밍 언어입니다.

그러나 해결되지 않은 문제가 있었습니다. 아이러니하게도 JavaScript가 사용하기 쉬운 이유는 JavaScript가 코드를 손상시킬 수 있는 이유와 같습니다. TypeScript가 우리를 도울 수 있는 곳이 바로 여기입니다!

TypeScript의 목적

TypeScript는 JavaScript의 상위 집합입니다. 이것은 무엇을 의미합니까? 글쎄, 어떤 사람들에게는 TypeScript가 기존 JavaScript 코드를 지원하는 데 사용되기 때문에 프로그래밍 언어가 아닙니다. 그럼에도 불구하고 TypeScript는 코드 구조를 강화하여 JavaScript 사용자를 돕습니다. 이는 우리가 가지고 있는 각 변수에 대한 데이터 유형의 일관성을 보장함으로써 수행됩니다. 이는 개발 중에 잠재적인 버그를 강조하고 코드가 JavaScript로 컴파일되기 전에 경고하기 때문에 테스트할 때 유용합니다.

JavaScript와 TypeScript 비교

그들은 이러한 데이터 유형을 공유합니다

  • 문자열
  • 번호
  • 부울
  • 정의되지 않음

그러나 이를 구현하려면 다른 접근 방식이 필요합니다. 방법을 보여드리겠습니다!

추론

JavaScript에서 변수를 정의할 때 해당 데이터 유형은 나중에 원할 경우 변경될 수 있습니다. 변수의 데이터 유형은 TypeScript에 의해 추론되거나 명시적으로 명시되므로 TypeScript에 대해서는 다른 이야기입니다. 변수의 데이터 유형은 추론할 수 없거나 명시적으로 명시되지 않은 경우 어떤 것이든 될 수 있습니다!

// JavaScript 
let x = 6;  // x stores a number value.  
x = "Hello there";  // x is now storing a string value.  
// This is valid since JavaScript allows dynamic type reassignment.  

// TypeScript 
let x = 6;  // x stores a number value.  
// (For line below) Error: Type string is not assignable to type number.  
x = "Hello there";  
// The reassigned value below matches the inferred or declared type of 
// the variable. TypeScript is okay with this.  
x = 8;  

// For both 
// x stores a number value and does not allow reassignment here. 
const x = 20; 
// Error: Cannot assign to 'x' because it is a constant.  
x = 25; 
로그인 후 복사
로그인 후 복사

유형 주석

위 하위 섹션에 이어 TypeScript에서 변수의 데이터 유형을 명시적으로 기술할 수 있는 또 다른 방법은 유형 주석을 사용하는 것입니다. 이는 변수 이름을 지정한 후 콜론과 유형(: )을 추가하는 것을 의미합니다.

// JavaScript 
let x = 6;  // x stores a number value.  
x = "Hello there";  // x is now storing a string value.  
// This is valid since JavaScript allows dynamic type reassignment.  

// TypeScript 
let x = 6;  // x stores a number value.  
// (For line below) Error: Type string is not assignable to type number.  
x = "Hello there";  
// The reassigned value below matches the inferred or declared type of 
// the variable. TypeScript is okay with this.  
x = 8;  

// For both 
// x stores a number value and does not allow reassignment here. 
const x = 20; 
// Error: Cannot assign to 'x' because it is a constant.  
x = 25; 
로그인 후 복사
로그인 후 복사

모양

TypeScript에서 "모양"은 무엇을 의미하나요? 예를 들어, 문자열의 경우 메서드에는 고유한 속성이 있습니다. 이러한 "속성"은 변수의 "모양" 또는 구조를 구성합니다. 변수의 속성에 접근하려면 먼저 사용 중인 메서드가 필요한 정보를 제공하는지 확인해야 합니다. JavaScript는 이에 대해 엄격하지 않으며 런타임에 변수의 모양을 변경할 수 있습니다. 그러나 TypeScript는 변수의 정확한 속성을 검색하므로 주의해야 합니다. 마치 블록을 모양에 맞게 윤곽선에 맞추는 것과 같습니다.

// JavaScript 
// No need to state the data type here, just assign the variable a value. 
let color = ‘purple’;
// Since JavaScript is flexible, it is fine with this reassignment. 
color = ‘blue’;
// This is also the case even if the value changes to 10. 

// TypeScript 
// 'color' is declared and expected to have a string value.  
let color: string;
// Similar to the line above, except we assign a value as well.  
let color: string = 'red';
color = ‘purple’;  // 'purple' is a string value, so this is valid.  
color = ‘blue’;  // 'blue' is a string value, so this is valid.  
로그인 후 복사

이것 말고도 많아요!

결론

지금까지 TypeScript에 대한 나의 첫인상은 이러했습니다. 나는 JavaScript가 이미 우리를 위해 할 수 있는 일을 어떻게 향상시킬 수 있는지에 매료되었다고 말해도 무방합니다. 나는 더 많은 것을 배우고 그것을 내 JavaScript 프로젝트에 구현하고 싶습니다!

이 내용이 JavaScript와 함께 샌드박스/도구 상자에 TypeScript를 추가하는 데 관심을 갖게 되기를 바랍니다. 코드가 더 잘 구성되는 것을 원하지 않는 사람이 누가 있겠습니까?

위 내용은 TypeScript를 사용하여 스크립트에 추가의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿