【发布时间】:2017-03-05 12:04:42
【问题描述】:
我已经像这样使用vue.js 1.0 成功上传了文件(发布请求):
store () {
this.storingMessage = true;
var form = new FormData();
form.append('subject', this.message.subject);
form.append('message', this.message.message);
form.append('topic_id', this.message.topic_id);
for(var key in this.message.attachment) {
form.append('attachment[' + key + ']', this.message.attachment[key]);
}
MessageService.store(this, form);
}
但是当我尝试更新这样的文件时(提出请求):
update () {
this.updatingMessage = true;
var form = new FormData();
form.append('subject', this.message.subject);
form.append('message', this.message.message);
form.append('slug', this.message.slug);
for(var key in this.message.attachment) {
form.append('attachment[' + key + ']', this.message.attachment[key]);
}
MessageService.update(this, form);
}
在我的控制器中,我 dd($request->all()) 结果是 []。
那么为什么它不能与put?????!?!?!?
服务:
store (context, form) {
return Vue.http.post('/api/message', form)
.then(({data}) => {
context.success();
}, (error) => {
context.error(error.data);
});
},
update (context, form) {
return Vue.http.put('/api/message/' + form.get('slug'), form)
.then(({data}) => {
context.success();
}, (error) => {
context.error(error.data);
});
}
【问题讨论】:
标签: javascript php laravel vue.js form-data