APICloud AVM框架封装纵向滚动通知栏组件

使用APICloud AVM框架封装纵向滚动通知栏组件,该纵向滚动通知栏组件用于循环播放展示一组消息通知。

首先是组件整体布局,分为左右2部分,左边是标题或者图标,右边是消息的容器盒子。

接收来自父组件的消息列表数组,通过v-for循环把消息全部填充到容易盒子中。

<view class="easy-notice-bar_item-box">

<view :style="istop?'transition:all 0.5s;margin-top: -30px;':'transition:none;'">

<view class="easy-notice-bar_item" v-for="(item,index) in list" data-id={item.id} @click="clickNotice">

<text class="easy-notice-bar_item-title">{item.id}{item.content}</text>

</view>

</view>

</view>

通过overflow: hidden;隐藏掉去多余的通知消息,保证只能显示一条通知消息。 

.easy-notice-bar_item-box{

height: 20px;

overflow: hidden;

flex: 1;

margin: auto;

}

通过延时器,每一次会把数组的第一位加入到数组的最后一位,然后在删除第一位,这样显示出来的就是下一个,第二次运行时会继续把当前的第一个元素(也就是原来的第二个)加入数组的最后一位并删除当前这一位,让下一个元素变成第一位,以此类推。

noticeScroll(){

this.data.istop = true;

setTimeout(() => {

this.props.list.push(this.props.list[0]);

this.props.list.shift();

this.data.istop = false;

}, 5000);

},

通过一个定时器来实现循环

this.data.timer = setInterval(()=>this.noticeScroll(),2000);

在循环执行的时间间隔内,先完成容器盒子上移的效果,然后把消息数组的顺序继进行改变,是当前展示的消息通知放在第一的位置,然后取消过渡的动画,事件一到再次重复执行。

为了方便展示效果,我把容器盒子的overflow: hidden取消掉, 实际实现的效果是这样的。

 把容器盒子的overflow: hidden属性加上,就是完整的效果了

 组件文件

easy-notice-bar.stml

<template>

<view class="easy-notice-bar_container">

<view class="easy-notice-bar_ico-box">

<image class="easy-notice-bar_ico" src={ico} mode="widthFix"></image>

</view>

<view class="easy-notice-bar_item-box">

<view :style="istop?'transition:all 0.5s;margin-top: -30px;':'transition:none;'">

<view class="easy-notice-bar_item" v-for="(item,index) in list" data-id={item.id} @click="clickNotice">

<text class="easy-notice-bar_item-title">{item.id}{item.content}</text>

</view>

</view>

</view>

</view>

</template>

<script>

export default {

name: 'easy-notice-bar',

installed(){

//开始定时

this.data.timer = setInterval(()=>this.noticeScroll(),2000);

},

props:{

list:Array

},

data() {

return{

ico:'',

timer:null,

istop:false

}

},

methods: {

noticeScroll(){

this.data.istop = true;

setTimeout(() => {

this.props.list.push(this.props.list[0]);

this.props.list.shift();

this.data.istop = false;

}, 5000);

},

clickNotice(e){

let id = e.currentTarget.dataset.id;

this.fire('clickNotice',id);

}

}

}

</script>

<style>

.easy-notice-bar_container {

flex-flow: row nowrap;

justify-content: flex-start;

padding: 10px;

background-color: #f0f0f0f0;

}

.easy-notice-bar_ico-box{

margin: auto;

padding-right: 20px;

}

.easy-notice-bar_ico{

width: 20px;

height: 20px;

}

.easy-notice-bar_item-box{

height: 20px;

overflow: hidden;

flex: 1;

margin: auto;

}

.easy-notice-bar_item{

min-height: 30px;

}

.easy-notice-bar_item-title{

font-size: 16px;

color: #ff7037;

text-overflow: ellipsis;

    white-space: nowrap;

}

</style>

示例文件

demo-easy-notice-bar.stml

<template>

<view class="page">

<safe-area></safe-area>

<easy-notice-bar

:list="listData"

onclickNotice="showNotcie"

>

</easy-notice-bar>

</view>

</template>

<script>

import '../../components/easy-notice-bar.stml'

export default {

name: 'demo-easy-notice-bar',

apiready(){

},

data() {

return{

listData:[

{id:"1",content:"这是一个用于循环播放展示一组消息通知组件"},

{id:"2",content:"接社区通知,全员核酸检测时间调整为6:00-11:00,带来不便,敬请谅解。"},

{id:"3",content:"现摸排60岁~69岁(1953年~1962年出生)未接种疫苗的住户,请主动联系楼管,请大家一定跟自家老人确认,如不报备导致漏报,后果自负。收到请回复,如不回复,我们将视同您已收到,感谢配合。"},

{id:"4",content:"7月14日(明天)周四,开展全员核酸检测,时间:6:00~11:30,居家健康检测人员不要参加,已放暑假孩子在本小区检测。"}

]

}

},

methods: {

showNotcie(e){

// console.log(JSON.stringify(e));

api.toast({

location:'middle',

msg:'当前点击了的消息ID是'+e.detail

})

}

}

}

</script>

<style>

.page {

height: 100%;

padding-top: 100px;

}

</style>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值