Skip to content

Instantly share code, notes, and snippets.

@enkot
Last active August 2, 2019 10:26
Show Gist options
  • Save enkot/0c095e4c158a1b5be45e76f9764a4a08 to your computer and use it in GitHub Desktop.
Save enkot/0c095e4c158a1b5be45e76f9764a4a08 to your computer and use it in GitHub Desktop.
// ...
<script>
import {
value,
watch,
computed,
onMounted,
onUnmounted
} from 'vue-function-api'
import { fetchUserPosts } from '@/api'
export default {
setup(props) {
const pageOffset = value(0)
const isLoading = value(false)
const posts = value([])
const count = computed(() => posts.value.length)
const update = () => {
pageOffset.value = window.pageYOffset
}
onMounted(() => window.addEventListener('scroll', update))
onUnmounted(() => window.removeEventListener('scroll', update))
watch(
() => props.id,
async id => {
isLoading.value = true
posts.value = await fetchUserPosts(id)
isLoading.value = false
}
)
return {
isLoading,
pageOffset,
posts,
count
}
}
}
</script>
// ...
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment