【发布时间】:2017-10-02 15:35:14
【问题描述】:
我正在尝试使用 axios 发布我的表单,但我无法使用 expressjs 将数据发送到我的后端
这就是我正在做的:
<template>
<form class="" method="post" @submit.prevent="postNow">
<input type="text" name="" value="" v-model="name">
<button type="submit" name="button">Submit</button>
</form>
</template>
export default {
name: 'formPost',
data() {
return {
name: '',
show: false,
};
},
methods: {
postNow() {
axios.post('http://localhost:3030/api/new/post', {
headers: {
'Content-type': 'application/x-www-form-urlencoded',
},
body: this.name,
});
},
components: {
Headers,
Footers,
},
};
后端文件:
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: true }));
router.post('/new/post', (req, res) => {
res.json(console.log("this is working" + ' ' + req.body.name));
});
我收到的错误是:
this is working undefined
【问题讨论】:
-
posti未在任何地方定义并在此处使用body: this.posti -
对不起,我更新了我的问题,应该是 this.name
-
哦,我刚刚注意到:您的方法不在
methods对象内。将其与data、components等一起放入methods。 -
对不起,我有更多的组件和方法,在编辑以确保安全时,我不小心删除了它。刚刚更新!
标签: javascript node.js express vue.js axios