Javascript-форум (https://javascript.ru/forum/)
-   Общие вопросы Javascript (https://javascript.ru/forum/misc/)
-   -   Отображение содержимого input (https://javascript.ru/forum/misc/80326-otobrazhenie-soderzhimogo-input.html)

ABitOfJS 23.05.2020 10:47

Отображение содержимого input
 
Итак, доброго времени суток! Назрело пару вопросов по моему коду. Ну, для начала сам код:
<html>
<head>
<script type="text/javascript">
document.addEventListener('DOMContentLoaded', () => {
  const inp = document.getElementById('message'),
        div = document.getElementById('messagebox'),
        btn = document.getElementById('send');
  btn.addEventListener('click', function () {
    if (inp.value.length)
      div.innerHTML += '<span class="newmessage">' + inp.value + '</span><br><br>'; 
  });
});
</script>
<style>
.newmessage {
width: 70vw;
max-height: 500px;
overflow: auto;
border: 2px solid black;
border-radius: 10px 10px 10px 10px / 5px 5px 5px 5px;
padding: 5px;
margin-top: 10px;
margin-bottom: 10px;
}
</style>
</head>
<body>
<input type="text" id="name" placeholder="Ваше имя"><input type="button" id="letname" value="Сохранить имя">
<hr>
    <input id="send" type="reset" value="Отправить">
    <textarea id="message"></textarea>
    <div id="messagebox"></div>
</body>
</html>

Код выводит тот текст, который юзер ввёл в #message. Но... Я не знаю как правильно сохранить .newmessage. localStorage? Да, его можно использовать, но как? Для каждого отдельного сообщения делать новую переменную? А если сообщений будет миллион :blink: ? Обернуть каждый .newmessage? Тогда как?
Еще проблема: если в сообщении есть перевод на новую строчку, то в .newmessage эти переводы отображаюся всего лишь как пробелы. Есть возможность отобразить сообщение "как есть"?
Ах да, ещё забыл сказать. Как можно сохранить значение #name, и потом в каждом .newmessage выводить сохранённый текст?

void() 23.05.2020 11:23

1. Сохраняй сообщения в массив (let temp = []) перед выводом в HTML.
Добавить сообщение в массив: temp.push(inp.value);

2. Дальше записывай в хранилище массив temp (но его нужно сначала привести к JSON). Вот функция:

function setInp(temp) {
  localStorage.setItem('saveInp', JSON.stringify(temp));
}


3. При загрузке страницы - функция, которая читает:
function getInp() {
  temp = JSON.parse(localStorage.getItem('saveInp'));
}


4. Теперь в массиве temp есть все сообщения и их нужно только вывести циклом в HTML.


Часовой пояс GMT +3, время: 16:06.