import React, { Component } from 'react'
import PropTypes from 'prop-types'
import './index.scss'
const trail = {
linear : (t, b, c, d) => {
return c * t/d + b
},
easeIn : ( t, b, c, d ) => c * ( t /= d ) * t + b,
easeOut : ( t, b, c, d ) => -c *( t/=d )*( t - 2 ) + b,
easeInOut : ( t, b, c, d ) => {
if ( ( t/=d/2 ) < 1 ) return c/2 * t * t + b
return -c/2 * ( (--t) * (t-2) - 1 ) + b
}
}
class Back extends Component {
state = {
isShow: false
}
scrollTo = () => {
// const { y, duration, rate } = this.props
const y = 100, duration = 900, rate = 30
const start = this.getScrollTop()
let end = y
if(end < 0) {
end = 0
}
this.getStep(start, end, (step) => {
this.setScrollTop(step)
}, duration, rate)
}
getStep = (start, end, callback, duration, rate) => {
const diff = end - start
if(duration == 0 || diff == 0) {
callback && callback(end)
return
}
let count = duration / rate
let i = 0
let t = 0
this.props.onScrollStart()
const timer = window.setInterval(() => {
if(i < count - 1) {
t += rate
const value = trail.easeOut(t, start, diff, duration)
callback && callback(value)
i++
} else {
this.props.onScrollEnd()
callback && callback(end)
window.clearInterval(timer)
}
}, rate)
}
bindScroll = () => {
const scrollTop = this.getScrollTop()
if(scrollTop > this.props.offset){
this.setState({ isShow: true })
}else{
this.setState({ isShow: false })
}
}
setScrollTop = (y) => {
document.documentElement.scrollTop = y
document.body.scrollTop = y
}
getScrollTop = () => {
const scrollTop = document.documentElement.scrollTop || document.body.scrollTop
return scrollTop
}
componentDidMount(){
window.addEventListener('scroll', this.bindScroll)
}
componentWillUnmount() {
window.removeEventListener('scroll', this.bindScroll)
}
render() {
const { icon } = this.props
const { isShow } = this.state
return (
<div className="back" >
{ isShow &&
<div className="back-warp" onClick={this.scrollTo}>
{ icon && <div className="back-icon">{icon}</div>}
</div>
}
</div>
)
}
}
Back.porpTypes = {
icon: PropTypes.string,
offset: PropTypes.number,
onScrollStart: PropTypes.func,
onScrollEnd: PropTypes.func
}
Back.defaultProps = {
icon: '',
offset: 1000,
onScrollStart: () => {},
onScrollEnd: () => {}
}
export default Back
滚动到指定位置
©著作权归作者所有,转载或内容合作请联系作者
- 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
- 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
- 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
推荐阅读更多精彩内容
- 今天开发中遇到一个小问题: 需求:在UICollectionView在展示之前显示到具体的某一个Cell上 在vi...
- 两种监听页面滚动的方法 一、原生js通过window.onscroll监听 二、Jquery通过$(window)...
- 滚动监听 滚动到底部// 滚动到底if (scrollY == (v.getChildAt(0).getMeasu...