Сохранение файла при нажатии на кнопку
Есть код:
<head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <select id="list"> <option>a.html</option> <option>b.html</option> </select> <br> <textarea id="file" style="width: 100%; height: 300px"></textarea> <br> <button onclick="save()">Save</button> </body> Сервер запущен. При переходе на страницу я выбираю файл, изменяю его и нажимаю сохранить. Вопрос :как сделать, чтобы при нажатии кнопки сохранить файл перезаписывался на значение в textarea |
Цитата:
<body> <form method="post" action='/a.html'> <select id="list" name='select'> <option>a.html</option> <option>b.html</option> </select> <br> <textarea id="file" style="width: 20%; height: 200px" name='file'></textarea> <br> <button type="submit">Save</button> </form> </body> app.post('/a.html', function(req, res) { res.send(req.body.file); //Undefined }); Выскакивает ошибка: Cannot read property 'file' of undefined |
по дефолту express (v4) не парсит post request, и поэтому нужен middleware bodyparser
https://github.com/expressjs/body-parser |
app.use(bodyParser.json()) app.post('/a.html', function(req, res) { res.send(req.body.file); //Undefined }) Undefined все равно |
Вообще-то, в вопросе написана какая-то бессмыслица, белиберда - я три раза перечитал, но так ничего и не понял. Про что на него дают ответы - тоже не понял.
|
Audaxviator,
точно бред какой-то)) думал там обычная отправка файла на сервер, оказалось все сложнее. |
Крч. Есть 2 файла в папке. Выбираем допустим файл 'a.html'. В textarea появляется текст из этого файла. Мы изменяем и нажимаем кнопку Save. И вот как сделать, чтобы при нажатии Save текст в textarea перезаписывался в этот файл.
Если еще проще:возможность перезаписать файл |
Ну делов-то.
Надо на событие 'change' отправить AJAX-запрос на сервер, оттуда прислать строку выбранного файла и ответ вставить в поле textarea. Как это сделать - вот сюда https://learn.javascript.ru/ |
dakociha,
app.use(bodyParser.urlencoded({ extended: false })) Потому что когда вы отправляете форму на сервер Content-type: application/x-www-form-urlencoded, а не application/json, как нужно для bodyParser.json() |
Сделал таким образом
app.post('/', function(req, res) { fs.writeFileSync(path.join(__dirname, 'public') + '/' + req.body.list, req.body.file); res.redirect('back'); }); |
Часовой пояс GMT +3, время: 04:18. |