vue寫一個組件
寫一個vue組件
我下面寫的是以.vue結(jié)尾的單文件組件的寫法,是基于webpack構(gòu)建的項目。如果還不知道怎么用webpack構(gòu)建一個vue的工程的,可以移步到vue-cli。
一個完整的vue組件會包括一下三個部分:
- template:模板
- js: 邏輯
- css : 樣式
每個組件都有屬于自己的模板,js和樣式。如果將一個頁面比喻成一間房子的話,組件就是房子里的客廳、臥室、廚房、廁所。如果把廚房單獨(dú)拿出來的話,組件又可以是刀、油煙機(jī)...等等。就是說頁面是由組件構(gòu)成的,而組件也可以是組件構(gòu)成的。這樣就可以非常的靈活,耦合性也非常的低。
先來看看一個組件在不是.vue文件內(nèi)的寫法:
Vue.component('simple-counter', {
template: '<div id="inputBox"><input type="text"></div>',
data () { // 數(shù)據(jù)
return {
counter: 0
}
},
methods: {
// 寫點(diǎn)方法
},
created () {
// 生命鉤子
},
computed: {
// 計算屬性
}
})
template是用來干嘛的呢?
<template> <div id="inputBox"> <input type="text"> </div> </template> <!-- template就是這個組件的html,也就是下面部分(vue-loader會將template標(biāo)簽下的內(nèi)容解析出來): --> <div id="inputBox"> <input type="text"> </div> <!-- 對應(yīng)原生寫法的話,就是template內(nèi)的dom字符串 -->
js部分
export default {
data () {
return {
counter: 0
}
},
methods: {
// 方法
},
created () {
// 生命鉤子
},
computed: {
// 計算屬性
}
}
// 在這里很明顯js部分就是對應(yīng)的原生寫法內(nèi)的非template部分了。
// export default這個是es6的模塊寫法,不懂的可以先去了解es6的模塊化
css部分
<style lang="scss" scoped> ...樣式 </style>
<!--這里的你可以使用scss(CSS擴(kuò)展語言)只要安裝"sass-loader"和"node-sass"這兩個npm包就好了,vue-cli已經(jīng)配好相關(guān)參數(shù)了。如果想使用less或其它c(diǎn)ss擴(kuò)展語音,只要裝好各自的編譯包就好了。而scoped是讓css的作用域只在該文件下。-->
引入
要怎么在其它組件引用該組件?
組件一(button.vue)
<template>
<div class="button">
<button @click="onClick">{{text}}</button>
</div>
</template>
<script>
export default {
props: ['text'], // 獲取父組件的傳值
data () {
return {
}
},
methods: {
onClick () {
console.log('點(diǎn)擊了子組件')
}
}
}
</script>
<style lang="scss" scoped>
.button {
button {
width: 100px;
}
}
</style>
組件二(box.vue)
<template>
<div class="box">
<v-button :text="text"></v-button> <!--使用組件并傳值(text)-->
</div>
</template>
<script>
import Button from './button.vue' // 引入子組件
export default {
components: {
'v-button': Button
},
data () {
return {
text: '按鍵的name'
}
},
methods: {
}
}
</script>
總結(jié)
以上所述是小編給大家介紹的vue組寫一個組件,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
vue style屬性設(shè)置背景圖片的相對路徑無效的解決
這篇文章主要介紹了vue style屬性設(shè)置背景圖片的相對路徑無效的解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10
Vuex modules模式下mapState/mapMutations的操作實例
這篇文章主要介紹了Vuex modules 模式下 mapState/mapMutations 的操作實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10
前端使用print.js實現(xiàn)打印功能(基于vue)
最近新接了一個需求,想要在前端實現(xiàn)打印功能,下面這篇文章主要給大家介紹了關(guān)于前端使用print.js實現(xiàn)打印功能(基于vue)的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-05-05

