我的api.php
中有两条路线。
Route::get('resume-list/{templateID}', 'BasicController@getAllResumes'); Route::get('resume/single/{id}', 'BasicController@getResume');
第一个路由正常,但是第二个路由返回索引页的html代码。
以下是该路线的axios调用:
data() {
return {
id: this.$route.params.id,
data: {}
};
},
methods: {
loadData() {
axios.get("api/resume/single/" + this.id).then(response => {
console.log(response);
this.data = response;
});
}
},
created() {
this.loadData();
}
后端功能
public function getResume($id)
{
return Basic::where('id', $id)->firstOrFail();
}
产生此代码的原因是什么?
Bootstrap.js
window._ = require('lodash');
window.Popper = require('popper.js').default;
try {
window.$ = window.jQuery = require('jquery');
require('bootstrap');
require('admin-lte');
} catch (e) {}
window.axios = require('axios');
window.axios.defaults.headers.common['X-Requested-With'] = 'XMLHttpRequest';
let token = document.head.querySelector('meta[name="csrf-token"]');
if (token) {
window.axios.defaults.headers.common['X-CSRF-TOKEN'] = token.content;
} else {
console.error('CSRF token not found: https://laravel.com/docs/csrf#csrf-x-csrf-token');
}
答案 0 :(得分:2)
尝试手动转换-https://laravel.com/docs/5.1/responses#json-responses
如果它不起作用,则问题在于配置路由器
答案 1 :(得分:2)
以这种方式进行设置
window._ = require('lodash');
window.Popper = require('popper.js').default;
try {
window.$ = window.jQuery = require('jquery');
require('bootstrap');
require('admin-lte');
} catch (e) {}
window.axios = require('axios');
//window.axios.defaults.baseURL = process.env.APP_URL;
window.axios.defaults.baseURL = 'http://localhost:8000';
window.axios.defaults.headers.common = {
'X-Requested-With': 'XMLHttpRequest',
'Content-Type':'application/json',
'Accept':'application/json'
};
let token = document.head.querySelector('meta[name="csrf-token"]');
if (token) {
window.axios.defaults.headers.common['X-CSRF-TOKEN'] = token.content;
} else {
console.error('CSRF token not found: https://laravel.com/docs/csrf#csrf-x-csrf-token');
}
Now your axios call will become
loadData() {
axios.get(`/api/resume/single/${this.$route.params.id}`).then(response => {
console.log(response);
});
}
OR
"/api/resume/single/"+this.id