-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathscript.js
124 lines (96 loc) · 4.64 KB
/
script.js
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
const studentForm = document.querySelector('.form');
const studentInput = studentForm.querySelector('input#student');
const studentListElement = document.querySelector('.student-list');
const deleteButtonClickHandler = function (evt) {
const studentElement = evt.target.parentNode;
studentElement.classList.add('student_deleted');
setTimeout(function () {
if (studentElement.parentNode) {
studentListElement.removeChild(studentElement);
}
}, 500);
};
const addDeleteButtonClickHandlerToLastStudent = function () {
const deleteButton = studentListElement.children[studentListElement.childElementCount - 1].querySelector('.student__delete');
deleteButton.addEventListener('click', deleteButtonClickHandler);
};
const createStudentElement = function (studentName, faceNumber) {
const studentElement = document.createElement('article');
studentElement.classList.add('student');
const faceElement = document.createElement('div');
faceElement.classList.add('student__face');
faceElement.classList.add('student__face_number_' + faceNumber);
studentElement.appendChild(faceElement);
const nameElement = document.createElement('div');
nameElement.classList.add('student__name');
nameElement.innerText = studentName;
studentElement.appendChild(nameElement);
const dateElement = document.createElement('div');
dateElement.classList.add('student__date');
dateElement.innerText = Date();
studentElement.appendChild(dateElement);
const crossElement = document.createElement('div');
crossElement.classList.add('student__delete');
crossElement.innerText = 'x';
studentElement.appendChild(crossElement);
return studentElement;
};
const createStudentElementFromTemplate = function (studentName, faceNumber) {
const studentTemplate = document.querySelector('#student-template').content;
const studentElement = studentTemplate.cloneNode(true);
studentElement.querySelector('.student__face').classList.add('student__face_number_' + faceNumber);
studentElement.querySelector('.student__name').innerText = studentName;
studentElement.querySelector('.student__date').innerText = Date();
return studentElement;
};
const insertWithInnerHtml = function (evt) {
const studentName = studentInput.value;
const faceNumber = Math.floor(Math.random() * 6);
studentListElement.innerHTML +=
`<article class="student">
<div class="student__face student__face_number_${faceNumber}"></div>
<div class="student__name">${studentName}</div>
<div class="student__date">${Date()}</div>
<div class="student__delete">x</div>
</article>`;
addDeleteButtonClickHandlerToLastStudent();
};
const insertWithAdjacentHtml = function (evt) {
const studentName = studentInput.value;
const faceNumber = Math.floor(Math.random() * 6);
studentListElement.insertAdjacentHTML('beforeend',
`<article class="student">
<div class="student__face student__face_number_${faceNumber}"></div>
<div class="student__name">${studentName}</div>
<div class="student__date">${Date()}</div>
<div class="student__delete">x</div>
</article>`);
addDeleteButtonClickHandlerToLastStudent();
};
const insertWithAppendChild = function (evt) {
const studentName = studentInput.value;
const faceNumber = Math.floor(Math.random() * 6);
const studentElement = createStudentElement(studentName, faceNumber);
studentListElement.appendChild(studentElement);
addDeleteButtonClickHandlerToLastStudent();
};
const insertWithAppend = function (evt) {
const studentName = studentInput.value;
const faceNumber = Math.floor(Math.random() * 6);
const studentElement = createStudentElement(studentName, faceNumber);
studentListElement.append(studentElement);
addDeleteButtonClickHandlerToLastStudent();
};
const insertWithTemplate = function (evt) {
const studentName = studentInput.value;
const faceNumber = Math.floor(Math.random() * 6);
const studentElement = createStudentElementFromTemplate(studentName, faceNumber);
studentListElement.appendChild(studentElement);
addDeleteButtonClickHandlerToLastStudent();
};
studentForm.addEventListener('submit', evt => evt.preventDefault());
document.querySelector(".insert-with-inner-html").addEventListener('click', insertWithInnerHtml);
document.querySelector(".insert-with-adjacent-html").addEventListener('click', insertWithAdjacentHtml);
document.querySelector(".insert-with-append-child").addEventListener('click', insertWithAppendChild);
document.querySelector(".insert-with-append").addEventListener('click', insertWithAppend);
document.querySelector(".insert-with-template").addEventListener('click', insertWithTemplate);