Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/4: Рейтинг темы: голосов - 4, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 11.02.2014
Сообщений: 16

Создать кнопку сохранить все фотографии

22.04.2024, 16:24. Показов 862. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В div блоке хранятся изображения img их может быть 1-20.
Подскажите как создать кнопку что бы из div блока сохранить все img ?
HTML5
1
2
3
4
5
6
7
8
9
10
11
<div class="row no-gutters mb-2 rounded">
        <a class="col-4 images-kor-5bIu5Iphd63wLP" href="">
            <img src="" class="img-thumbnail" alt="">
        </a>
 
 
        <a class="col-4 images-kor-5bIu5Iphd63wLP" href="">
            <img src="" class="img-thumbnail" alt="">
        </a>
</div>
<button class="btn">Скачать файл</button>
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.04.2024, 16:24
Ответы с готовыми решениями:

Создать кнопку динамически и сохранить ее на странице
как сделать это: я создаю динамически кнопку на странице и нужно как-то её сохранить на ней,так чтобы даже после закрытия сайта она...

Как создать кнопку которая удаляет все строки в бд Access?
Как создать кнопку С# , которая удаляет все строки в бд аccess Есть кнопка, есть datagreadview... На ней отображаются данные, нажимая...

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

12
Невнимательный
 Аватар для ft4l
3106 / 1275 / 358
Регистрация: 08.02.2013
Сообщений: 7,440
Записей в блоге: 2
22.04.2024, 20:49
Цитата Сообщение от kukush Посмотреть сообщение
все img
как вариант
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
<!DOCTYPE html>
<html lang="ru"><head>
    <title>Index</title>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" type="text/css" href="/sys/CSS.css" />
    <script type="text/javascript">
function getConfirmation(src) {
    var link, retVal = confirm(src + " Do you want to download ?");
    if( retVal == true ) {
        link = document.createElement('A');
        link.href = src;
        link.download = src.substr(src.lastIndexOf('/') + 1);
        link.click();
        return true;
    }
    return false;
}
function getImgs(btn){
    var i=0, imgs =btn.previousElementSibling.getElementsByTagName('IMG'); 
    for(;i<imgs.length; ++i) getConfirmation(imgs[i].src)
}
    </script>
</head>
<body>
<header>
    <h2>Index</h2>
</header>
<main>
 
<div class="row no-gutters mb-2 rounded">
        <a class="col-4 images-kor-5bIu5Iphd63wLP" href="">
            <img src="/favicon.ico" class="img-thumbnail" alt="">
        </a>
 
 
        <a class="col-4 images-kor-5bIu5Iphd63wLP" href="">
            <img src="/favicon.ico" class="img-thumbnail" alt="">
        </a>
</div>
<button class="btn" onclick="getImgs(this)">Скачать файл</button>
 
</main>
</body></html>
Добавлено через 5 минут
... opera 12 открывает вместо диалога сохранения

Добавлено через 1 минуту
... IE11 молча ничего не делает ))
1
Молодой техлид)
Эксперт JSЭксперт HTML/CSS
 Аватар для mr_dramm
1818 / 1056 / 329
Регистрация: 17.07.2021
Сообщений: 2,147
Записей в блоге: 14
22.04.2024, 21:56
Создать zip с помощью jszip

PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Create ZIP Archive with Images</title>
</head>
<body>
 
<img src="img/1.jpg" class="photo">
<img src="img/2.jpg" class="photo">
<img src="img/3.jpg" class="photo">
 
<button id="createZipButton">Create ZIP Archive</button>
<script src="https://cdnjs.cloudflare.com/ajax/libs/FileSaver.js/2.0.0/FileSaver.min.js" integrity="sha512-csNcFYJniKjJxRWRV1R7fvnXrycHP6qDR21mgz1ZP55xY5d+aHLfo9/FcGDQLfn2IfngbAHd8LdfsagcCqgTcQ==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jszip/3.10.1/jszip.min.js" integrity="sha512-XMVd28F1oH/O71fzwBnV7HucLxVwtxf26XV8P4wPk26EDxuGZ91N8bsOttmnomcCD3CS5ZMRL50H0GgOHvegtg==" crossorigin="anonymous" referrerpolicy="no-referrer"></script>
<script>
document.getElementById('createZipButton').addEventListener('click', () => {
    const images = document.querySelectorAll('.photo');
    if (images.length === 0) {
        alert('No images found.');
        return;
    }
 
    const zip = new JSZip();
    const promises = [];
 
    images.forEach((image, index) => {
        const imageUrl = image.src;
        const fileName = `photo_${index + 1}.jpg`;
 
        const promise = fetch(imageUrl)
            .then(response => response.blob())
            .then(blob => zip.file(fileName, blob));
        promises.push(promise);
    });
 
    Promise.all(promises).then(() => {
        zip.generateAsync({ type: 'blob' }).then((content) => {
            saveAs(content, 'photos.zip');
        });
    });
});
</script>
</body>
</html>
так как картинки загружабтся с помощью fetch нужно чтобы они загржжались без нарушения CORS
1
 Аватар для voraa
1245 / 1148 / 178
Регистрация: 21.01.2024
Сообщений: 5,316
23.04.2024, 08:34
Цитата Сообщение от kukush Посмотреть сообщение
сохранить все img
Сохранить куда? Себе в файл? Сохранить на сервере?
0
0 / 0 / 0
Регистрация: 11.02.2014
Сообщений: 16
23.04.2024, 15:06  [ТС]
Необходимо сохранить с сервера к себе на устройство

Добавлено через 5 минут
Цитата Сообщение от ft4l Посмотреть сообщение
...

На каждую фотографию есть вопрос - Сохранить Да/Нет. Можно это обойти ?
0
 Аватар для voraa
1245 / 1148 / 178
Регистрация: 21.01.2024
Сообщений: 5,316
23.04.2024, 15:49
Цитата Сообщение от kukush Посмотреть сообщение
Можно это обойти ?
Нет.
1
Молодой техлид)
Эксперт JSЭксперт HTML/CSS
 Аватар для mr_dramm
1818 / 1056 / 329
Регистрация: 17.07.2021
Сообщений: 2,147
Записей в блоге: 14
23.04.2024, 18:27
Цитата Сообщение от kukush Посмотреть сообщение
На каждую фотографию есть вопрос - Сохранить Да/Нет. Можно это обойти ?
Если применительно к предложенному коду, то нет. Но можно использовать File System API , в этом апи есть возможность отрыть диалог выбора директории, создать несколько файлов, если встерится файл с похожим именем прибавить к имени число(стандантное поедение при сохраниении файлов с одинаковыми именами). Поддержка браузерами
0
 Аватар для voraa
1245 / 1148 / 178
Регистрация: 21.01.2024
Сообщений: 5,316
23.04.2024, 18:27
Цитата Сообщение от mr_dramm Посмотреть сообщение
Но можно использовать File System API , в этом апи есть возможность отрыть диалог выбора директории, просканировать выбранную директорию определеть какие файлы в ней уже имеются и создать несколько файлов,
А вы пробовали сами работать с этим API?
Я не пробовал, но из чтения документаций и спецификаций понял, что все равно будут запрашиваться разрешения на доступ к файлам в виде диалоговых окон.
Без разрешений только доступ к "частной" файловой системе, но она не видна из-вне браузера (Ну типа как indexedDB, или localStorage)
0
Молодой техлид)
Эксперт JSЭксперт HTML/CSS
 Аватар для mr_dramm
1818 / 1056 / 329
Регистрация: 17.07.2021
Сообщений: 2,147
Записей в блоге: 14
23.04.2024, 18:53
Цитата Сообщение от voraa Посмотреть сообщение
Я не пробовал, но из чтения документаций и спецификаций понял, что все равно будут запрашиваться разрешения на доступ к файлам в виде диалоговых окон.
Конечно будут запрашивать разрешения для доступа к директории, да пробовал
0
 Аватар для voraa
1245 / 1148 / 178
Регистрация: 21.01.2024
Сообщений: 5,316
23.04.2024, 19:08
Цитата Сообщение от mr_dramm Посмотреть сообщение
Конечно будут запрашивать разрешения для доступа к директории, да пробовал
И что, потом в эту директорию можно писать что угодно без всяких разрешений?
Просто в доке написано, что дополнительно запрашивается при записи
https://fs.spec.whatwg.org/#ap... filehandle
This operation requires write permission, even if the file being returned already exists. If this handle doesn’t already have write permission, this could result in a prompt being shown to the user.
Для этой операции требуется разрешение на запись, даже если возвращаемый файл уже существует. Если у этого дескриптора еще нет разрешения на запись, пользователю может быть показано приглашение.
0
Невнимательный
 Аватар для ft4l
3106 / 1275 / 358
Регистрация: 08.02.2013
Сообщений: 7,440
Записей в блоге: 2
23.04.2024, 19:49
Цитата Сообщение от voraa Посмотреть сообщение
Нет.
Возможно ТС-у не понравилось ещё одно лишнее нажатие кнопки,
то которе из-за
Цитата Сообщение от ft4l Посмотреть сообщение
retVal = confirm(src + " Do you want to download ?")
Там ещё от настроек браузера бывает сначала "открыть или сохранить" и потом только выбор места.
Цитата Сообщение от kukush Посмотреть сообщение
обойти
оно, как мне кажется, предотвращало начало загрузки файла, до того как юзер выбрал путь+имя...
Возможно замечали, что пока что-то выбирается в диалоге выборе места сохранения, по сети уже что-то грузит
, и если "Отмена", то это работает как прерывание соединения.
+ как-бы ставит старты скачивания в очередь... но диалог сохранения может и ведёт себя так-же... типа очереди
у меня практически для всего включено сохранять, и спрашивать куда.
... даже мысли никогда такой не возникало,) что грузить всегда всё надо в папку "Загрузки"))
Но бывает и такое... плюс помню раньше менеджерыЗагрузок можно было в браузерах задействовать... ещё варианты
0
Молодой техлид)
Эксперт JSЭксперт HTML/CSS
 Аватар для mr_dramm
1818 / 1056 / 329
Регистрация: 17.07.2021
Сообщений: 2,147
Записей в блоге: 14
23.04.2024, 22:55
voraa, с таким кодом задается два запроса один на разрешение читать файлы из директории и второй запрос на редактирования фалов в директории
PHP/HTML
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Save Images to Directory</title>
  </head>
  <body>
    <img src="img/1.jpg" class="photo" />
    <img src="img/2.jpg" class="photo" />
    <img src="img/3.jpg" class="photo" />
    <img src="img/4.jpg" class="photo" />
    <button id="saveImagesButton">Save Images to Directory</button>
    <script>
      document
        .getElementById("saveImagesButton")
        .addEventListener("click", async () => {
          const images = document.querySelectorAll(".photo");
          if (images.length === 0) {
            alert("No images found.");
            return;
          }
 
          try {
            const directoryHandle = await window.showDirectoryPicker();
 
            const existingFiles = [];
            for await (const entry of directoryHandle.values()) {
              existingFiles.push(entry.name);
            }
 
            images.forEach(async (image, index) => {
              const imageUrl = image.src;
              const fileName = `photo_${index + 1}.jpg`;
 
              const response = await fetch(imageUrl);
              if (!response.ok) {
                throw new Error(`Failed to fetch ${imageUrl}`);
              }
              const fileData = await response.blob();
 
              let newFileName = fileName;
              let count = 1;
              while (existingFiles.includes(newFileName)) {
                newFileName = `${fileName.replace(".jpg", `_${count}.jpg`)}`;
                count++;
              }
 
              const fileHandle = await directoryHandle.getFileHandle(
                newFileName,
                { create: true },
              );
              const writable = await fileHandle.createWritable();
              await writable.write(fileData);
              await writable.close();
 
              console.log(`Saved ${newFileName}`);
            });
 
            // alert('Images saved successfully.');
          } catch (error) {
            console.error("Error saving images:", error);
            // alert('An error occurred while saving images.');
          }
        });
    </script>
  </body>
</html>
2
 Аватар для voraa
1245 / 1148 / 178
Регистрация: 21.01.2024
Сообщений: 5,316
23.04.2024, 23:26
Цитата Сообщение от mr_dramm Посмотреть сообщение
voraa, с таким кодом задается два запроса один на разрешение читать файлы из директории и второй запрос на редактирования фалов в директории
Понял.
Попробовал. Так и работает.
Спасибо

Добавлено через 12 минут
Работает, но только в Хроме.

Добавлено через 12 минут
И только на десктопе
https://caniuse.com/?search=showDirectoryPicker
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
23.04.2024, 23:26
Помогаю со студенческими работами здесь

Как создать кнопку, которая выполняет функцию "сохранить как" в бинарном файле
Помогите с кодом пожалуйста. Буду очень признательна за сам полный код)

Создать свой комонет(кнопку) которая будет убегать от курсора верх и вниз(и все). Есть у кого наработки?
Так и не понял как начать.

bios v.3.0 не могу сохранить intel(r)speed step(tm) tech все остальное сохраняется как сохранить?
bios v.3.0 не могу сохранить intel(r)speed step(tm) tech все остальное сохраняется как сохранить?

bios v.3.0 не могу сохранить intel(r)speed step(tm) tech все остальное сохраняется как сохранить?
люди помогите! у меня bios v.3.0 все сохраняется кроме intel(r) speed step(tm)tech как сохранить?

Как при нажатии на кнопку создать еще одну кнопку?
Собственно во прос в выше, я нажимаю на кнопку, рядом должна появится еще одна, как такие вещи вообще реализуются?


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит токи на L и напряжения на C в установ. режимах до и. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
Почему дизайн решает?
Neotwalker 09.01.2026
В современном мире, где конкуренция за внимание потребителя достигла пика, дизайн становится мощным инструментом для успеха бренда. Это не просто красивый внешний вид продукта или сайта — это. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru