我正在尝试使用Jquery Ajax调用从反应前端提取post请求。然而,我尝试关于app.post的任何事情似乎都没有实际发送数据到数据库。如果有什么我只是在“完成发送”上得到一个空{}
代码: Server.js
app.post('/api/users', function(req, res) {
var name = req.body.name;
var gender = req.body.gender;
users.findOne({ users : users.name }, function(err, users) {
if (err) return next(err);
users.save(function(err) {
if (err) return next(err);
res.send({ message: users.name + ' has been added' });
});
});
});
代码: 模型/ model.js
var mongoose = require('mongoose');
var userSchema = new mongoose.Schema({
name: {
first: String,
last: String
},
email: String,
gender: String,
school: String,
updated_at: {type: Date, default: Date.now},
});
module.exports = mongoose.model('User', userSchema);
代码:
React Actions文件: 应用程序/动作/ userAction.js
class AddCharacterActions {
constructor() {
this.generateActions(
'addCharacterSuccess',
'addCharacterFail',
'updateName',
'updateGender',
'invalidName',
'invalidGender'
);
}
addCharacter(name, gender) {
$.ajax({
type: 'POST',
url: '/api/users',
data: { name: name, gender: gender }
})
.done((data) => {
this.actions.addCharacterSuccess(data.message);
})
.fail((jqXhr) => {
this.actions.addCharacterFail(jqXhr.responseJSON.message);
});
}
}
export default alt.createActions(AddCharacterActions);
反应控制器:
应用程序/控制器/ userController.js
class AddCharacter extends React.Component {
constructor(props) {
super(props);
this.state = AddCharacterStore.getState();
this.onChange = this.onChange.bind(this);
}
componentDidMount() {
AddCharacterStore.listen(this.onChange);
}
componentWillUnmount() {
AddCharacterStore.unlisten(this.onChange);
}
onChange(state) {
this.setState(state);
}
handleSubmit(event) {
event.preventDefault();
var name = this.state.name.trim();
var gender = this.state.gender;
if (!name) {
AddCharacterActions.invalidName();
this.refs.nameTextField.getDOMNode().focus();
}
if (!gender) {
AddCharacterActions.invalidGender();
}
if (name && gender) {
AddCharacterActions.addCharacter(name, gender);
}
}
我似乎无法弄清楚我的错误发生在哪里虽然我有一个潜行的怀疑,因为我的server.js app.post文件。谢谢
答案 0 :(得分:0)
看起来您没有在Server.js中定义用户。除非在您发布的代码之外定义,否则users.name
未定义。
users.findOne({ users : users.name },...
应为users.findOne({users: name}, ...