[英]Submit a form using POST request in VueJS
我有一個端點可以使用 POST 請求提交數據,
http://localhost:3000/entry
鍵是fname, lname, age
我可以向給定的端點發出 POST 請求,它會創建一個條目。
我正在嘗試使用 VueJS 提交表單。 但是,當我在表單中調用 API 時,它沒有提交數據。 我檢查了網絡調用,它沒有向端點發送任何數據。
HTML :-
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/1.0.4/vue.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue-resource/0.1.16/vue-resource.min.js"></script>
<script src="script.js"></script>
<link rel="stylesheet" type="text/css" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.min.css">
<link rel="stylesheet" type="text/css" href="style.css">
<div id="vueApp">
<div class="container">
<div class="row">
<div class="col-sm-12">
<h3>
Dashboard
</h3>
</div>
</div>
<div class="row">
<div class="col-sm-12">
<div class="form-group">
<label for="fname">First Name</label>
<input type="text" class="form-control" value="" v-model="fname" />
</div>
<div class="form-group">
<label for="lname">Last Name</label>
<input type="text" class="form-control" value="" v-model="lname" />
</div>
<div class="form-group">
<label for="age">Age</label>
<input type="text" class="form-control" value="" v-model="age" />
</div>
</div>
<div class="col-sm-12">
<a href="#" class="btn btn-success" @click="submitEntry">Submit</a>
<span v-if="ajaxRequest">Please Wait ...</span>
</div>
</div>
<div> </div>
<div class="row" v-if="debug">
<div class="col-sm-12">
<pre>{{ $data | json }}</pre>
</div>
</div>
<!-- Table Start -->
<div class="row">
<table style="width:100%">
<tr>
<th>First Name</th>
<th>Last Name</th>
<th>Age</th>
</tr>
<tr>
<td>{{fname}}</td>
<td>{{lname}}</td>
<td>{{age}}</td>
</tr>
</table>
</div>
<!-- Table END -->
</div>
</div>
腳本.js :-
Vue.http.options.emulateJSON = true;
new Vue({
el: '#vueApp',
data: {
debug: true,
fname: '',
lname: '',
age: '',
ajaxRequest: false,
postResults: []
},
methods: {
submitEntry: function() {
this.ajaxRequest = true;
this.$http.post('http://localhost:3000/entry', {
fname: this.fname,
lname: this.lname,
age: this.age
}, function (data, status, request) {
this.postResults = data;
this.ajaxRequest = false;
});
}}
});
style.css :-
table, th, td {
border: 1px solid black;
border-collapse: collapse;
}
th, td {
padding: 5px;
text-align: left;
}
你可以試試這個。
axios.post('http://localhost:3000/entry',{ params: { fname: this.fname, lname: this.lname, age: this.age }})
.then(response => this.responseData = response.data)
.catch(error => {});
使用前需要鏈接Axios CDN
https://cdn.jsdelivr.net/npm/axios@0.12.0/dist/axios.min.js
即使這有點舊,我也遇到了同樣的問題,沒有數據發送到端點(這個問題首先出現在谷歌中)。 問題是 vue-resource 的 $http.post() 默認將數據發布為資源/json 而不是表單。 要發布表單,請將emulateJSON設置為 true,這將發送“請求正文作為應用程序/x-www-form-urlencoded 內容類型” 。
順便說一句,結果是一個 Promise,這意味着應該使用 then() 來處理響應(正如@ribas 正確提到的那樣)。
所以上例中的 submitEntry() 應該是:
submitEntry: function() {
this.ajaxRequest = true;
this.$http.post('http://localhost:3000/entry', {
fname: this.fname,
lname: this.lname,
age: this.age
}, {
emulateJSON: true // <-- This was missing
}).then(function (data) { // <-- Handle results like this
this.postResults = data;
this.ajaxRequest = false;
});
}}
使用完全不同的庫 (axios) 很好,實際上是 Evan You(Vue 的創建者)推薦的,但它沒有解決使用 vue-resource ajax 庫的實際問題。
也許像這樣
this.$http({method: 'POST', url: URL, data: data})
.then(response => {
this.postResults = data;
this.ajaxRequest = false;
}).catch((err) => {
console.log(err)
})
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.