index.js
11.0 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
const notice = ''
const close = ''
Component({
externalClasses: ['wux-class'],
options: {
multipleSlots: true,
},
properties: {
icon: {
type: String,
value: notice,
},
content: {
type: String,
value: '',
},
mode: {
type: String,
value: '',
},
action: {
type: String,
value: close,
},
loop: {
type: Boolean,
value: false,
},
leading: {
type: Number,
value: 500,
},
trailing: {
type: Number,
value: 800,
},
speed: {
type: Number,
value: 25,
},
},
data: {
animatedWidth: 0,
overflowWidth: 0,
visible: true,
},
methods: {
clearMarqueeTimer() {
if (this.marqueeTimer) {
clearTimeout(this.marqueeTimer)
this.marqueeTimer = null
}
},
startAnimation() {
this.clearMarqueeTimer()
const { overflowWidth, loop, leading, trailing, speed } = this.data
const isLeading = this.data.animatedWidth === 0
const timeout = isLeading ? leading : speed
const animate = () => {
let animatedWidth = this.data.animatedWidth + 1
const isRoundOver = animatedWidth > overflowWidth
// 判断是否完成一次滚动
if (isRoundOver) {
if (!loop) {
return false
}
// 重置初始位置
animatedWidth = 0
}
// 判断是否等待一段时间后进行下一次滚动
if (isRoundOver && trailing) {
setTimeout(() => {
this.setData({
animatedWidth,
})
this.marqueeTimer = setTimeout(animate, speed)
}, trailing)
} else {
this.setData({
animatedWidth,
})
this.marqueeTimer = setTimeout(animate, speed)
}
}
if (this.data.overflowWidth !== 0) {
this.marqueeTimer = setTimeout(animate, timeout)
}
},
initAnimation() {
const query = wx.createSelectorQuery().in(this)
query.select('.wux-notice-bar__marquee-container').boundingClientRect()
query.select('.wux-notice-bar__marquee').boundingClientRect()
query.exec((rects) => {
if (rects.filter((n) => !n).length) {
return false
}
const [container, text] = rects
const overflowWidth = text.width - container.width
if (overflowWidth !== this.data.overflowWidth) {
this.setData({ overflowWidth }, this.startAnimation)
}
})
},
onAction() {
if (this.data.mode === 'closable') {
this.clearMarqueeTimer()
this.setData({
visible: false
})
}
this.triggerEvent('click')
},
onClick() {
this.triggerEvent('click')
},
},
ready() {
this.initAnimation()
},
detached() {
this.clearMarqueeTimer()
},
})