在使用vue-cli搭建項(xiàng)目時(shí),出現(xiàn)了變量賦值的問題。
從component外部傳入一個(gè)變量來渲染菜單,該變量由$.post取得
,但是使用不同的賦值方式會(huì)使得結(jié)果不同:
如圖,使用方式1進(jìn)行賦值時(shí),菜單無法渲染,使用2時(shí)則正常。
菜單本身是數(shù)組,在chrome中console如下:
component中使用的是簡單的v-for。使用props傳入該變量
問題1:這兩種方式究竟有什么本質(zhì)不同?
問題2:在data中聲名時(shí),若是聲明mainMenu: ''而不是圖中的mainMenu: [],則方法1會(huì)直接報(bào)錯(cuò),這又是什么原理呢?
問題2是因?yàn)槟闶褂昧藇-for,那么你用v-for遍歷一個(gè)字符串顯然是不可行的,必須是數(shù)組類型才能編譯通過的呀
問題1是因?yàn)槟愀铝藬?shù)組的內(nèi)容
https://cn.vuejs.org/v2/guide...
文檔指出
“
Vue 包含一組觀察數(shù)組的變異方法,所以它們也將會(huì)觸發(fā)視圖更新。這些方法如下:
push()
pop()
shift()
unshift()
splice()
sort()
reverse()
你打開控制臺,然后用前面例子的 items 數(shù)組調(diào)用變異方法:example1.items.push({ message: 'Baz' }) 。
由于 JavaScript 的限制,Vue 不能檢測以下變動(dòng)的數(shù)組:
當(dāng)你利用索引直接設(shè)置一個(gè)項(xiàng)時(shí),例如:vm.items[indexOfItem] = newValue
當(dāng)你修改數(shù)組的長度時(shí),例如:vm.items.length = newLength
”
你更新的方式剛剛好屬于不能檢測到變動(dòng)的情況,vue不能檢測到數(shù)組變化就不會(huì)觸發(fā)視圖更新,所以視圖就不會(huì)重新渲染,所以這是vue的特性,跟數(shù)組賦值沒毛線關(guān)系,當(dāng)然倆個(gè)數(shù)組也是不同的,畢竟是倆個(gè)數(shù)組倆個(gè)地址的引用
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進(jìn)“中國制造2025”,實(shí)現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項(xiàng)目經(jīng)理從事移動(dòng)互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍(lán)懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負(fù)責(zé)iOS教學(xué)及管理工作。
浪潮集團(tuán)項(xiàng)目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗(yàn)。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。