滚动状态管理以及滚动条复原是困扰了我很久的问题,想必也有和我有同样感受的同学,比如首页跳详情页,以及各详情页滚动条的管理,让人感觉很难受,那么如何来简化它呢?那么就使用这款神奇的插件vue-rescroll吧,让你疯狂飙车,为所欲为。
用了指令就不可以用keep-alive来进行缓存,因为那样自定义指令里的钩子函数不会触发,自然指令就失效了,一般的滚动插件配合vuex,可以开启数据的局部缓存,就是在页面返回之后不再请求,当滚动条再次拉到vuex里保存的pageindex(后台接口给的页数参数)时再去继续请求。
对于每个list对应的点击之后进入的详情页如果也需要的保存滚动条的话,也是同样的方法,不过不需要缓存数据,因为没有下拉加载的这些操作。如果想做持久化记录的话,可以使用插件的localstorage模式,这样每次你进到对应的详情都会滚动到你的上次浏览的位置。
这里比较恶心的,就是tab切换,几个模块共用的是一个滚动条,一个页面滚动了,其他的都会受影响,当时写的时候有点被恶心到了,相信大部分同学应该深有同感,请设置插件的domType为tab,则不会受公用滚动条的影响了。
注意:vue3.0版本请前往这里,用法一样。
install
npm install vue-rescroll --save
use
全局注册/Global registration (main.js)
import VueRescroll from 'vue-rescroll'
Vue.use(VueRescroll);
局部注册/Partial registration (*.vue)
import { directive } from 'vue-rescroll';
directives: {
'rescroll': directive
}
*.vue
使用默认配置/use default config
<div v-rescroll="{name: 'A unique marker'}"></div>
key | require | value | type | discribe |
name | 是 | string | 用来保存滚动状态的key值 | |
type | 否 | 'default'/'window' | string | 滚动类型(局部,全局) |
storageMode | 否 | 'default'/'localstorage' | string | 滚动状态保存方式 |
domType | 否 | 'default'/'tab' | string | 是否为tab切换组件 |
<div
v-rescroll="{
name: `${id}-scroll`,
type: 'window',
storageMode: 'localstorage'
}"
></div>
github地址:https://github.com/Vitaminaq/vue-rescroll
实践项目:传送门
演示地址:传送门 (由于我这里只存放在当前实例上,所以刷新浏览器无效,请滑动到一定距离,进详情页,后退,或者直接在详情页查看)
有同学觉得这样实用又方便的话,欢迎star,欢迎讨论,无时不在。