vue组件实现⽂字居中对齐的⽅法
继续学习Vue,这次是⼀个组件的制作过程
先让我们来看⼀下组件的预期效果
上图为公司⾃营的⼀个商城的某⼀部分截图,可以看到红框内部分的⽂字多⾏与单⾏是居中对齐的,我们现在要做的就是使⽤Vue把⾥边的⽂字模块制作成⼀个可以复⽤的组件。
⾸先我们先把css部分拿下来
css:
.
word-v-middle{
margin-bottom: 0;
font-size: 12px;
min-height: 31px;
display: flex;
align-items: center;
justify-content: center;
height: 31px;
margin-top: 5px;
color: #87878a;
white-space: normal;
}
.word-v-middle span{
text-align: left;
font-size: 10px;
text-overflow: -o-ellipsis-lastline;
overflow: hidden;
text-overflow: ellipsis;
display: -webkit-box;
-webkit-line-clamp: 2;
-webkit-box-orient: vertical;
}
上边就是组件的核⼼css,也就是使⽂字上下居中的css,接下来我们先把它封装成⼀个Vue组件
html部分
<p class="word-v-middle"><span>⽂字内容</span></p>
我们先把这部分注册成⼀个组件,这⾥使⽤的是组件的局部注册⽅法
var wordMiddle = {
template:'<p class="word-v-middle"><span>⽂字内容</span></p>',
};
之后实例化
html:
<div id="exp">
flex布局对齐方式 <word-v-middle></word-v-middle>
</div>
js:
components:{
'word-v-middle':wordMiddle
}
});
这样第⼀步就算完成了效果图如下
第⼆步我们来给组件绑定动态的数据,我们先在组件注册的时候添加⼀个props⽅法,让组件可以接受数据,之后使⽤data⽅法来为组件添加数据
var wordMiddle = {
template:'<p class="word-v-middle"><span>{{msg}}</span></p>',
props:['data'],
data:function(){
return {
msg:this.data
};
}
};
这样我们的组件就可以接收数据并把数据绑定到内容中,实例化时的代码也要对应的改变⼀下
html部分
<div id="exp">
<word-v-middle :data='aaa' ></word-v-middle>
</div>
js部分
new Vue({
el:"#exp",
data:{
aaa:'hello',
},
components:{
'word-v-middle':wordMiddle
}
})
到这⾥单个动态数据的组件以及完成了,但项⽬中⽤到这种对齐⽅式的⼀般都是多列的块结构,所以我们再写⼀个多列的例⼦,并使⽤循环绑定多个数据
css部分
#example2{
width: 100%;
overflow: hidden;
}
#example2 div{
float: left;
width: 25%;
}
html部分
<div id="example2">
<div v-for='aaa in sites'>
<word-v-middle :data='aaa' ></word-v-middle>
</div>
</div>
js部分
new Vue({
el:"#example2",
"洗发⽔洗发⽔洗发⽔",
"洗发⽔洗发⽔",
"洗发⽔洗发⽔洗发⽔洗发⽔洗发⽔",
"洗发⽔洗发⽔",
]
},
components:{
'word-v-middle':wordMiddle
}
})
效果如上图,上述代码中,css部分是为了让代码为并列的四列,html中使⽤v-for⽅法循环数据,在组建内通过:data='aaa'接收循环输出的数据,⽽数据的来源是⽗元素实例化中的data内的名为sites的数组,在实际项⽬中,把sites内的数据换成后台输出的数组就可以实现后台数据的绑定。
代码还有很多不⾜的地⽅,⽐如想要更改上下对齐的⾏数还要通过修改css修改,这篇⽂章仅作为学习Vue的⼩结,供⾃⼰以后复习学习使⽤,有什么问题希望⼤家指正。
以上就是本⽂的全部内容,希望对⼤家的学习有所帮助,也希望⼤家多多⽀持。
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论