Сначала найдите точку для каждой кнопки, это
let point = this.parentNode.parentNode.querySelector(".num");
потому что он находится в родительском div, родительском div кнопки, и там находится первый элемент, который соответствует .num
.
После этого увеличить или уменьшить innerHTML
point.innerHTML = parseInt(point.innerHTML)+1
let form = document.getElementById('myForm');
let content = document.querySelector('#content');
form.addEventListener("submit", addIt);
function addIt(e) {
e.preventDefault();
let siteName = document.getElementById('siteName').value;
let siteUrl = document.getElementById('siteUrl').value;
content.innerHTML += `
<div class="row rating">
<div class="points col-md-4">
<p class="num">0</p>
<p class="point">Points</p>
</div>
<div class="matter col-md-6">
<h2>${siteName}</h2>
<p class="lead">${siteUrl}</p>
<button class="upvote">upvote</button>
<button class="downvote">downvote</button>
</div>
</div>
`
votes();
}
function votes() {
let upvotes = Array.from(document.querySelectorAll('.upvote'));
let downvotes = Array.from(document.querySelectorAll('.downvote'));
upvotes.forEach(upvote => upvote.addEventListener('click', up));
downvotes.forEach(downvote => downvote.addEventListener('click', down));
function up() {
let point = this.parentNode.parentNode.querySelector(".num");
point.innerHTML = parseInt(point.innerHTML)+1
}
function down() {
let point = this.parentNode.parentNode.querySelector(".num");
point.innerHTML = parseInt(point.innerHTML)-1
}
}
.rating {
border: 1px solid red;
}
<div class="submit-box">
<form id="myForm">
<h2>Add a Link</h2>
<h3>Title:</h3>
<input type="text" placeholder="Enter title" id="siteName">
<h3>Link:</h3>
<input type="text" id="siteUrl" placeholder="Enter URL Link">
<button class="btn" type="submit">Submit Link</button>
</form>
</div>
<div class="container">
<div class="content-box" id="content">
// Code dynamically generated from javascript...
</div>
</div>
Я добавил красную рамку, чтобы вы могли видеть, какие элементы принадлежат какому-либо веб-сайту.
Чтобы сохранить это в localStorage, вы можете создать JSON Array из веб-сайтов и сохранить его. Когда вы добавляете новый веб-сайт, получите этот массив из localStorage и добавьте в него новый веб-сайт. При загрузке получите то же самое и запустите addIt для каждого из них.
let form = document.getElementById('myForm');
let content = document.querySelector('#content');
form.addEventListener("submit", addIt);
let websiteArr = [];
try {
websiteArr = JSON.parse(localStorage.getItem("websites"));
} catch {
// no websites in localStorage
}
if (websiteArr.length != 0) {
websiteArr.forEach(web => {
addIt(!0, {name:web.name, url:web.url, points:web.points});
});
}
function addIt(e, options) {
e && e.preventDefault(); // only run preventDefault when addIt is called in the submit handler of the form
let siteName = document.getElementById('siteName').value;
let siteUrl = document.getElementById('siteUrl').value;
let points = 0;
if(options) {
siteName = options.name;
siteUrl = options.url;
points = options.points;
}
content.innerHTML += `
<div class="row rating">
<div class="points col-md-4">
<p class="num">${points}</p>
<p class="point">Points</p>
</div>
<div class="matter col-md-6">
<h2>${siteName}</h2>
<p class="lead">${siteUrl}</p>
<button class="upvote">upvote</button>
<button class="downvote">downvote</button>
</div>
</div>
`
votes();
}
function saveArray() {
localStorage.setItem("websites", JSON.stringify(websiteArr));
}
function votes() {
let upvotes = Array.from(document.querySelectorAll('.upvote'));
let downvotes = Array.from(document.querySelectorAll('.downvote'));
upvotes.forEach(upvote => upvote.addEventListener('click', up));
downvotes.forEach(downvote => downvote.addEventListener('click', down));
function up() {
let point = this.parentNode.parentNode.querySelector(".num");
point.innerHTML = parseInt(point.innerHTML)+1
let url = this.parentNode.querySelector("p").innerHTML;
websiteArr.forEach(web => (web.url === url) && web.points++);
saveArray();
}
function down() {
let point = this.parentNode.parentNode.querySelector(".num");
point.innerHTML = parseInt(point.innerHTML)-1
let url = this.parentNode.querySelector("p").innerHTML;
websiteArr.forEach(web => (web.url === url) && web.points--);
saveArray();
}
}
.rating {
border: 1px solid red;
}
<div class="submit-box">
<form id="myForm">
<h2>Add a Link</h2>
<h3>Title:</h3>
<input type="text" placeholder="Enter title" id="siteName">
<h3>Link:</h3>
<input type="text" id="siteUrl" placeholder="Enter URL Link">
<button class="btn" type="submit">Submit Link</button>
</form>
</div>
<div class="container">
<div class="content-box" id="content">
// Code dynamically generated from javascript...
</div>
</div>