浪柱娱乐
您的当前位置:首页关于Vue组件实现tips的总结

关于Vue组件实现tips的总结

来源:浪柱娱乐
 本文主要介绍了详解Vue组件实现tips的总结,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧,希望能帮助到大家。

组件,顾名思义,就是把一个相对,而且会多次使用的功能抽象出来,成为一个组件!如果我们要把某个功能抽象为一个组件时,要做到这个组件对其他人来说是个黑盒子,他们不用关心里面是怎么实现的,只需要根据约定的接口调用即可!

我用一张图稍微总结了下Vue中组件的构成:

可以看到组件中包含的东西还是蛮多的,而且,还有很多的点没有列出来,这里面的每一个知识点能都展开讲很多。不过我们这里不讲原理,只讲使用。

我们以一个tips弹窗为例,来综合运用下组件的知识点。tips弹窗,几乎所有的框架或者类库,都会有弹窗这个组件,因为弹窗这个功能平时非常普遍,而且模块解耦度高!

1. 接口约定

我们这里实现的弹窗,能用到的知识点有:props, event, slot, ref等。这里我们也能看到各个知识点是怎么运用的。


2. modal组件的实现

tips组件相对来说实现的比较简单,仅用作提示用户的简单弹层。

模板:


<p class="tips" v-show="show" transition="fade">
 <p class="tips-close" @click="closeTips">x</p>
 <p class="tips-header">
 <slot name="header">
 <p class="title">{{tips.title}}</p>
 </slot>
 </p>
 <p class="tips-body">
 <slot name="body">
 <p class="notice">{{tips.text}}</p>
 </slot>
 </p>
 <p class="tips-footer">
 <a href="javascript:;" rel="external nofollow" rel="external nofollow" v-if="tips.showbtn" @click="yes" >{{tips.btnText}}</a>
 </p>
</p>

模板中将结构分成了三部分,标题、内容和操作区域。这里既可以使用props传递字符串,也可以使用slot进行定制。

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;
}

组件内的方法:


3. 调用tips组件

首先我们开始渲染组件:


<p 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">提示标题</h3>
 <p slot="body">
 <p>hello world</p>
 <p>wenzi</p>
 </p>
 </tips>
</p>

点击显示按钮后展示tips:


4. 总结

在这个简单的tips组件里,我们实现了用props传递参数,用$emit向外传递参数,用slot插槽来定制内容。

需要注意的是:组件props是单向绑定,即父组件的属性发生变化时,子组件能接收到相应的数据变化,但是反过来就会出错。即不能在子组件中修改props传过来的数据,来达到修改父组件属性的目的。这是为了防止子组件无意修改了父组件的状态。

另外,每次父组件更新时,子组件的所有 prop 都会更新为最新值。这意味着你不应该在子组件内部改变 prop。如果你这么做了,Vue 会在控制台给出警告。如果真的需要在子组件里进行修改,可以用这两种方法应对:

定义一个局部变量,并用 prop 的值初始化它:


定义一个计算属性,处理 prop 的值并返回。


当然,这只是单页面中组件的实现,更复杂的组件后续我们也会实现。

显示全文