AVM(Application-View-Model)前端组件化开发模式基于标准 Web Components 组件化思想,提供包含虚拟 DOM 和 Runtime 的编程框架 avm.js 以及多端统一编译工具,完全兼容 Web Components 标准,同时兼容 Vue 和 React 语法糖编写代码,编译工具将 Vue 和 React 相关语法糖编译转换为 avm.js 代码。
基于标准 Web Components 组件化思想,兼容 Vue / React 语法特性,通过一次编码,分别编译为 App、小程序代码,实现多端开发。
组件功能介绍用于循环播放展示一组消息通知。
首先是组件整体布局,分为左右 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>
复制代码
组件使用说明
具体在项目中的使用步骤是,第一步将压缩文件中的 easy-notice-bar.stml 文件拷贝到项目的 components 目录,通过阅读 readme.md 文档和查看 demo 示例文件 demo-easy-notice-bar.stml 在需要开发的 stml 文件中,引入组件文件,完成页面的开发。
文件目录
实际项目中需要的其它组件,可以自己尝试封装组件。
这是组件化开发的在线文档地址
评论