<div id="app">
<p>數(shù)字: {{number}}</p>
<button @click="plusOne(rand1,$event)">點一下加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">這是一個自定義的組件,讓它擁有點擊事件能力,就像個按鈕</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("隨機增加一個數(shù)后的:" + this.number);
this.rand1=Math.random()*10;
return this.number;
},
minus: function(num) {
console.log(rand2);
this.number = this.number - num;
console.log("隨機減去一個數(shù)后的:" + this.number);
this.rand2=Math.random()*10;
return this.number;
}
},
components: {
"customizeBtn": customizeBtn
}
})
</script>
發(fā)現(xiàn)下面幾個情況:
1.事件監(jiān)聽和樣式屬性綁定都直接寫在組件標(biāo)簽上
<customize-btn @click.native="minus(rand2)" :class="btnClass" ></customize-btn>
報錯btnClass未定義
2.事件監(jiān)聽和樣式屬性綁定都直接寫在tempalet里面
template: ` <div @click.native="minus(rand2)" :class="btnClass">這是一個自定義的組件,讓它擁有點擊事件能力,就像個按鈕</div> `,
不報錯,但是第二個按鈕點擊無效,事件沒綁上
3.事件監(jiān)聽寫在template,樣式屬性綁定寫在組件標(biāo)簽上
<customize-btn :class="btnClass" ></customize-btn>
template: ` <div @click.native="minus(rand2)">這是一個自定義的組件,讓它擁有點擊事件能力,就像個按鈕</div> `,
報錯,btnClass未定義
4.第三種就是最前面的那樣。事件監(jiān)聽寫在組件標(biāo)簽上,樣式屬性綁定寫在template里,這里正常。
<customize-btn @click.native="minus(rand2)"></customize-btn>
template: ` <div :class="btnClass">這是一個自定義的組件,讓它擁有點擊事件能力,就像個按鈕</div> `,
從結(jié)論看,自定義組件的事件監(jiān)聽必須寫在組件標(biāo)簽上,而自定義組件的樣式屬性(包括其他屬性?)綁定必須在template里面? 這個結(jié)論對不對呢?為什么呢?
1.<customize-btn @click.native="minus(rand2)" :class="btnClass" ></customize-btn> 這是要將父組件的btnClass傳遞個子組件,但是父組件中沒有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è)的國家
達內(nèi)教育集團成立于2002年,是一家由留學(xué)海歸創(chuàng)辦的高端職業(yè)教育培訓(xùn)機構(gòu),是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
北大課工場是北京大學(xué)校辦產(chǎn)業(yè)為響應(yīng)國家深化產(chǎn)教融合/校企合作的政策,積極推進“中國制造2025”,實現(xiàn)中華民族偉大復(fù)興的升級產(chǎn)業(yè)鏈。利用北京大學(xué)優(yōu)質(zhì)教育資源及背
博為峰,中國職業(yè)人才培訓(xùn)領(lǐng)域的先行者
曾工作于聯(lián)想擔(dān)任系統(tǒng)開發(fā)工程師,曾在博彥科技股份有限公司擔(dān)任項目經(jīng)理從事移動互聯(lián)網(wǎng)管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責(zé)任公司從事總經(jīng)理職務(wù)負責(zé)iOS教學(xué)及管理工作。
浪潮集團項目經(jīng)理。精通Java與.NET 技術(shù), 熟練的跨平臺面向?qū)ο箝_發(fā)經(jīng)驗,技術(shù)功底深厚。 授課風(fēng)格 授課風(fēng)格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網(wǎng)頁制作和網(wǎng)頁游戲開發(fā)。
具有10 年的Java 企業(yè)應(yīng)用開發(fā)經(jīng)驗。曾經(jīng)歷任德國Software AG 技術(shù)顧問,美國Dachieve 系統(tǒng)架構(gòu)師,美國AngelEngineers Inc. 系統(tǒng)架構(gòu)師。