内容简介:上一篇中,我们用GraphiQL测试了GraphQL的查询。今天,我们就要用这些查询来打造一个Index页面。打开/pages/index.js,之前我们加入了Link,现在要使用GraphQL来取得资料,你可以参考/templates/post.js,两者很类似,差别在于,post是取得单篇文章资料,而index是取得多篇文章资料:
上一篇中,我们用GraphiQL测试了GraphQL的查询。今天,我们就要用这些查询来打造一个Index页面。
视频教学连结
加入GraphQL
打开/pages/index.js,之前我们加入了Link,现在要使用GraphQL来取得资料,你可以参考/templates/post.js,两者很类似,差别在于,post是取得单篇文章资料,而index是取得多篇文章资料:
export const pageQuery = graphql`
query IndexQuery {
allMarkdownRemark(limit: 10) {
edges {
node {
id
frontmatter {
title
path
}
}
}
}
}
`
其中id是自动产生的,用于Link连结,因为每个component都需要一个唯一的Key。
接着就可以将GraphQL取得的数据交给IndexPage使用,完全的index.js程式如下:
import React from 'react'
import { Link } from 'gatsby'
import Layout from '../components/layout'
const IndexPage = ({data}) => (
<Layout>
<h1>Hi guys</h1>
<p>Welcome to your new Gatsby site.</p>
<p>Now go build something great.</p>
<Link to="/page-2/">Go to page 2</Link>
<Link to="/page-3/">Go to page NEW</Link>
<h2>Index</h2>
{data.allMarkdownRemark.edges.map(post => (
<Link
key={post.node.id}
to={post.node.frontmatter.path}>
{post.node.frontmatter.title}
</Link>
))}
</Layout>
)
export const pageQuery = graphql`
query IndexQuery {
allMarkdownRemark(limit: 10) {
edges {
node {
id
frontmatter {
title
path
}
}
}
}
}
`
export default IndexPage
执行 gatsby develop 之后,便能在index页面看到那两篇文章的连结。
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
SOA & Web 2.0 -- 新商业语言
(美)Sandy Carter / 袁月杨、麻丽莉 / 清华大学出版社 / 2007 / 29.80元
在《SOA&Web 2.0:新商业语言》中,Sandy Calter示范了将企业解构为“组件化”业务模式的方法,然后用相互连接的、可重复的并且能快速、轻松、经济地适应各种变化的IT服务来支持该模式。这些技术将帮助IT专家和业务经理达到崭新的运营水平,以开展着眼于市场的创新,这才是最重要的。总而言之,企业必须实现灵活应对。直到最近,技术都一直阻碍着这些目标的实现。正是由于面向服务架构(SOA)、We......一起来看看 《SOA & Web 2.0 -- 新商业语言》 这本书的介绍吧!