- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
如果页面在渲染期间最终抛出,是否可以在构建期间跳过创建页面?
此页面是 created programmatically via gatsby-node createPage
并且可能来自页面查询(来自我们的 CMS)的数据不好导致它抛出。
我不想因为一个错误页面而停止构建,因此理想情况下不会创建该页面或将后备页面放入其位置(并且错误事件将被记录到 Sentry 或类似内容)。
关于如何实现这一目标的任何想法?
编辑:我没有足够澄清我的问题,所以我想添加一些关于我正在尝试解决的问题以及原因的上下文。
我试图捕获的错误发生在构建期间呈现页面的过程中。 发生此错误是因为我尝试呈现的组件假定了一些不正确的数据(但应该是正确的)。
例如,假设我正在为我网站上的所有产品创建许多页面。组件期望每个产品都有 imagesSizes
并调用 imagesSizes.split(',')
在渲染过程中。因为 imagesSizes
是 null
来自 page query ,整个组件抛出错误并中断构建。
就像@EliteRaceElephant 建议的那样,我试过使用 React Error Boundaries 不幸的是,它们不适用于 SSR(Gatsby 在构建时使用)。因此,即使我将组件包装在错误边界中,它最终仍会破坏构建。
最后一点,我上面给出的示例只是我遇到的数据错误并破坏构建的情况之一。
我想要实现的是一个简单的后备页面,用于何时 在构建期间渲染期间发生任何任意错误 .我的理想解决方案甚至可以让我throw
当我对数据做出的某些假设不正确时故意出现错误(因为我宁愿向用户发送错误页面,而不是向他们显示包含错误数据的页面)。
从历史上看,当我在 Gatsby 之外完成 SSR 时,我会简单地将整个调用包装到 ReactDOMServer.renderToString
在 try
catch
阻止并在 catch
中返回我的后备页面堵塞。
Gatsby 的等价物是什么?
最佳答案
您可以优雅地处理错误,因为 graphQL 查询作为 promise 返回。如果 promise 未能解决并继续构建您的页面,请处理引发的错误。
来自 Gatsby node API documentation :
const path = require(`path`)
exports.createPages = ({ graphql, actions }) => {
const { createPage } = actions
const blogPostTemplate = path.resolve(`src/templates/blog-post.js`)
return graphql(`
query loadPagesQuery ($limit: Int!) {
allMarkdownRemark(limit: $limit) {
edges {
node {
frontmatter {
slug
}
}
}
}
}
`, { limit: 1000 }).then(result => {
if (result.errors) {
throw result.errors
// ##### Handle your ERROR here #######
// send to sentry, try another query, etc
// or pass an empty result object so no pages are created but the build continues
}
result.data.allMarkdownRemark.edges.forEach(edge => {
createPage({
path: `${edge.node.frontmatter.slug}`,
component: blogPostTemplate,
context: {},
})
})
})
}
<PageTemplate>
<ErrorBoundary>
<YourContent />
</ErrorBoundary>
</Page Template>
<PageTemplate>
{ imagesSizes.split(',') // do whatever and break the build }
</PageTemplate>
render()
let pageThrows = false;
const imageSizesSplitCheck = (images) => {
try {
imagesSizes.split(',') // throw error
} catch {
pageThrows = true; // outside of the JSX flow you can still catch errors while serverside renddering
}
}
// more try catch functions
if (pageThrows) {
// render error page
} else {
// render default page
}
关于gatsby - 如果页面在渲染期间最终抛出,是否可以在构建期间跳过创建页面?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59900772/
我的算法- private static MyList skip$DeleteItem(MyList L , int M , int N){ MyList curr = L; MyLi
我正在 SWI-Prolog 下开发,但我的目标是 Erlog (https://github.com/rvirding/erlog)。我需要一种使用非标准 Prolog 语法的方法。 有没有办法
我正在尝试从应用程序下载一大堆文件。它的shell命令是“下载文件名”。 我有一个文本文件,其中包含必须下载的所有文件名。我要做的就是运行一个脚本/命令,以便在执行上述命令时 1.从文本文件中提取文件
我试图循环遍历所有用户的评论,但使用 if 语句查找特定值。问题是我的应用程序崩溃了,因为一些用户没有发表评论,因此我得到“无法读取‘收集’未定义的属性”。如何跳过 if 语句的未定义值?代码如下:
我们有按年份分区的索引,例如: items-2019 items-2020 考虑以下数据: POST items-2019/_doc { "@timestamp": "2019-01-01" }
我只是编写一个页面来按实体编号查看每个 ASCII 条目,我想知道是否有一种更简单/更干净的方法来跳过不需要的数字。 var x = new Ar
我希望能够普遍使用重复条目,但也能够跳过特定日期。例子: ** TODO swim practice SCHEDULED 但是,我提前知道 2013-12-25 不会有练习。但是,当我将项目标
如何跳过像这样的 for 循环的一次迭代: for (int i = 65; i <= 90; i++) { if (!(i == 73)) { uniq.add((char) i);
这个问题已经存在: Scanner issue when using nextLine after nextXXX [duplicate] 已关闭 9 年前。 ask=1; while(ask==1)
我在使用一个程序时遇到了一些麻烦,我应该允许用户在程序中输入任意数量的数字,直到他们不再想要为止。然后程序应该计算输入数字的平均值和最大值。我哪里做错了? import java.util.Scann
我有一个名为segments的 Sprite 数组,我想在每个循环中跳过segments的第一个元素。我目前正在这样做: var first = true; for each (var segment
我目前正在编写一个 for 循环来遍历包含 38 个元素的 2D。然而,其中一些元素为空,我希望 for 循环简单地跳过它们(因为在我正在解决的难题中,它们没有与它们相关的移动)。快速搜索表明,我可以
我想使用pre-commit处理我的 git 项目的 git hooks。但是,当我使用它时,git commit 命令不断跳过 unittest 执行: (smartexchange) trnboo
这个问题在这里已经有了答案: Does scanf() take '\n' as input leftover from previous scanf()? (1 个回答) 关闭 9 年前。 我正在
我正在迭代 csv 文件中的每一行,并仅选择/计算满足条件的行。但是,当连续出现错误时,它会停止循环。有没有办法告诉 python 跳过错误并移动到下一行?我使用了 try 函数但没有工作。我的代码是
感谢您提供的优秀示例,我试过了,它按我的预期工作。很高兴看到有人了解问题的本质。但是,我认为我应该用 Lift 标记问题,因为我正在使用 Lift 框架,这就是(仍然)发生这个问题的地方(尽管我仍然认
大家好,我正在编写一个算法来从 NodeTree 中删除具体分支(例如 DSF)。如果您选择 Node 的名称,算法将检查该 Node 是否是其他 Node 的父 Node ;如果是,它会获取该 No
附有代码和输出。 基本上它是第二次跳过我的输入。就像我启动代码一样,它让我输入一个选项,然后第二次跳过输入,直接转到开关的默认情况。 然后第三次它就会允许我输入。不明白为什么。 任何帮助将不胜感激。
我在 JavaScript 中有一个 for 循环,它会定期跳过间隔,但我无法确定原因。 console.log(parseInt($('input.num-to-add').val())); num
我正在 JasperSoft 中填写参数。在我的报告中我有参数:参数_1、参数_2、参数_3 int a; for (a = 0; a < headers.length; a++) {
我是一名优秀的程序员,十分优秀!