<div id="app">
<p>數(shù)字: {{number}}</p>
<button @click="plusOne(rand1,$event)">點(diǎn)一下加2</button>
<customize-btn @click.native="minus(rand2)" ></customize-btn>
</div>
<script type="text/javascript">
var rand1=Math.random()*10;
var rand2=Math.random()*10;
var customizeBtn = {
data: function() {
return { btnClass: "btn" }
},
template: ` <div :class="btnClass">這是一個(gè)自定義的組件,讓它擁有點(diǎn)擊事件能力,就像個(gè)按鈕</div> `,
}
var app = new Vue({
el: "#app",
data: {
message: 'hello world',
number: 3,
rand1:rand1,
rand2:rand2
},
methods: {
plusOne: function(num, a) {
console.log(rand1);
this.number = this.number + num;
console.log("隨機(jī)增加一個(gè)數(shù)后的:" + this.number);
this.rand1=Math.random()*10;
return this.number;
},
minus: function(num) {
console.log(rand2);
this.number = this.number - num;
console.log("隨機(jī)減去一個(gè)數(shù)后的:" + this.number);
this.rand2=Math.random()*10;
return this.number;
}
},
components: {
"customizeBtn": customizeBtn
}
})
</script>
發(fā)現(xiàn)下面幾個(gè)情況:
1.事件監(jiān)聽和樣式屬性綁定都直接寫在組件標(biāo)簽上
<customize-btn @click.native="minus(rand2)" :class="btnClass" ></customize-btn>
報(bào)錯(cuò)btnClass未定義
2.事件監(jiān)聽和樣式屬性綁定都直接寫在tempalet里面
template: ` <div @click.native="minus(rand2)" :class="btnClass">這是一個(gè)自定義的組件,讓它擁有點(diǎn)擊事件能力,就像個(gè)按鈕</div> `,
不報(bào)錯(cuò),但是第二個(gè)按鈕點(diǎn)擊無效,事件沒綁上
3.事件監(jiān)聽寫在template,樣式屬性綁定寫在組件標(biāo)簽上
<customize-btn :class="btnClass" ></customize-btn>
template: ` <div @click.native="minus(rand2)">這是一個(gè)自定義的組件,讓它擁有點(diǎn)擊事件能力,就像個(gè)按鈕</div> `,
報(bào)錯(cuò),btnClass未定義
4.第三種就是最前面的那樣。事件監(jiān)聽寫在組件標(biāo)簽上,樣式屬性綁定寫在template里,這里正常。
<customize-btn @click.native="minus(rand2)"></customize-btn>
template: ` <div :class="btnClass">這是一個(gè)自定義的組件,讓它擁有點(diǎn)擊事件能力,就像個(gè)按鈕</div> `,
從結(jié)論看,自定義組件的事件監(jiān)聽必須寫在組件標(biāo)簽上,而自定義組件的樣式屬性(包括其他屬性?)綁定必須在template里面? 這個(gè)結(jié)論對(duì)不對(duì)呢?為什么呢?
1.<customize-btn @click.native="minus(rand2)" :class="btnClass" ></customize-btn> 這是要將父組件的btnClass傳遞個(gè)子組件,但是父組件中沒有btnClass,所以btnClass is undefined!同問題3
2.<div @click.native="minus(rand2)" :class="btnClass"> 子組件中沒有定義minus的function
3.<customize-btn @click.native="minus(rand2)"></customize-btn> 建議你了解下父子組件的通信!
北大青鳥APTECH成立于1999年。依托北京大學(xué)優(yōu)質(zhì)雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數(shù)據(jù)專業(yè)的國家
北大青鳥中博軟件學(xué)院創(chuàng)立于2003年,作為華東區(qū)著名互聯(lián)網(wǎng)學(xué)院和江蘇省首批服務(wù)外包人才培訓(xùn)基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團(tuán)創(chuàng)建于1999年,經(jīng)過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術(shù)與教育服務(wù)機(jī)構(gòu),發(fā)展為教育服務(wù)業(yè)的綜合性企業(yè)集團(tuán),成為集合面授教學(xué)培訓(xùn)、網(wǎng)
達(dá)內(nèi)教育集團(tuán)成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機(jī)構(gòu),是中國一站式人才培養(yǎng)平臺(tái)、一站式人才輸送平臺(tái)。2014年4月3日在美國成功上市,融資1
曾工作于聯(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ù), 熟練的跨平臺(tái)面向?qū)ο箝_發(fā)經(jīng)驗(yàn),技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點(diǎn)難點(diǎn)突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對(duì)瀏覽器兼容性、前端性能優(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)師。