<MyRusakov.ru />

Профессия Web-разработчик

Профессия Web-разработчик

Этот комплект за 8 месяцев превратит Вас в Web-разработчика с нуля. Учиться достаточно 1 час в день.

Начнёте Вы с HTML, CSS и вёрстки сайтов. Потом перейдёте к программированию и JavaScript. Затем изучите PHP, MySQL, SQL, Python. Изучите Web-фреймворки Laravel и Django. Создадите 5 своих сайтов для портфолио.

Комплект содержит:

- 540 видеоуроков

- 110 часов видео

- 1205 заданий для закрепления материала из уроков

- 5 финальных тестов

- 7 сертификатов

- 12 Бонусных курсов

Подробнее
Подписка

Подпишитесь на мой канал на YouTube, где я регулярно публикую новые видео.

YouTube Подписаться

Подписавшись по E-mail, Вы будете получать уведомления о новых статьях.

Подписка Подписаться

Добавляйтесь ко мне в друзья ВКонтакте! Отзывы о сайте и обо мне оставляйте в моей группе.

Мой аккаунт Мой аккаунт Моя группа
Опрос

Какая тема Вас интересует больше?

Как работать с локальной файловой системой в JavaScript

Как работать с локальной файловой системой в JavaScript

Работа с файлами — одна из типичных задач при создании веб-приложений. Однако, доступ к локальной файловой системе пользователя с помощью JavaScript ограничен по соображениям безопасности. Современные браузеры, тем не менее, предоставляют возможности для взаимодействия с файлами через File API и File System Access API. Эти интерфейсы позволяют читать и сохранять файлы, не передавая их на сервер.

Основные подходы

В JavaScript существует два основных способа взаимодействия с локальной файловой системой:

  1. File API — позволяет работать с файлами, выбранными пользователем через <input type="file">.
  2. File System Access API — предоставляет более глубокий доступ к файловой системе: чтение, запись и создание файлов и папок (поддерживается не во всех браузерах).

File API: чтение загруженных файлов

Классический способ работы с файлами предполагает использование элемента формы:

<input type="file" id="fileInput">
<pre id="output"></pre>

<script>
  document.getElementById('fileInput').addEventListener('change', function (event) {
    const file = event.target.files[0];
    const reader = new FileReader();

    reader.onload = function () {
      document.getElementById('output').textContent = reader.result;
    };

    reader.readAsText(file);
  });
</script>

Этот метод подходит для: - Загрузки и анализа текстовых и бинарных файлов - Парсинга данных, например, CSV или JSON - Отображения содержимого файлов на клиентской стороне

File System Access API: прямой доступ к файловой системе

Этот API позволяет: - Выбирать и открывать файлы и папки - Читать содержимое файлов - Записывать данные в существующие или новые файлы

Пример чтения содержимого файла:

async function openFile() {
  const [fileHandle] = await window.showOpenFilePicker();
  const file = await fileHandle.getFile();
  const content = await file.text();
  console.log(content);
}

Пример записи в файл:

async function saveFile() {
  const options = {
    suggestedName: 'example.txt',
    types: [{
      description: 'Text Files',
      accept: { 'text/plain': ['.txt'] }
    }]
  };

  const handle = await window.showSaveFilePicker(options);
  const writable = await handle.createWritable();
  await writable.write('Текст, записанный с помощью JavaScript');
  await writable.close();
}

Пример работы с папками:

async function openFolder() {
  const dirHandle = await window.showDirectoryPicker();

  for await (const [name, handle] of dirHandle.entries()) {
    console.log(`${handle.kind}: ${name}`);
  }
}

Ограничения и безопасность

  • Доступ предоставляется только по инициативе пользователя через диалоговое окно.
  • Браузеры изолируют доступ: JavaScript не может получить произвольный доступ к файловой системе.
  • В большинстве случаев доступ сохраняется только на время сессии, если не используются специальные механизмы хранения дескрипторов.

Проверка доступности API:

if ('showOpenFilePicker' in window) {
  // File System Access API поддерживается
}

Когда использовать File API, а когда File System Access API

| Задача | API | |--|--| | Чтение пользовательских файлов | File API | | Запись в файлы, создание новых файлов | File System Access API | | Работа с папками | File System Access API | | Поддержка всеми браузерами | File API |

Современные возможности JavaScript позволяют организовать работу с локальными файлами без использования сервера. Это особенно полезно в офлайн-приложениях, редакторах и инструментах для работы с данными. Однако при разработке следует учитывать уровень поддержки браузерами и всегда ориентироваться на безопасность пользователя.

Если требуется реализация конкретного сценария или создание демо-приложения с использованием описанных API, я готов помочь.

Копирование материалов разрешается только с указанием автора (Михаил Русаков) и индексируемой прямой ссылкой на сайт (http://myrusakov.ru)!

Добавляйтесь ко мне в друзья ВКонтакте: http://vk.com/myrusakov.
Если Вы хотите дать оценку мне и моей работе, то напишите её в моей группе: http://vk.com/rusakovmy.

Если Вы не хотите пропустить новые материалы на сайте,
то Вы можете подписаться на обновления: Подписаться на обновления

Если у Вас остались какие-либо вопросы, либо у Вас есть желание высказаться по поводу этой статьи, то Вы можете оставить свой комментарий внизу страницы.

Порекомендуйте эту статью друзьям:

Если Вам понравился сайт, то разместите ссылку на него (у себя на сайте, на форуме, в контакте):

  1. Кнопка:

    Она выглядит вот так: Как создать свой сайт

  2. Текстовая ссылка:

    Она выглядит вот так: Как создать свой сайт

  3. BB-код ссылки для форумов (например, можете поставить её в подписи):

Комментарии (0):

Для добавления комментариев надо войти в систему.
Если Вы ещё не зарегистрированы на сайте, то сначала зарегистрируйтесь.