リロードせずにデータを送信してデータベースに保存することはできません。私は理解できない、どうして私のページがリロードされるのか。私はここでページをリロードせずにajaxでデータを送信する方法は? (Nodejs)
は私の形です...私は私の問題を解決することができますどのようにないアイデアを持っていない:ここで
<form action="/user/change" method="post">
Name: <input type="text" id="name" name='profile_name' value="{{myName}}">
Surname: <input type="text" id="surname" name="profile_surname" value="{{mySurname}}">
Age: <input id="profile_age" name="age" type="text" value="{{myAge}}">
<input type="hidden" name="_csrf" value='{{csrfToken}}'>
<input type="submit" value="Send" id="send_profile">
</form>
は私のAjaxのスクリプトです:
$('#send_profile').click(function() {
$.ajax({
global: false,
type: 'POST',
url: /user/change,
dataType: 'html',
data: {
name: $("#profile_name").val(),
surname: $("#profile_surname").val(),
age: $("#profile_age").val()
},
success: function (result) {
console.log(result);
},
error: function (request, status, error) {
serviceError();
}
});
});
そして、私のNode.jsの要求ハンドラ:
router.post('/change', function (req, res) {
var name = req.body.name,
surname = req.body.surname,
age = req.body.age
User.findOneAndUpdate({_id: req.user._id}, {$set:{name: name, surname: surname, age: age}}, {new: true}, function(err, doc){
if(err){
console.log("Something wrong when updating data!");
}
console.log(req);
console.log('req received');
res.redirect('/user/'+req.user._id);
});
});
URLを上の
詳細情報も文字列でなければなりません。 url: '/ user/change'、 –