vue如何給數(shù)組添加新對象并賦值
給數(shù)組添加新對象并賦值
方法一
適用于數(shù)組就只有一組
listData: [{name:"張三",age:18}],
//直接添加對象
listData.sex="男"方法二
適用于數(shù)組中有多組信息
listData:[],
list:[{"張三","李四"}]
//比如想把另外一個數(shù)組中編列出來的值加入到這個數(shù)組中
? ?for (let index = 0; index < this.listlist.length; index++) {
? ? ? ? ? this.listData.push({ name: "" });
? ? ? ? ? this.listData[index].name= this.list[index];
? ? ? ? }數(shù)組賦值踩過的坑及解決
最近需要在Vue當中完成動態(tài)賦值數(shù)組操作,從服務(wù)器拿到數(shù)據(jù)后,刷新數(shù)組中的數(shù)據(jù),但是發(fā)現(xiàn)無論使用什么方法都不行,通過打log,發(fā)現(xiàn)數(shù)據(jù)在這里就無法向下執(zhí)行,而且也沒有報任何的異常,最終問題解決,在這里做個記錄。
Vue中的數(shù)組賦值和在普通的JS中賦值還是有所區(qū)別。
- 以下操作可以引起界面刷新:push,pop ,unshift,shift,reverse,sort,splice
- 以下操作不會引起界面刷新:slice,concat ,filter
還有一點需要注意:
如果通過直接賦值或者改變長度是無法讓界面刷新的。
(1)通過索引直接設(shè)置項。
(2)修改數(shù)組長度,mylist.length=3
第二點,在從服務(wù)器中獲取數(shù)據(jù)后賦值需要注意一個問題:主體對象的改變。
比如在使用axios對象發(fā)起請求后,在返回方法中處理數(shù)據(jù)需要注意:
注意在axios的then方法中調(diào)用對象時,不能使用this對象,因為此時this對象指的是axios實例,所以通過this是獲取不到vue實例中的data數(shù)據(jù)的,必須在外界使用一個值來指向vue實例對象,通過這個外部對象來賦值,才是正確的。
var self;
created:function(){
self = this;
},
mouted:function(){ ? ? ? ?
axios.create({
? ? ? ? baseURL: 'url',
? ? ? ? timeout: 10000,
? ? ? ? headers: { 'Content-Type': 'application/json' }
? ? ? }).get('xxxxxxxxxx')
? ? ? ? ? .then(function(response){
? ? ? ? ? ? if(response.data.dataList.length>0){
? ? ? ? ? ? ? var datalist = response.data.dataList;
? ? ? ? ? ? ? for(var i=0;i<datalist.length;i++){
? ? ? ? ? ? ? ? self.DeviceTypeList.push({devicetype:datalist[i].name});
? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? })
? ? ? ? ? .catch(function(error){
? ? ? ? ? ? console.log(JSON.stringify(error));
? ? ? ? ? });
}以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
antd vue 如何調(diào)整checkbox默認樣式
這篇文章主要介紹了antd vue 如何調(diào)整checkbox默認樣式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-12-12

