共计 4502 个字符,预计需要花费 12 分钟才能阅读完成。
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](http://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 文件中,引入组件文件,实现页面的开发。
文件目录
理论我的项目中须要的其它组件,能够本人尝试封装组件。
这是组件化开发的在线文档地址