You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
svelte/site/content/examples/20-miscellaneous/01-hacker-news/List.svelte

46 lines
739 B

<script>
import { beforeUpdate } from "svelte";
import Summary from "./Summary.svelte";
const PAGE_SIZE = 20;
export let page;
let items;
let offset;
$: fetch(`https://node-hnapi.herokuapp.com/news?page=${page}`)
.then(r => r.json())
.then(data => {
items = data;
offset = PAGE_SIZE * (page - 1);
window.scrollTo(0, 0);
});
</script>
<style>
a {
padding: 2em;
display: block;
}
.loading {
opacity: 0;
animation: 0.4s 0.8s forwards fade-in;
}
@keyframes fade-in {
from { opacity: 0; }
to { opacity: 1; }
}
</style>
{#if items}
{#each items as item, i}
<Summary {item} {i} {offset}/>
{/each}
<a href="#/top/{page + 1}">page {page + 1}</a>
{:else}
<p class="loading">loading...</p>
{/if}