반응형
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- State
- react
- input
- mapGetters
- jsx
- v-html
- Vue
- App.vue
- HOC
- 리액트
- 댓글달기
- Vue.js
- storybook
- 자바스크립트
- MySQL
- event
- express
- 자료구조
- vuex
- webpack
- ES6
- sass
- 쉬운설명
- JavaScript
- TypeScript
- Wecode
- scss
- CSS
- Vue transition
- nodejs
Archives
- Today
- Total
익명의 개발노트
[해결] 댓글달기-모달창구현 중 에러 본문
반응형
//수정창 모달로 만들기
function modifyComments(event){
const mBtn = event.target;
//모달창 만들기
const modal = document.createElement('div')
const modalOverlay = document.createElement('div');
const modalContent = document.createElement('div');
const cancleBtn = document.createElement('button');
const okBtn = document.createElement('button');
const input = document.createElement('input');
const span = document.createElement('span');
modal.className = "modal hidden";
modalOverlay.className ="modal__overlay";
modalContent.className ="modal__content";
okBtn.id = "ok";
okBtn.innerHTML="수정";
cancleBtn.id = "cancle";
cancleBtn.innerHTML = "취소";
input.id = "modifyVal";
input.placeholder = "변경할 내용을 입력하세요";
span.id ="inBtn";
span.appendChild(okBtn);
span.appendChild(cancleBtn);
modalContent.appendChild(input);
modalContent.appendChild(span);
modal.appendChild(modalOverlay);
modal.appendChild(modalContent);
rootDiv.appendChild(modal);
modal.classList.remove("hidden");
cancleBtn.addEventListener("click",function(){
modal.classList.add("hidden");
});
okBtn.addEventListener("click",function(event){
console.dir(event.target);
for(var i=0; i<idOrVoteCountList.length; i++){
if(idOrVoteCountList[i]["commentId"].toString() === mBtn.parentNode.id){
idOrVoteCountList[i]["commentValue"] = input.value;
//childNode의 가장최근값은 인덱스 0번부터 시작한다. idOrVoteCountList인덱스하고 반대임.
for(var j=idOrVoteCountList.length-1; j>=0; j--){
if(rootDiv.children[j-i].children[1].id === idOrVoteCountList[i]["commentId"].toString()){
rootDiv.children[j-i].children[1].innerHTML = input.value;
}
}
// console.dir(rootDiv.childNodes[0].childNodes[1].id);
// console.dir(rootDiv.childNodes[0]);
//modal.classList.add("hidden");
}
}
});
}
일단 에러 내용이 Uncaught TypeError: Cannot read property이다.
이 에러는 크롬에서 정의되지 않은 객체의 property를 읽어내거나 method를 호출했을 때 발생한다.
내가 선택한 방식은 event.target으로 부터 ID를 찾아가야 몇번째 댓글의 수정버튼을 클릭했는지 크롬에서 기억할 수 있
는데, 나는 역으로 DOM의 끝부분부터 찾아내려왔다. 그러니깐 1개일때는 이상없이 수정되었지만, 2개부터는 에러가 나
는 것이다.
그래서 코드를 바꿔봤다.
okBtn.addEventListener("click",function(event){
console.dir(mBtn.parentNode.parentNode.children[1]);
for(var i=0; i<idOrVoteCountList.length; i++){
if(idOrVoteCountList[i]["commentId"].toString() === mBtn.parentNode.id){
idOrVoteCountList[i]["commentValue"] = input.value;
//수정버튼누르면 변경.
mBtn.parentNode.parentNode.children[1].innerHTML = input.value;
modal.classList.add("hidden");
}
}
});
맨 밖에 모달창 떳을때 event.target값을 mBtn에 미리 저장했는데, 그것을 이용했다.
댓글은 Span#inputValue값이 가지고 있기때문에. 그 곳의 위치가 아래와 같다.
mBtn.parentNode.parentNode.children[1]
그 곳을 찾아서 값을 변경해주면? 끝난다.
반응형
'코딩일기 > 에러 일지' 카테고리의 다른 글
[mysql] ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (0) | 2019.11.03 |
---|---|
TypeError: Cannot assign to read only property 'exports' of object '#<Object>' (0) | 2019.10.30 |
[해결] node 회원가입 api 구현간 발생한 에러 (2) | 2019.06.28 |
[해결] mysql 정보 insert시 발생한 에러. (0) | 2019.06.28 |
[해결] 댓글달기 (투표버튼과 카운트) (0) | 2019.03.30 |
Comments