.sweepstake {
color: orange;
font-size: 24px;
font-weight: bold;
}

先来一个简单的

        <style>
.sweepstake {
color: orange;
font-size: 24px;
font-weight: bold;
}
</style> <script src="http://files.cnblogs.com/rubylouvre/avalon2014123.js"> </script>
<script>
var id
var vm = avalon.define({
$id: "test",
number: 100,
click: function() {
if (!id) {
id = setInterval(function() {
vm.number--
if (vm.number === 0) {
clearInterval(id)
id = null
}
}, 100)
}
}
})
</script> <div ms-controller="test">
<p class="sweepstake">{{number}}
</p>
<p><button type="button" ms-click="click">xxx</button></p>
</div>

var id
var vm = avalon.define({
$id: "test",
number: 100,
click: function() {
if (!id) {
id = setInterval(function() {
vm.number--
if (vm.number === 0) {
clearInterval(id)
id = null
}
}, 100)
}
}
})

{{number}}

xxx

再来一个复杂的有动画效果的柏青哥

<!DOCTYPE html>
<html>
<head>
<title>TODO supply a title</title>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width">
<script src="avalon.js">

</script>
<style>
.pachinko{
height: 40px;
width: 245px;
border: 5px solid black;
padding: 15px;
}
.pachinko .cell{
margin-right: 20px;
position: relative;
float: left;
border: 1px solid blueviolet;
width: 30px;
height: 40px;
overflow:hidden
}
.pachinko .cell.last{
margin-right: 0px;
}
.pachinko .cell .top{
position: absolute;
display: block;
top: 0px;
left: 0px;
text-align: center;
line-height: 40px;
width: 30px;
height: 40px;
}
.pachinko .cell .middle{
position: absolute;
display: block;
top: -40px;
left: 0px;
text-align: center;
line-height: 40px;
width: 30px;
height: 40px;
}
</style>
<script>

var id
var vm = avalon.define({
$id: "test",
array: [{number: 9}, {number: 9}, {number: 9}, {number: 9}, {number: 9}],
subtractOne: function(a) {
var a = a - 1
if (a < 0) {
a = 9
}
return a
},
distance: 0, //0-40 每个格子都高40px, 那么top的移动距离也是40, 其初始值为0
start: function() {
for (var i = 0, n = vm.array.length; i < n; i++) {
vm.array[i].number = Math.floor(Math.random() * 10)
}
if (!id) {
id = setInterval(function() {
vm.distance += 5
if (vm.distance > 50) {
vm.distance = 0
for (var i = 0, n = vm.array.length; i

.pachinko{
height: 40px;
width: 245px;
border: 5px solid black;
padding: 15px;
}
.pachinko .cell{
margin-right: 20px;
position: relative;
float: left;
border: 1px solid blueviolet;
width: 30px;
height: 40px;
overflow:hidden
}
.pachinko .cell.last{
margin-right: 0px;
}
.pachinko .cell .top{
position: absolute;
display: block;
top: 0px;
left: 0px;
text-align: center;
line-height: 40px;
width: 30px;
height: 40px;
}
.pachinko .cell .middle{
position: absolute;
display: block;
top: -40px;
left: 0px;
text-align: center;
line-height: 40px;
width: 30px;
height: 40px;
}

var id
var vm = avalon.define({
$id: "test2",
array: [{number: 9}, {number: 9}, {number: 9}, {number: 9}, {number: 9}],
subtractOne: function(a) {
var a = a - 1
if (a 50) {
vm.distance = 0
for (var i = 0, n = vm.array.length; i 9){
vm.array[i].number = 0
}
}
}
}, 20)
}

},
stop: function() {
if (id) {
clearInterval(id)
id = null
}
vm.distance = 0
}
})

{{subtractOne(el.number)}}
{{el.number}}

startstop

简单说一下原理,表面上只有五个格子,其实为了出现更好的过渡效果,总共有10个格子。其中有五个位于另五个的上方,然后动画就是改变格子的top样式值就行了。对应avalon,就是改vm中的distance属性值, 它会在定时器里面快速地递加,一直加到50就归零。而格子里面的值,在第一次点击时进行第一次洗牌,然后每当格子快跌出可视区后再递增一,当它大于10时,就变回0。这样不断变啊变,直到用户点了stop按钮就才得结果。

avalon做的抽奖效果的更多相关文章

  1. bootstrap中table页面做省市区级联效果(级联库见前面级联编辑)(非select下拉框)

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  2. CSS3做动物走路效果

    CSS3做动物走路效果 采用的CSS3切换序列帧做 核心代码如下<pre>.game .role { width: 60px; height: 86px; position: absolu ...

  3. 2021年都要过去啦,你还在用Excel做数据可视化效果吗?

    2021年都要过去啦,你还在用Excel做数据可视化效果吗?古语有云,"工欲善其事,必先利其器",没有专业的工具,前期准备的再好也是白搭.现在运用数据可视化工具于经营活动中的企业是 ...

  4. css做旋转相册效果

    css做旋转相册效果 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> &l ...

  5. 简单JS旋转实现转盘抽奖效果

    闲来没事,做了一个模拟转盘抽奖的HTML&JS的效果: 可以在设置的时候,选择几个区域,并且可以填写指针将要停止的区域 比如,我选择了"区域2",结果就是这样 具体可以见下 ...

  6. 利用background-attachment做视差滚动效果

    视差滚动(Parallax Scrolling)是指让多层背景以不同的速度移动,形成立体的运动效果,带来非常出色的视觉体验.作为今年网页设计的热点趋势,越来越多的网站应用了这项技术. 不明白的可以先看 ...

  7. Deeplink做不出效果,那是你不会玩!

    最近魔Sir听一些有些同学说之前用过Deeplink,但效果并没有想象中的那么好,在了解了小伙伴的使用场景后,魔Sir觉得有必要出这么篇东西告诉大家,Deeplink效果差,那是因为你不会玩! 对于已 ...

  8. 最近比较迷flash professional cc 做PPT,做一个flash做动态打字效果的教程

    想做一个flash打字效果.网上的方法要不是太繁琐,要不然就是各种遗漏.在这边做一个行之有效的flash做打字效果教程. 首先我用的是最新版本的flash professional cc .但是应该和 ...

  9. Flash 用FLASH遮罩效果做图片切换效果

    本教程是关于FLASH应用遮罩效果制作好看的图片切换效果.该教程选用FLASH遮罩中最简单的一种作为例子,当然你可以用自己的想象力来做出更多更好的图片动画.希望本教程能带你带来帮助. 让我们先看看效果 ...

随机推荐

  1. PHP接收表单(GET/POST)时,表单名中的点变成了下划线怎么办?

    如果开发中发现,从表单中传递上来的表单名称后端接不到值,不要惊慌,很有可能是表单名称中带有特殊字符(.和空格) PHP接收参数时,发现表单名中如果是 句号(.)或者空格( ),会被转换成下划线(_) ...

  2. 更新上篇文章 调用三级目录文章内容 dede频道页实现三级栏目嵌套调用文章

    原文:http://www.wuaie.com/?p=66 源码改写 $typeid = $row['id']; if((class_exists('PartView'))) { $pv = new ...

  3. VS起始页不显示最近使用的项目解决方案

    前段时间换了一家公司,做ASP.NET开发,让我郁闷的是VS的起始页总是不显示最近使用项目,起先没在意,后来觉得越来越不方便了,然后本着内事不决问百度,外事不决问谷歌的态度,我就百了下~,结果还真遇到 ...

  4. 管道和FIFO 一

    管道和FIFO   管道(pipe)       管道在Unix及Linux进程间通信是最基础的,很容易理解.管道就像一个自来水管,一端注入水,一端放出水,水只能在一个方向上流动,而不能双向流动.管道 ...

  5. Hadoop专业解决方案-第12章 为Hadoop应用构建企业级的安全解决方案

    一.前言: 非常感谢Hadoop专业解决方案群:313702010,兄弟们的大力支持,在此说一声辛苦了,春节期间,项目进度有所延迟,不过元宵节以后大家已经步入正轨, 目前第12章 为Hadoop应用构 ...

  6. appium API记录

    1,滑动屏幕 driver.swipe(start_x=720, start_y=1000, end_x=0, end_y=1000,duration=1000) ,注意开始坐标不能是最大值 2,获取 ...

  7. 云-AWS-百科:AWS

    ylbtech-云-AWS-百科:AWS Amazon Web Services AWS是亚马逊公司旗下云计算服务平台,为全世界范围内的客户提供云解决方案.AWS面向用户提供包括弹性计算.存储.数据库 ...

  8. Ubuntu16.04或18.04上安装QQ微信迅雷

    0. 写在前面 没办法,公司的电脑是Windows的,windows下面开发实在太恶心人,并且开发中需要编译golang和C++的程序,于是开始了Linux的折腾之路. 如果你只是想用Linux环境开 ...

  9. 【Unix网络编程】 chapter5 TCP客户,服务器程序实例

    chapter5 5.1 概述 5.2 TCP回射服务器程序:main函数 int main(int argc, char **argv) { int listenfd,connfd; pid_t c ...

  10. 洛谷P1415 拆分数列

    题目背景 [为了响应党中央勤节俭.反铺张的精神,题目背景描述故事部分略去^-^] 题目描述 给出一列数字,需要你添加任意多个逗号将其拆成若干个严格递增的数.如果有多组解,则输出使得最后一个数最小的同时 ...