Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Как на клиентском JavaScript создать некий текст и сохранить (https://javascript.ru/forum/dom-window/56942-kak-na-klientskom-javascript-sozdat-nekijj-tekst-i-sokhranit.html)

mmotor 11.07.2015 03:39

Как на клиентском JavaScript создать некий текст и сохранить
 
Нужно дать пользователю возможность сохранить некий текст в файл, даже если отключен интернет

Deff 11.07.2015 03:48

mmotor,
Сохранить в один из вариантов Storage браузера, наиболее просто в localStorage, но убивается очисткой Кеша, про менее распространённые методы можно почитать в гугле, к примеру FileApi

kostyanet 11.07.2015 04:13

Локально через data url, например http://stackoverflow.com/a/18197511/2607462

alex_rr 13.07.2015 11:40

мб localStorage подойдёт?

kostyanet 13.07.2015 13:49

А как из localStorage сохранить текст в файл на диск?

Leon-on12 13.07.2015 16:04

Цитата:

Сообщение от kostyanet
А как из localStorage сохранить текст в файл на диск?

Ну если мы знаем ключ. И работаем в IE с плохими настройками безопасности, то наверное можно использовать activeX.
Достаём из локала и юзаем актив.

Deff 13.07.2015 16:07

Основная задача не сохранить на диск - явно, а сделать данные нестираемые при очиске кеша браузера, а сохранить можно и на сервер при восстановлении связи. Для этого есть (не во всех браузерах) иные Storage и FileApi

mmotor 13.07.2015 17:13

Благодарю за ответы. У меня основная задача все таки сохранить на диск, причем в пределах текущей сессии.

В целом я сделал так

window.open("data:application/octet-stream," + (JSON.stringify(content)), "fail");


Теперь возник вопрос, как задать имя файлу.

рони 13.07.2015 18:00

mmotor,
window.open("data:application/octet-stream," + (JSON.stringify(content)), input.value+".txt");

mmotor 13.07.2015 19:08

window.open("data:application/octet-stream," + (JSON.stringify("df")), "d.txt");


нету имени у файла заданного

kostyanet 13.07.2015 19:09

Цитата:

Сообщение от Deff
Основная задача не сохранить на диск - явно

Там же написано - сохранить в файл. Где еще файлы могут быть?

Цитата:

Сообщение от mmotor
Теперь возник вопрос, как задать имя файлу.

Еще можно тупо в атрибуте download="filename.ext" если через мгновенно созданную ссылку.

kostyanet 13.07.2015 19:16

Вот кусок из юзер-скрипта сохраняющий массив в чесеве:

if(rows.length) {
	var blob = new Blob(rows, {type:'text/csv'}),
		link = document.createElement("a");
	link.download = file_name+'.csv';
	link.style.display='none';
	link.href = window.URL.createObjectURL(blob);
	link = document.body.appendChild(link);
	link.click();
	var timeoutID = setTimeout(function() {
		link = document.body.removeChild(link);
		delete link;
		window.clearTimeout(timeoutID);
	}, 1500);
}


Возможно ФФ-специфичный, попробуйте приделать к своим реалиям. Через блоб получается лучше чем через дата-урл напрямую.

ЗЫ Для фактуры http://stackoverflow.com/questions/1...-and-save-file

рони 13.07.2015 22:12

сохранение текста в файл для Google Chrome и Mozilla Firefox
 
mmotor,
function download(filename, text) {
    var blob = new Blob([text], {type:'text/csv'}),
        link = document.createElement('a');
        link.href = URL.createObjectURL(blob);
        link.setAttribute('download', filename);
        var event = document.createEvent('MouseEvents');
        event.initEvent('click', true, true);
        link.dispatchEvent(event);
}
download('test.txt', 'Hello world! Hello world!');

kostyanet 14.07.2015 07:33

if (document.createEvent) то click() не сработает?

рони 14.07.2015 12:16

kostyanet,
нет не сработает, проверить как всегда кому-то лень -- можно убрать link.click(); только ветка document.createEvent

kostyanet 14.07.2015 12:31

Ну я и говорю, а если document.createEvent то click() не сработает?

рони 14.07.2015 15:31

kostyanet,
нет Firefox не будет реагировать на такой клик, Chrome безразлично сработает в обоих случаях, click() оставлен про запас не нравится можно убрать.

kostyanet 14.07.2015 22:45

Цитата:

Сообщение от рони
Chrome безразлично сработает в обоих случаях

То есть Хром попадет и в тот, и в другой зуб вилки?

Я одного не пойму - вы же видите что условие вычисляется в true

Цитата:

если document.createEvent то click() не сработает?
но второй раз уже отвечаете как будто в false.

Короче, прямым текстом - в каком браузере a.click() не сработает и понадобится сооружать кастомное событие и поджигать?

рони 14.07.2015 23:43

kostyanet,
в Firefox не сработает click()

рони 14.07.2015 23:57

kostyanet,
убрал лишнее смотрите 13 пост

kostyanet 15.07.2015 04:58

Цитата:

Сообщение от рони
в Firefox не сработает click()

Это с какого года?

Ладно, не важно. Вы просто скопировали сырец с СО по моей ссылке, чтобы любовно оформить его в тегах "запустить". В этом же вы видите вашу великую миссию - подсовывать ламерам готовенькое за плюсики. Звучит гимн героев советского союза... :)

Разумеется в ФФ .click() работает и давно и получше чем в других браузерах.

рони 15.07.2015 06:52

Цитата:

Сообщение от kostyanet
Разумеется в ФФ .click() работает и давно и получше чем в других браузерах.

шедевр!!!вам хоть иногда ... , видимо нет :)

kostyanet 15.07.2015 14:50

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

рони 15.07.2015 16:17

kostyanet
хорошо пусть в вашей вселенной клик в ФФ работает
тогда этот код для вас
function download(filename, text) {
    var blob = new Blob([text], {type:'text/csv'}),
        link = document.createElement('a');
        link.href = URL.createObjectURL(blob);
        link.setAttribute('download', filename);
        link.click()
}
download('test.txt', 'Hello world! Hello world!');

остальным я рекомендую не этот а рабочий код в 13 посте.
буду считать что вы kostyanet невнимательны, при чтении тем.

kostyanet 15.07.2015 21:48

Цитата:

Сообщение от рони
буду считать что вы kostyanet невнимательны, при чтении тем.

Это вы профессор. Что вы щелкать-то собираетесь? Абстрактный элемент которого еще нет дома? Само собой он не будет щелкаться, а браузеры которые дают такое щелкать - не нормальные. ФФ не дает? Значит в ФФ все сделано правильно.

Надо в дом засунуть и тогда хоть где хоть защелкайся. То есть смысл той вилки все равно нулевой. Нет никакой связи между наличием кастомных событий и возможной фичей браузера который дает щелкать по абстрактному элементу (ну типа элементу в теневом доме). Потому что вы подепили тот снипет лишь бы оформить.

Вот что надо вставить перед link.click():

link = document.body.appendChild(link);
link.click();


Ну, типа да, затем придется удалить или просто закешировать и затем навешивать другие урлы и имена файлов.

рони 15.07.2015 22:18

Цитата:

Сообщение от kostyanet
Вот что надо вставить перед link.click():

одно радует что вы разобрались, и дали разумное обьяснение, жаль что до этого вы счёлкали
Цитата:

Сообщение от kostyanet
Абстрактный элемент которого еще нет дома?

сейчас если хотите делайте круглые глаза, изображайте, патетику и охайте.
мир по прежнему вокруг вас одни дураки.
да, а где код с интерфейсом для
Цитата:

Сообщение от kostyanet
Ну, типа да, затем придется удалить или просто закешировать и затем навешивать другие урлы и имена файлов.

? (не надо кода, я вам так верю)

kostyanet 15.07.2015 23:06

Цитата:

Сообщение от рони
да, а где код с интерфейсом для

Делайте квадратные глаза http://javascript.ru/forum/dom-windo...tml#post379204

рони 15.07.2015 23:35

kostyanet,
только как догадатся что rows это массив с текстом? вижу недоработочка в интерфейсе, добавьте поле ввода с проверкой, чтоб не гонять пустой массив, а то вы как то не по программистки.

kostyanet 16.07.2015 06:22

Признаю вашу наглость и позволяю приделать к тому кусочку все что пожелаете.

Для тех кто тоже нипонял: текст надо засунуть в [], то есть вот так передать [text]

mmotor 30.07.2015 03:48

Цитата:

Сообщение от рони (Сообщение 379238)
mmotor,
function download(filename, text) {
    var blob = new Blob([text], {type:'text/csv'}),
        link = document.createElement('a');
        link.href = URL.createObjectURL(blob);
        link.setAttribute('download', filename);
        var event = document.createEvent('MouseEvents');
        event.initEvent('click', true, true);
        link.dispatchEvent(event);
}
download('test.txt', 'Hello world! Hello world!');

В IE не работает

рони 30.07.2015 05:48

Цитата:

Сообщение от mmotor
В IE не работает

:blink:
Цитата:

Сообщение от рони
сохранение текста в файл для Google Chrome и Mozilla Firefox


mmotor 30.07.2015 13:30

Ну так а как в IE то сделать?

Deff 30.07.2015 13:58

mmotor,
Вы бы сказали конечную задачу, возможно( а тем более в ИЕ) сохранять без файла. Наверняка не затем, чтобы читать файл самому пользователю? (Или да ?) Думаю, вы хотите затем загрузить этот файл при обрыве инет-соединения ? В ИЕ есть ведь и другие способы сохранить данные, к примеру порыть в сторону behavior

mmotor 30.07.2015 15:56

Подскажите, а как здесь делают?

http://eligrey.com/demos/FileSaver.js/

mmotor 10.09.2015 14:08

Подскажите, а как теперь сохранить картинку таким же образом

Lemme 10.09.2015 23:06

http://javascript.ru/forum/misc/5815...tml#post387523


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