看到一篇 Implementing an Infinite Scroll with Vue.js, 以为挺实用的就看了下, 顺便简单翻译了一下给须要的人参考.从这个项目中能够加深对Vue的生命周期的理解, 什么时候开始axios请求, 如何结合Vue使用原生js来写scroll事件等等, 我这里主要是对原文的重点提取和补充css
Vue
生命周期axios
简单用法moment.js
格式化日期scroll
事件首先建立一个简单的vue项目html
# vue init webpack-simple infinite-scroll-vuejs
而后安装项目所须要用的一些插件vue
# npm install axios moment
项目搭建完后, 跑起来看看webpack
# npm run dev
打开http://localhost:8080
无误后, 咱们开始修改代码, 先看看获取用户数据这块,ios
<script> import axios from 'axios' import moment from 'moment' export default { name: 'app', // 建立一个存放用户数据的数组 data() { return { persons: [] } }, methods: { // axios请求接口获取数据 getInitialUsers() { for (var i = 0; i < 5; i++) { axios.get(`https://randomuser.me/api/`).then(response => { this.persons.push(response.data.results[0]) }) } }, formatDate(date) { if (date) { return moment(String(date)).format('MM/DD/YYYY') } }, beforeMount() { // 在页面挂载前就发起请求 this.getInitialUsers() } } </script>
这里原做者也专门提醒, 彻底没有必要也不建议在加载页面的时候请求5次, 只是这个接口一次只能返回1条数据, 仅用于测试才这样作的. 固然我这里也能够经过Mock来模拟数据, 就不详细说了~
接下来来写模板结构和样式, 以下:git
<template> <div id="app"> <h1>Random User</h1> <div class="person" v-for="(person, index) in persons" :key="index"> <div class="left"> <img :src="person.picture.large" alt=""> </div> <div class="right"> <p>{{ person.name.first}} {{ person.name.last }}</p> <ul> <li> <strong>Birthday:</strong> {{ formatDate(person.dob)}} </li> <div class="text-capitalize"> <strong>Location:</strong> {{ person.location.city}}, {{ person.location.state }} </div> </ul> </div> </div> </div> </template> <style lang="scss"> .person { background: #ccc; border-radius: 2px; width: 20%; margin: 0 auto 15px auto; padding: 15px; img { width: 100%; height: auto; border-radius: 2px; } p:first-child { text-transform: capitalize; font-size: 2rem; font-weight: 900; } .text-capitalize { text-transform: capitalize; } } </style>
这样页面就能显示5我的的我的信息了.github
咱们接下来须要在methods
里面添加scroll()
来监听滚动, 而且这个事件是应该在mounted()
这个生命周期内的. 代码以下:web
<script> // ... methods: { // ... scroll(person) { let isLoading = false window.onscroll = () => { // 距离底部200px时加载一次 let bottomOfWindow = document.documentElement.offsetHeight - document.documentElement.scrollTop - window.innerHeight <= 200 if (bottomOfWindow && isLoading == false) { isLoading = true axios.get(`https://randomuser.me/api/`).then(response => { person.push(response.data.results[0]) isLoading = false }) } } } }, mounted() { this.scroll(this.persons) } } </script>
这段代码原文是有一点拼写错误的. 我这里修正了, 另外增长了距离底部即开始加载数据, 并进行截流.
保存好, 回到浏览器, 查看效果, 已经没有问题了~npm
滚动到页面底部无限加载的功能在Vue上实现其实和普通的页面开发差很少, 每次滚动加载未完成的状况下不会触发请求下一次, 每次请求push
到数组内, 经过<img :src="">
的数据绑定实现了懒加载(其实0 0我不太承认...), 看完是否是感受挺简单的.axios
最后, 我把这个也弄了一份在GitHub上面, 有须要的能够看看infinite-scroll-vuejs-demo~