Как увеличить и уменьшить число при клике и сохранить его в локальном хранилище? - PullRequest
0 голосов
/ 08 сентября 2018

Это пример приложения Reddit. Я хочу увеличить или уменьшить число при нажатии кнопки «upvote» или «downvote», и значение этого параметра должно быть сохранено в локальном хранилище ... спасибо;

HTML-разметка:

<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" >Submit Link</button>
    </form>
</div>

<div class="container">
    <div class="content-box" id="content">
        // Code dynamically generated from javascript...  
    </div>
</div>

Javascript код:

let form = document.getElementById('myForm');
let content = document.querySelector('#content');


function addIt(e) {
    e.preventDefault();
    let siteName = document.getElementById('siteName').value;
    let siteUrl = document.getElementById('siteUrl').value;

    content.innerHTML += `
    <div class="row">
      <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() {
     //...
   }

   function down() {
     //...
   }

}

Вывод результата:

enter image description here

1 Ответ

0 голосов
/ 08 сентября 2018

Сначала найдите точку для каждой кнопки, это

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>
...