favicon같은 정적요소들 지속적을 dist에서 관리하여 나타내기

parcel-plugin-static-files-copy

favicon같은 파일들이 npm으로 만들어지는 dist폴더안에 자동으로 계속 저장될수 있도록 설정을 위해 사용한다.

관리할 폴더를 생성하여 안에 든 파일들은 자동으로 dist안에 저장될수 있도록 설정한다. package.json으로 관리할 폴더 경로를 지정해준다.

static폴더 생성후 package.json으로 관리할 폴더경로를 지정한다.

 

POSTCSS 와 AUTOPREFIXER

npm i -D postcss autoprefixer

웹에서 쓸 수 있는 요소에 따라 적용되거나 적용해지 될지 결정해주는것으로

설치후

browserslist옵션은 현재 npm 프로젝트에서 지원할 브라우저의 범위를 명시하는 용도이다. 해당 옵션은 전 세계 점유율이 1% 이상인 모든 브라우저의 마지막 2개버전 까진 지원하겠다는 옵션

 

ESM 즉 자바스크립트 모듈에서는 Import/export를 사용하며

노드js에서는 commonJS를 사용하여 require() / module.exports를 사용한다.

autoprefixer JS선언 Import / export

 

bootstrap npm으로 import설정하기 (이후 import시 via java로 초기화,성능최적화 해야함)

scss :

@import "/node_modules/bootstrap/scss/bootstrap.scss"

js:

import bootstrap from './node_modules/bootstrap/dist/js/bootstrap.bundle'

 

 

bootstrap 정해진 요소들 커스텀마이징 하기

$theme-color은 scss/variables에 들어있다.

 

bootstrap등 성능최적화 옵티마이징하기

bootstrap처럼 모든 요소가 들어가있는것을 import하면 무거워지므로 dropdown같은 사용할요소만 지정하여 import한다. 하지만 bootstrap은 popper을 외부에서 가져와 사용하므로 bootstrap을 통째로 import하면 문제가 없지만 사용할 요소만 import하면 popper가 설치되지 않아 오류가 발생하니 popperjs를 일반의존성@으로 설치한다.

bootstrap의 각 요소들은 js/dist안에있다.

npm i @popperjs/core

dropdown 초기화 및 최적화 , 변수선언 const로
modal 초기화 및 최적화

scss 재활용

선언 @mixin {

@content // 추가적인값 

사용 @include

scss for문 활용

$z는 for문의 i처럼 변수

scss 색상내장함수

rgba(색상,투명도)

mix(색상1,색상2) //색상1,색상2 섞기

lighten(색상,밝기)

darken(색상,어둡기)

saturate(색상,채도)

desaturate(색상,채도감소도)

grayscale(색상) //회색화

invert(색상) //반전

 

 

any와 generic

함수의 (매개변수)에 따라 달라지는 type을 위해 generic을 쓴다.

선언1. hello<미리선언string>(매개변수)

선언2. hello(추론매개변수)

'mark'의 type을 추론하여 함수,매개변수,리턴값에 추론된 type을 지정한후 반환한다.
배열과 튜플에서 generic
클래스 generic

keyof

keyof를 사용하면 객체안에 key값이 될 수 있는 것들만 나오게된다.

'TypeScript' 카테고리의 다른 글

클래스 constructor, public, private, protected, static, readonly  (0) 2021.08.02
Interface 섹션  (0) 2021.08.02
tsconfig schema  (0) 2021.07.31
compiler옵션 중 strict 옵션  (0) 2021.07.31
typescript 기초와 설치  (0) 2021.07.30

생성자 constructor을 활용한 class

변수값 초기화/할당이 없어 에러시에는 무시하는 !를 사용하며 constructor에서 매개변수를 받아 할당되도록 별도로 만들수 있다.

 

접근제어자의 public과 private, protected

public은 외부에서도 호출 참조 할 수 있으나

private는 외부에서 호출할수 없고 선언 내부에서만 사용할 수 있다.

protected는 상속관계에서만 서로 호출참조할수있다.

Getters & Setters

 

 

 

READONLYpublic,priavte에 상관없이 무조건 변수값 선언/초기화 하는 부분에서만 값을 바꿀수있거나 constructor에서만 수정가능하다.

 

클래스에서 프로퍼티 이름이 동적으로 들어올시 인덱스시그니처를 사용해본다

[index:string] : string 또는 [index:string] : 'male' | 'female'

 

static 사용

new로 만들필요없이 바로 class명으로 부를수있다.

'TypeScript' 카테고리의 다른 글

generic과 keyof  (0) 2021.08.05
Interface 섹션  (0) 2021.08.02
tsconfig schema  (0) 2021.07.31
compiler옵션 중 strict 옵션  (0) 2021.07.31
typescript 기초와 설치  (0) 2021.07.30

optional property 인덱스 스트링

person['syster']처럼 interface index:string을 통해 문자가 들어갈수 있게 했고 값에는 any로 어떤 것이든 들어갈수 있게 했으므로 무엇을 추가해도 오류가 없다.

readonly

interface로 타입을 객체타입선언시 readonly로 오로지 읽을수만 있지 수정 변경이 불가능하게 값을 설정하여 수정이나 변경시도시 에러가 나타난다.

 

type알리아싱은 merging이 불가능하고 interface는 merging이 가능하다.

'TypeScript' 카테고리의 다른 글

generic과 keyof  (0) 2021.08.05
클래스 constructor, public, private, protected, static, readonly  (0) 2021.08.02
tsconfig schema  (0) 2021.07.31
compiler옵션 중 strict 옵션  (0) 2021.07.31
typescript 기초와 설치  (0) 2021.07.30

compileOnSave
extends로 외부부모파일에서 상속받아 옵션을 적용받는다.
증명된 tsconfig를 외부로 부터 가져오기위해설치하고 선언하는법
files > exclude > include
rootDir에 작성한 폴더 주소에 있는 파일을 npx tsc 명령어로 작동시 rootDir안에 있는 ts파일이 outDir에 작성된 폴더를 주소에 만든뒤 안에 js파일이 생성된다.

 

strict 옵션

nolmplicitAny

any로 추론되면 any로 지정하지않거나 아무것도 지정하지 않으면빨간색으로 에러가 발생한다.

 

noImplicitThis

함수내 this에 type이 없을시 에러가 뜨며 아래처럼 지정해주어야한다.

매개변수 맨 앞에 this를 type선언한다. 이것은 typescript에만 있는 문법이다.

strictNullChecks

일반적인 type은 지정된 type만 사용하여야하며 여러타입을 지정하려면 union type인 | 을 사용한다.

모든값은 null과 undefined값을 가질 수 없다.

예외적으로 void는 undefined도 할당가능하다.

any는 모든값을 가질수 있다. (무적)

 

strictFunctionTypes

매개변수 와 인자를 받는것 사이에는 

매개변수는 같거나 넓어야하고

리턴타입은 같거나 하위여야한다.

 

strictPropertyInitialization

strictNullChecks가 기본적으로 켜진다.

초기화 되지 않은 값은 타입이 명시되어도 오류가 발생한다.

하지만 constructor에서 this로 값을 할당하면 오류가 사라진다.

constructor에서 this로 값을 할당하면 오류가 사라진다.

 

 

'TypeScript' 카테고리의 다른 글

generic과 keyof  (0) 2021.08.05
클래스 constructor, public, private, protected, static, readonly  (0) 2021.08.02
Interface 섹션  (0) 2021.08.02
compiler옵션 중 strict 옵션  (0) 2021.07.31
typescript 기초와 설치  (0) 2021.07.30

nolmplicitAny 옵션

타입명시를 안하여 any로 타입스크립트가 자동판단하는것을 방지하여 컴파일 에러를 발생시킨다.

=return값이 무조건 있어야한다.

 

strictNullChecks 옵션

모든타입에 자동 포함된 null 과 undefined를 제거한다.

 

strictFuctionTypes 옵션

매개변수 타입이 같거나 슈퍼타입 이아닌 경우 에러 경고

일반적인 경우

 

함수 모양일시 

 

'TypeScript' 카테고리의 다른 글

generic과 keyof  (0) 2021.08.05
클래스 constructor, public, private, protected, static, readonly  (0) 2021.08.02
Interface 섹션  (0) 2021.08.02
tsconfig schema  (0) 2021.07.31
typescript 기초와 설치  (0) 2021.07.30

타입스크립트 설치 npm install typescript -D

-D 는 개발용으로 사용하는 것이다.

 

타일 스크립트를 프로젝트에서만 관리하려고할시

프로젝트안에서 어떻게 컴파일할지, tsc로 한번에 모두 컴파일 할수 있을지 등 정의는 default를 만들어줘야한다.

 

프로젝트의 root에서 default생성 : tsc --init

 

ts파일을 수정시 자동으로 js도 수정해주는 설정 : tsc -w //watch모드

 

--init 으로 tsconfig를 생성해주어야 tsc만으로 컴파일 할수 있다.

 

npm환경에서는 npx tsc명령어로 가능하다

 

1. npm init -y로 npm사용선언 

2. npm install typescript -D 로 설치

3. package.json에 script에 "build" 설정

4. npx tsc --init으로 default 만들기

5. npx tsc 로 빌드해보기

 

symbol

함수로 사용시 대분자 Symbol

타입으로 사용시 소문자 symbol

sym은 Symbol( )을 하였으니 [sym]으로만 접근할 수있다.

각 타입에는 각자 포함되는 타입만 쓸수 있으나 아래처럼 유니온방식으로 여러 타입을 쓸수 있다.

string과 null을 합집합하였다.

object create는 object말고도 null도 허용하는 union타입이다.

array 표현법 :

let list : number[ ] = [1,2,3]

let list : Array<number> = [1,2,3]

튜플 표현법 : 

const person : [string, number]

person =['hello',32]

 

any 타입

any의 사용법

void 타입

function 에서 return 값이 없어야하고 있다면 undefined만이 return 될수 있다.

'TypeScript' 카테고리의 다른 글

generic과 keyof  (0) 2021.08.05
클래스 constructor, public, private, protected, static, readonly  (0) 2021.08.02
Interface 섹션  (0) 2021.08.02
tsconfig schema  (0) 2021.07.31
compiler옵션 중 strict 옵션  (0) 2021.07.31

정규표현식

// 생성자방식

new RegExp('표현','옵션')

new RegExp('[a-z]','gi')

 

// 리터럴방식

/표현/옵션

/[a-z]/gi

 

옵션 g = 조건에 맞는 모든것들을 배열로 집어넣어준다.

옵션 i - 대소문자 구분을 하지 않고 모두 검색한다.

옵션 m - 문단이 끝나는 부분마다 검사할 수 있게 해준다.

.match메소드안에 생성한 정규표현식을 넣는다.

+ Recent posts