首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

用 Gatsby 创建一个博客

它通过在构建时通过服务器端渲染将动态的 react 组件呈现为静态 HTML 内容。...这就是所谓的 frontmatter,而这部分内容可以供 React 组件使用(例如path,date,title等等)你可以添加其他的数据,因此,你可以自由地进行实验,找到必要的信息,以实现一个理想的博客系统...这个 React 组件将被呈现为静态 HTML 字符串,这将成为我们博客导航的基础。 在这一点上,有一种合理的混乱和魔法会发生,特别是在 props 属性注入的时候。...在这一点上,我们使用 React 组件和几个 GraphQL 查询创建了一个单页静态博客。然而,这不是一个博客!...你不知道,我们在 Gatsby 做到这一点有多容易,使用我们在博客模板中使用的类似策略,例如一个 React 组件和一个 GraphQL 查询。

2.5K30

JavaScript前端学习有哪些项目可以练习

01 使用React构建电影搜索应用 首先,可以使用React构建一个电影搜索应用。 你将学到什么内容: 构建这个应用时,你将使用相对较新的Hooks API来提升你的React技能。...04 使用Next.js构建电子商务购物车 你将学到什么: 在这个项目中,你将学习如何设置Next.js开发环境、创建新页面和组件、获取数据和样式并部署一个next应用程序。...技术栈和功能: Next.js 组件和页面 数据获取 样式 部署 SSR和SPA 教程:https://snipcart.com/blog/next-js-ecommerce-tutorial 05 使用...Nuxt.js构建完整的多语言博客网站 你将学到什么内容: 这个示例项目将教你从初始设置到最终部署,使用Nuxt.js构建完整网站的全过程。...06 使用Gatsby建立博客 你将学到什么内容: 在本教程中,你将学习如何利用Gatsby构建出色的博客,可以很好地用来撰写自己的文章,同时利用React和GraphQL的能力。

2.9K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    2021 年你应该尝试的 8 个 React 库

    1. react-select 一个厉害的,强大的表单下拉选择框的库 代表了一种开发功能强大的 react.js 组件的全新方式,这些组件在完全可定制的同时开箱即用。...突出的功能特性 灵活的数据处理方法,具有可定制的功能。 灵活结合 emotion 这个库(一个 css in js 的强大的库 ). 组件注入API,用于完全控制UI行为。...突出的功能 非常适合Trello(一个管理任务的工具)和Storify 等应用程序,其中拖动负责在应用程序的不同部分之间传输数据。 建立在HTML5拖放API之上。...使用 React构建快速、现代的应用程序和网站 突出的功能 以极低代价托管: Gatsby站点不需要服务器,因此您可以以服务器呈现站点的一小部分成本在CDN上托管整个站点。... ); } }; 7. react-virtualized 这提供了一个 React 组件来有效地呈现大列表和表格数据,由5个主要组件组成(Grid, List, Table,

    1.6K10

    React 18 最新进展:发布 Beta 版本,公开测试新特性

    此外,根据 2020 年堆栈溢出调查 ,React 是开发人员之间使用最多的前端开发框架。只有 jQuery 库领先于 Reactjs。...在标准的 React 应用程序中,如果动画在一个组件中工作,同时用户点击或输入其他 React 组件,如果用户键入或单击按钮,动画也会在 React 的上下文中呈现。...React 提供了最佳性能,因为它避免了不重要的重新渲染。它还阻止组件呈现半完成状态,同时在创建错误时更新单个状态变量。例如,在餐厅,服务员在选择第一道菜后不会跑到他的厨房,而是等待完成订单。...服务器会检索那些显示在 UI 上的相关数据。 服务器将整个应用程序呈现为 HTML 并迅速响应客户端响应。 客户端会运行不包括 HTML 的 javascript 包。...的最新版本支持 React 18 和并发特性: https ://nextjs.org/docs/advanced-features/react-18 Gatsby Gatsby 从 v3.7 开始支持

    5.2K20

    你的博客用不着什么JavaScript框架

    JavaScript 已准备就绪,可以运行——整个 DOM 通过 React 组件“被水化”(hydrated)。...这里就有些不对劲——Gatsby 需要你以 React 组件的形式再加载一次页面;在完成多出来的这一步之前,所有需要 JavaScript 的元素(例如按钮、菜单、自定义输入)实际上都不能交互。...从网站 /Web 应用的大致区别来看,React 是用于构建 Web 应用的,这种应用需要有响应用户输入或实时获取数据的交互式 UI;而博客只是一个网站而已。...如果你在开发关注可访问性的单页应用程序,那么你可能会试着使用 JavaScript 来模拟浏览器的行为。Gatsby 试图通过包含一个 RouteAnnouncer 组件来为你解决这个问题。...https://www.gatsbyjs.org/packages/gatsby-plugin-no-javascript/ 你可以继续编写 react 组件和 GraphQL,甚至可以使用 CSS-in-JS

    4.1K10

    9个不错的前端开源项目

    您将学到什么 在构建此应用程序时,您将使用相对较新的Hooks API来提高React技能。该示例项目利用了React组件,许多hook,一个外部API,当然还有一些CSS样式。...您将学到什么 在本教程中,您将学习如何利用Gatsby构建出色的博客,以便在使用React和GraphQL的同时编写自己的文章。...,但是使用Gatsby,您可以在使用React的同时创建高性能网站——这是一个了不起的组合。...8.用Gridsome建立博客 Gridsome是Vue的……好吧,我们已经在Next/Nuxt中有了它。 但是对于Gridsome和Gatsby也是如此。...两者都使用GraphQL作为数据层,但是Gridsome使用VueJS。这也是一个很棒的静态网站生成器,可帮助您创建出色的博客: ?

    7K30

    一杯茶的时间,上手 Gatsby 搭建个人博客

    且 VuePress 目前还是针对静态文档优化比较多,作为博客依然比较简陋。 这时 @unicar[8] 正好推荐了基于 React 的 Gatsby[9]。.../src/templates 目录下放渲染数据的模板组件,如渲染 Markdown 文章,在其它博客系统中一般叫 layout。 /src/components 一般放其它共用的组件。...一般使用时只需要知道集合里每个项目的数据在 edges.node 中,同时通过 GraphiQL 浏览其它可以使用的数据。...Netlify CMS 的优点是开源免费,文章跟项目源码在一起,界面可以高度自定义,甚至可以自行扩充 React 组件,基本满足简单的博客编写需求。.../src/templates/blog-post.js 组件里,接收 pageContext props,就可以使用上面传入的数据了。

    3.2K20

    进击的JAMStack

    除了Markdown文件之外,JAMStack的静态数据源还可以是其它的东西,例如我们后面说到的Gatsby(JAMStack的一种实现)就允许通过插件的方式使用SQL直接读取数据库的内容来生成静态页面...为了给大家一个直观点的认识,我使用Gatsby搭建了一个简单的个人博客网站,网站的源代码可以在我的github仓库找到。 博客网站包含以下的功能: 博客列表页面:展示我发表的所有博客。...而对于那些数据经常发生变化的且不需要被搜索引擎收录的内容,它们会等到浏览器实际渲染对应组件的时候才通过APIs动态获取数据渲染出来。...components: 存放React组件用的。 images:存放博客的一些图片资源。...除此之外,由于Gatsby使用了React,所以它间接上接入了React的生态系统,这样开发者在开发Gatsby应用时就可以使用React生态的各种最佳实践和库实现了,这无疑可以大大提高我们的开发效率。

    2.9K30

    Gatsby还是Next.js,微言码道官网折腾事记

    其中Gatsby是基于React的静态网站生成框架,而 Cockpit cms则是存储网站内容的headless cms。 在最初的技术选型时,有考虑过hexo以及Wordpress两个选项。...Hexo -- 灵活性欠缺 没有使用hexo开源的博客系列的原因在于,hexo是一个专注于博客的产品,它的灵活性非常欠缺,而我对微言码道的构思中,远不止博客一个内容,还包括电子书,myddd开源项目,视频及音频多种形式...因此,在2020年底了解了Jamstack理念以及基于React的Gatsby技术后,决定基于Gatsby完全开发一个网站,这个在2021年元旦用了三天假期完成。...但问题是tailwind css全是原子化的css,没有成套的组件,这意味着诸如弹出框,进度条等可能要自己写或网上找第三方,这非常不方便。而MUI则有一整套组件可供使用。...所以,在尝试与权衡后,决定仍然使用了Gatsby+MUI的搭配。 永不停止的折腾 当然,微言码道的官网不会就折腾到此为止。对它的折腾仍然是永不停止的。 而我最迫切想折腾的其实是UI。

    2.3K30

    【Web架构】静态站点生成器概述 Gatsby ,Hugo 和Jekyll对比

    使用反应物.js使Gatsby能够受益于框架呈现DOM的方法,因为组件成为焦点。 Gatsby还支持GraphQL,这意味着数据查询变得更加容易。...由于有了GraphQL, Gatsby可以生成能够访问和利用来自不同来源的数据的站点。 您将在使用Gatsby时看到,生成的站点是进步的Web应用程序。...缺点 使用Gatsby需要大量的JavaScript、React和GraphQL知识。 网站生成速度可以更快,盖茨比有点慢。...不支持XML作为数据文件类型。但是,支持YAML、JSON和CSV。 变身怪医(Jekyll) Jekyll由Tom Preston-Werner在2009年发布,是这个列表中最老的静态站点生成器。...与Hugo一样,Jekyll也附带一个HTTP服务器,通常用于生成博客。它也经常用于生成投资组合。 虽然Jekyll对页面内容使用Markdown,但它也使用液体模板语言来处理页面。

    3.1K20

    2018 年前端开发五大趋势

    此外,Vue.js支持声明式呈现,异步DOM更新,双向数据绑定,以及严格遵守Web组件规范和HTML模板的简单集成。...与 Jekyll,Hugo 或 Hexo 等流行解决方案不同,这个静态生成器不使用模板,而是信赖于 Webpack 和 React 组件(注意 React 官网本身也是在 Gatsby 的帮助下编写的)...从1.0版本开始,Gatsby 使用了上面提到的 GraphQL。因此,在构建过程,它可以从多个 GraphQL API 中获得数据,然后使用它们创建一个完全静态的 React 客户端应用程序。...特别是,得亏 StoryBook,你可以在独立的环境中设计和策划应用程序外的 UI 组件,并且在创建新的 UI 组件时它会发生变化。...如前所述,React Storybook允许您在应用程序之外开发和测试UI组件,并允许团队中的其他开发人员继续使用它们。 也就是说,有时会加速界面开发的过程。

    2.9K40

    学习gatsby,从这里开始!

    使用场景 如果你有一堆用 Markdown 编辑的文章,想要发布到网上,又不想浪费时间在编辑排版上,那么用 Gatsby 生成一个博客网站,是一个非常不错的解决方案。...:通过 GraphQL 查询 GraphQL Data Layer 中的数据 展示数据:通过React 编写HTML页面,把数据展示出来。...--- 三、安装 Gatsby 并新建网站 Gatsby 是在 Node.js 的基础上建立,使用 Gatsby 之前必须先安装 Node.js 且版本 ≥ 12.13。...--- 4、head HTML中head部分的数据对于 SEO 极其重要,用 bolog 模板生成的 Gatsby 项目,已经生成了SEO组件(src/components/seo.js),直接使用,完成页面...使用了插件 react-helmet。 --- 七、部署 怎么部署发布gatsby项目? 第一步:有一个备案过的域名。可以在阿里云上进行域名注册和备案; 第二步:需要一个服务器。

    2.2K20

    如何利用机器学习和Gatsby.js创建假新闻网站​

    ,请查看最后的GitHub Gatsby.js 为了构建一个可以无限扩展且加载速度非常快的博客,我们需要一个能够构建和渲染静态资源的框架,这些静态资源可以很容易地部署在web服务器上。...在安装完成nodejs以后,使用以下命令: npm install -g gatsby-cli 在Gatsby CLI中有相当数量的命令,可以通过下面的命令行提示符了解更多关于它们的信息: gatsby...一个重要的插件是Gatsby -source-filesystem,它允许Gatsby从存储在本地文件系统中的文件中提取数据。...gatsby-node.js 此文件用于实现api。这些api可以使用GraphQL从数据层中获取数据。在处理程序化页面生成时,我们将更深入地研究这个文件的内容。...Gatsby构建在React之上,而React是一个JavaScript库,它使使用称为“组件”的构建块构建用户界面变得更加容易。

    4.5K60
    领券