1. html attribute를 통한 Range제한
만약 input의 텍스트를 최대 15글자로제한하고 싶으면 다음과 같다.
- 일단 form 형태로
작성되어야한다
- div와 같은걸로 감싸봤자 의미가 없음
<input required maxlength="15" type="text" placeholder="What is your name?" />
다음과 같이 아예 더이상 작성이 되질 않는다.
2. _EVENT.preventDefault()
type에 따른 이벤트를 막는것
기본 동작을 실행하지 않도록
지정합니다.
submit
submit의 경우 제출했을시
페이지가 새로고침이 되는
기본 동작이 있다
<input type="submit" value="Login">
click
click의 경우 클릭 동작을 막는것
link
link의 기본동작은 링크로
이동하기
3. 내가실행한 이벤트확인
사용자가 어떤 이벤트를 벌였는지 화인할 수 있다
function listener(_E) {
console.log(_E)
}
_TARGET.addEventlistener(type, listener)
4. 백틱 문자열
`HELLO ${_VAR}`;
5. 저장하기
localStorage : Key - Value
개발자 도구에서 Application 메뉴에 확인가능
localStorage.setItem(,,,); localStorage.getItem(,,,); //if 값이 없다면 null값 반환 //=== 으로 유무판단하자.
좀더 정확한 localstorage JS_LOCALSTORAGE
Clock.js
1. setInterval/setTimeout
setInterval : 일정 시간간격을두고
함수를 실행하는 방법
setTimeout : 일정시간이 지난후에
함수를 실행하는 방법
2. padStart()
padStart(고정문자열길이, 채울문자)
clockElement.innerText = ` ${date.getHours()}: ${date.getMinutes()}: ${parseInt(date.getSeconds()) < 10 ? `0${date.getSeconds()}` : date.getSeconds()} `
이건 너무 코드가 길어
그래서 다음과 같이 작성하면 된다.
const hours = String(date.getHours()).padStart(2,"0"); const minutes = String(date.getMinutes()).padStart(2,"0"); const second = String(date.getSeconds()).padStart(2,"0"); clockElement.innerText = `${hours}:${minutes}:${second}`;
Quotes
Math.random()
Math.random()
0과 1 사이의 난수를
반환합니다.
Math.round(x)
숫자에서 가장 가까운 정수를
반환합니다.
BackGround
document.createElement
바로 적용할수 있는게
아니라
일단 HTML에 들어갈 수 있는 Element를
<> 형식으로 만들 수 있다.
▽ 이제 본격적으로 원하는 위치에 적용하고 싶다면 다음 명령어를 써야한다 ▽
.appendChild()
ToDoLIST
이벤트 발생좌표
내가 발생시킨 이벤트의 위치가 정확히 어디인지 확인하고 싶을때
- 이벤트 리스너를 가지고 console.dir출력
- target이나 좌표를 단서를 얻자
- target에는 parentElement라는것이 있다.
버그 발견
function deleteTODO(_E){ if(_E.target.localName === "button" || _E.target.innerText === "❌"){ const deleteTarget = _E.target.parentElement.parentElement; deleteTarget.remove(); } }
여기에서 target.localName을 한정하지 않으면 아래의 파란부분 클릭시
상위 태그의 요소들이 전부
삭제되는 버그가 있다.
따라서 li 부분을 클릭하지
못하게 막아줘야한다.
JSON
JSON.stringify(___)
어떤 정체불명의 데이터를
string으로 변환해주는
코드이다.
따라서 localstorage 저장시 다음을
응용한다면
JSON.parge
문자열로 가져온 데이터를 파싱해서 arr으로 저장가능하다.
Array
forEach
parsedTODOs.forEach(i => { console.log(i); });
filter(하나의 원소를 받고 ->
T/F로 반한되는 조건문혹은
함수)
O(N)으로 진행되는 삭제명령어
true -> 삭제 안됨
false -> 삭제
filter(sextFunction)
sextFunction(원소){
...원소값을가지고 조건문 만들기...
return T/F;
}
at: ƒ at()
concat: ƒ concat()
constructor: ƒ Array()
copyWithin: ƒ copyWithin()
entries: ƒ entries()
every: ƒ every()
fill: ƒ fill()
filter: ƒ filter()
find: ƒ find()
findIndex: ƒ findIndex()
findLast: ƒ findLast()
findLastIndex: ƒ findLastIndex()
flat: ƒ flat()
flatMap: ƒ flatMap()
forEach: ƒ forEach()
includes: ƒ includes()
indexOf: ƒ indexOf()
join: ƒ join()
keys: ƒ keys()
lastIndexOf: ƒ lastIndexOf()
length: 0
map: ƒ map()
pop: ƒ pop()
push: ƒ push()
reduce: ƒ reduce()
reduceRight: ƒ reduceRight()
reverse: ƒ reverse()
shift: ƒ shift()
slice: ƒ slice()
some: ƒ some()
sort: ƒ sort()
splice: ƒ splice()
toLocaleString: ƒ toLocaleString()
toString: ƒ toString()
unshift: ƒ unshift()
values: ƒ values()
Map-Array Element를 특정하자
어느 데이터가 지워져야하는지 식별하기위핸 id가 포함된 데이터를 만들자.
const map {
key : value;
}
array.push(map());
'Language > Javascript' 카테고리의 다른 글
require으로 모듈 import 할때, 타입스크립트 IntelliSense / 자동완성 작동이 안된다.. & Json 세팅 (0) | 2022.04.14 |
---|---|
| 노마드 코더 | 팁 | 자바스크립트 여러 팁 Console-Api, 페이지 텍스트 드래그 막기 (0) | 2022.01.25 |
|노마드 코더 | 팁 | 로컬 스토리지 저장 & 불러오기 (0) | 2022.01.25 |
|노마드 코더| 팁 | JS_LOCALSTORAGE (0) | 2022.01.25 |
|노마드 코더| 2 | 자바 스크립트 문법 - JS_ADVENCE (0) | 2022.01.25 |