詳解Vue組件實(shí)現(xiàn)tips的總結(jié)
官網(wǎng)上已經(jīng)有的內(nèi)容,我就不再贅述了,直接在官網(wǎng)上查看即可,這里蚊子想換個(gè)角度來(lái)講解下vue的組件。
組件,顧名思義,就是把一個(gè)相對(duì)獨(dú)立,而且會(huì)多次使用的功能抽象出來(lái),成為一個(gè)組件!如果我們要把某個(gè)功能抽象為一個(gè)組件時(shí),要做到這個(gè)組件對(duì)其他人來(lái)說(shuō)是個(gè)黑盒子,他們不用關(guān)心里面是怎么實(shí)現(xiàn)的,只需要根據(jù)約定的接口調(diào)用即可!
我用一張圖稍微總結(jié)了下Vue中組件的構(gòu)成:

可以看到組件中包含的東西還是蠻多的,而且,還有很多的點(diǎn)沒(méi)有列出來(lái),這里面的每一個(gè)知識(shí)點(diǎn)能都展開(kāi)講很多。不過(guò)我們這里不講原理,只講使用。
我們以一個(gè)tips彈窗為例,來(lái)綜合運(yùn)用下組件的知識(shí)點(diǎn)。tips彈窗,幾乎所有的框架或者類(lèi)庫(kù),都會(huì)有彈窗這個(gè)組件,因?yàn)閺棿斑@個(gè)功能平時(shí)非常普遍,而且模塊解耦度高!
1. 接口約定
我們這里實(shí)現(xiàn)的彈窗,能用到的知識(shí)點(diǎn)有:props, event, slot, ref等。這里我們也能看到各個(gè)知識(shí)點(diǎn)是怎么運(yùn)用的。
/**
* modal 模態(tài)接口參數(shù)
* @param {string} modal.title 模態(tài)框標(biāo)題
* @param {string} modal.text 模態(tài)框內(nèi)容
* @param {boolean} modal.showbtn 是否顯示按鈕
* @param {string} modal.btnText 按鈕文字
*/
Vue.component('tips', {
props : ['tipsOptions'],
template : '#tips',
data(){
return{
show : false
}
},
computed:{
tips : {
get() {
let tips = this.tipsOptions || {};
tips = {
title: tips.title || '提示',
text: tips.text || '',
showbtn : tips.showbtn || true,
btnText : tips.btnText || '確定'
};
// console.log(tips);
return tips;
}
}
}
})
2. modal組件的實(shí)現(xiàn)
tips組件相對(duì)來(lái)說(shuō)實(shí)現(xiàn)的比較簡(jiǎn)單,僅用作提示用戶的簡(jiǎn)單彈層。
模板:
<div class="tips" v-show="show" transition="fade">
<div class="tips-close" @click="closeTips">x</div>
<div class="tips-header">
<slot name="header">
<p class="title">{{tips.title}}</p>
</slot>
</div>
<div class="tips-body">
<slot name="body">
<p class="notice">{{tips.text}}</p>
</slot>
</div>
<div class="tips-footer">
<a href="javascript:;" rel="external nofollow" rel="external nofollow" v-if="tips.showbtn" @click="yes" >{{tips.btnText}}</a>
</div>
</div>
模板中將結(jié)構(gòu)分成了三部分,標(biāo)題、內(nèi)容和操作區(qū)域。這里既可以使用props傳遞字符串,也可以使用slot進(jìn)行定制。
tips樣式:
.tips {
position: fixed;
left: 10px;
bottom: 10px;
z-index: 1001;
-webkit-overflow-scrolling: touch;
max-width: 690px;
width: 260px;
padding: 10px;
background: #fff;
box-shadow: 0 0 10px #888;
border-radius: 4px;
}
.tips-close{
position: absolute;
top: 0;
right: 0;
width: 20px;
height: 20px;
line-height: 20px;
text-align: center;
}
.tips-header{
text-align: center;
font-size: 25px;
}
組件內(nèi)的方法:
methods:{
closeTips(){
this.show = false;
},
yes : function(){
this.show = false;
this.$emit('yes', {name:'wenzi', age:36}); // 觸發(fā)yes事件
},
showTips(){
var self = this;
self.show = true;
setTimeout(function(){
// self.show = false;
}, 2000)
}
}
3. 調(diào)用tips組件
首先我們開(kāi)始渲染組件:
<div class="app">
<a href="javascript:;" rel="external nofollow" rel="external nofollow" @click="showtips">顯示</a>
<tips :tips-options="tipsOptions" ref="dialog" @yes="yes" v-cloak >
<h3 slot="header">提示標(biāo)題</h3>
<div slot="body">
<p>hello world</p>
<p>wenzi</p>
</div>
</tips>
</div>
點(diǎn)擊顯示按鈕后展示tips:
var app = new Vue({
el : '.app',
data : {
tipsOptions : {
title : 'tip'
}
}
methods:{
// 監(jiān)聽(tīng)從組件內(nèi)傳遞出來(lái)的事件
yes(args){
// console.log( args );
alert( JSON.stringify(args) );
},
// 顯示tips
showtips(){
// console.log( this.$refs );
this.$refs.dialog.showTips();
}
}
})
4. 總結(jié)
在這個(gè)簡(jiǎn)單的tips組件里,我們實(shí)現(xiàn)了用props傳遞參數(shù),用$emit向外傳遞參數(shù),用slot插槽來(lái)定制內(nèi)容。
需要注意的是:組件props是單向綁定,即父組件的屬性發(fā)生變化時(shí),子組件能接收到相應(yīng)的數(shù)據(jù)變化,但是反過(guò)來(lái)就會(huì)出錯(cuò)。即不能在子組件中修改props傳過(guò)來(lái)的數(shù)據(jù),來(lái)達(dá)到修改父組件屬性的目的。這是為了防止子組件無(wú)意修改了父組件的狀態(tài)。
另外,每次父組件更新時(shí),子組件的所有 prop 都會(huì)更新為最新值。這意味著你不應(yīng)該在子組件內(nèi)部改變 prop。如果你這么做了,Vue 會(huì)在控制臺(tái)給出警告。如果真的需要在子組件里進(jìn)行修改,可以用這兩種方法應(yīng)對(duì):
定義一個(gè)局部變量,并用 prop 的值初始化它:
props: ['initialCounter'],
data: function () {
return { counter: this.initialCounter }
}
定義一個(gè)計(jì)算屬性,處理 prop 的值并返回。
props: ['size'],
computed: {
normalizedSize: function () {
return this.size.trim().toLowerCase()
}
}
當(dāng)然,這只是單頁(yè)面中組件的實(shí)現(xiàn),更復(fù)雜的組件后續(xù)我們也會(huì)實(shí)現(xiàn)。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
iview實(shí)現(xiàn)select tree樹(shù)形下拉框的示例代碼
這篇文章主要介紹了iview實(shí)現(xiàn)select tree樹(shù)形下拉框的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12
vue基于v-charts封裝雙向條形圖的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue基于v-charts封裝雙向條形圖的實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-12-12
詳解用vue.js和laravel實(shí)現(xiàn)微信授權(quán)登陸
本篇文章主要介紹了詳解用vue.js和laravel實(shí)現(xiàn)微信授權(quán)登陸,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-06-06
Vue使用extend動(dòng)態(tài)創(chuàng)建組件的實(shí)現(xiàn)
本文主要介紹了Vue使用extend動(dòng)態(tài)創(chuàng)建組件的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-04-04
vue項(xiàng)目設(shè)置活性字體過(guò)程(自適應(yīng)字體大小)
這篇文章主要介紹了vue項(xiàng)目設(shè)置活性字體過(guò)程(自適應(yīng)字體大小),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
vue實(shí)現(xiàn)將數(shù)據(jù)存入vuex中以及從vuex中取出數(shù)據(jù)
今天小編就為大家分享一篇vue實(shí)現(xiàn)將數(shù)據(jù)存入vuex中以及從vuex中取出數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11
vue實(shí)現(xiàn)打印指定組件內(nèi)容的示例詳解
這篇文章主要和大家分享一下vue中打印指定組件內(nèi)容,多頁(yè)打印自動(dòng)適配紙張大小打印的方案,文中的示例代碼講解詳細(xì),需要的可以參考一下2024-03-03

