javascript - vue 初始化數(shù)據(jù)賦值報錯
問題描述
vue代碼<script>import axios from ’axios’;export default { data() {return { titleList: [],} }, created() {this.axios.get(’XX’).then(function(response) { console.log(response.data); this.titleList=response.data;}).catch(function (error) { console.log(error);}); }}</script>報錯
TypeError: Cannot set property ’titleList’ of undefined類型錯誤,不能設(shè)置未定義的屬性,
數(shù)據(jù)response.data是一個對象數(shù)組我已經(jīng)初始化了titleList,不知為何說他未定義,求大神解答
問題解答
回答1:this 指向更改了 你可以打印出this來看一下指向誰
解決方案
1.用箭頭函數(shù)吧 2.保存this (let _this = this)
回答2:.then(res => { this.titleList = res;})回答3:
this.axios.get(’XX’) .then(function (response) { response=response.body; this.titleList=response.data; }) .catch(function (error) { console.log(error);})
這樣試下。如果不行,把錯誤貼出看下!
回答4:this指針丟失,可以使用箭頭函數(shù),也可以用一個變量保存this let _this = this
回答5:我在使用axios請求數(shù)據(jù)的時候記得是在程序入口文件main.js里面全局引入axios類庫,試試引入后用Vue.prototype.$http=axios,之后就可以在全局使用了,至于樓上給出的答案指出的this指針問題,可以試試,我習(xí)慣了es6的語法,所以項(xiàng)目中用的一般都是箭頭函數(shù)
回答6:axios.get(’***’).then((res) => { this.titleList=res.data;});
使用這種方式試試
相關(guān)文章:
1. javascript - react如何獲取offsetX?2. python - sqlalchemy更新數(shù)據(jù)報錯3. html5 - 前端面試碰到了一個緩存數(shù)據(jù)的問題,來論壇上請教一下4. MySQL中無法修改字段名的疑問5. macos - 無法source activate python276. PHPExcel表格導(dǎo)入數(shù)據(jù)庫怎么導(dǎo)入7. css - 移動端 盒子內(nèi)加overflow-y:scroll后 字體會變大8. 運(yùn)行python程序時出現(xiàn)“應(yīng)用程序發(fā)生異常”的內(nèi)存錯誤?9. html - 網(wǎng)頁的a標(biāo)簽到底要不要寫上域名?10. 我在導(dǎo)入模板資源時遇到無法顯示的問題,請老師解答下

網(wǎng)公網(wǎng)安備