Наповнення JS розділу

Добридень, Пані та Панове, завдяки вам вдалося зібрати більше 19тис грн з необхідних 15тис на впровадження JS розділу.

JS розділ вже впроваджено - переходимо до його наповнення і почнемо бігти довгий марафон, адже JS має більше 1100 різноманітних методів, властивостей, подій і т.д., які необхідно описати.

Будемо працювати, і вдень, і вночі, щоб орієнтовно взимку закінчити наповнювати JS розділ!

Ви також можете допомогти нам в цьому. Долучайтеся до нашої спільноти в дискорді - ставайте її частиною і допомагайте нашому розвитку.

Також, підтримуйте нас матеріально.

JS властивість Document.charset

Загальний опис

charset - це властивість об'єкта document, що дозволяє отримати або встановити кодування символів поточного документа. Ця властивість корисна для визначення кодування сторінки, особливо при роботі з зовнішніми ресурсами, такими як файли або веб-сервіси, які можуть використовувати інше кодування символів.

Для отримання поточного кодування символів достатньо звернутися до властивості document.charset:

const charset = document.charset;
console.log(charset); // Наприклад, "UTF-8"

Значення властивості charset можна також встановити, що може бути корисним для явного визначення кодування документа. Це може знадобитися, якщо сервер не надає правильну інформацію про кодування або якщо потрібно змінити кодування динамічно:

document.charset = "UTF-16";

Однак, слід зазначити, що встановлення charset може призвести до перекодування всього документа, що може негативно позначитися на продуктивності та спричинити непередбачувані наслідки. Тому рекомендується використовувати його обережно та лише у випадках, коли це дійсно необхідно.

Крім того, властивість charset може бути корисною при роботі з об'єктами XMLHttpRequest для відправлення запитів на сервер з правильним кодуванням символів. Наприклад:

const xhr = new XMLHttpRequest();
xhr.open('GET', 'https://example.com/data.json');
xhr.overrideMimeType(`text/plain; charset=${document.charset}`);
xhr.onload = function() {
  if (xhr.status === 200) {
    console.log(xhr.responseText);
  }
};
xhr.send();

У цьому прикладі ми використовуємо document.charset для явного вказування кодування символів для відповіді сервера, що забезпечує правильну обробку даних незалежно від кодування, яке використовується на сервері.

Порада:

Варто зазначити, що властивість document.charset вважається застарілою та може бути видалена у майбутніх версіях браузерів. Тому не рекомендується покладатися на неї у нових проєктах. Замість цього, краще використовувати більш сучасні та стандартизовані способи роботи з кодуваннями символів, такі як метод TextDecoder або бібліотеки для роботи з кодуваннями, наприклад iconv-lite. Це забезпечить кращу сумісність та підтримку у майбутньому.

Порада:

Уникайте встановлення document.charset, якщо це не абсолютно необхідно. Зміна кодування символів документа може призвести до перекодування всього вмісту, що може негативно вплинути на продуктивність та спричинити непередбачувані наслідки. Замість цього, спробуйте налаштувати кодування на рівні окремих ресурсів або використовуй відповідні методи декодування.

Синтаксис

Document.charset

Значення

Return

Переглядачі

Переглядач

1

1

3

12.1

12

Переглядач

1

18

4

1

Переглядач

-

-

Приклади


У цьому прикладі ми просто виводимо поточне кодування символів документа у консоль браузера за допомогою властивості document.charset.

console.log(`Кодування символів поточного документа: ${document.charset}`);

У цьому прикладі ми використовуємо властивість document.charset для налаштування кодування символів при відправленні запиту на сервер за допомогою об'єкта XMLHttpRequest. Це забезпечує правильну обробку відповіді сервера незалежно від кодування, яке він використовує.

function fetchData(url) {
  const xhr = new XMLHttpRequest();
  xhr.open('GET', url);

  // Встановлюємо кодування символів для відповіді сервера
  xhr.overrideMimeType(`text/plain; charset=${document.charset}`);

  xhr.onload = function() {
    if (xhr.status === 200) {
      console.log(`Отримані дані від сервера: ${xhr.responseText}`);
    } else {
      console.error(`Помилка запиту: ${xhr.statusText}`);
    }
  };

  xhr.onerror = function() {
    console.error('Помилка мережі');
  };

  xhr.send();
}

// Приклад використання
fetchData('https://example.com/data.json');