<header>
<h2 class="title">Event.paste</h2>
<p class="description">Контролюємо вставку тексту та видаляємо зайві пробіли</p>
</header>
<main>
<div class="result">
<!-- Поле вводу, що обробляє подію paste -->
<label for="inputField">Вставте текст у поле:</label>
<input type="text" id="inputField" placeholder="Вставте текст сюди" />
<p id="log"></p> <!-- Для виведення результату -->
</div>
</main>
body {
font-size: 16px;
line-height: 1.5;
font-family: monospace;
}
header {
background-color: #f1f1f1;
margin-bottom: 25px;
padding: 15px;
box-shadow: 0px 0px 3px 0px rgba(118, 118, 118, 1);
}
header h2.title {
padding-bottom: 15px;
border-bottom: 1px solid #999;
}
header p.description {
font-style: italic;
color: #222;
}
.result {
background-color: #f8f8f8;
padding: 15px;
box-shadow: 0px 0px 3px 0px rgba(118, 118, 118, 1);
}
label {
font-weight: bold;
}
input[type="text"] {
padding: 8px;
width: 100%;
margin-top: 5px;
margin-bottom: 10px;
font-size: 16px;
border: 1px solid #ccc;
border-radius: 4px;
}
#log {
color: #555;
font-size: 14px;
}
const inputField = document.getElementById("inputField");
const log = document.getElementById("log");
inputField.addEventListener("paste", (event) => {
event.preventDefault(); // Зупиняємо стандартну вставку
// Отримуємо дані з буфера обміну
const pasteData = event.clipboardData.getData("text");
// Очищуємо текст від зайвих пробілів
const cleanedData = pasteData.trim().replace(/\s+/g, " ");
// Вставляємо очищений текст у поле
inputField.value = cleanedData;
// Виводимо повідомлення про успішну вставку
log.innerText = "Вставлено текст: " + cleanedData;
});
This Pen doesn't use any external CSS resources.
This Pen doesn't use any external JavaScript resources.