- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试从 gatsby-browser.js
( gatsby browser API ) 中的 replaceRouterComponent
中运行一个 GraphQL 查询。然而,我可以从 Contentful 访问数据.
这可能不是最好的解决方案,任何有关我如何以其他方式实现的建议也将不胜感激。
问题来了-
在组件 TripAdvisor.js 内部,我将脚本安装在 componentDidMount
中,而 locationId
是基于 的数据>this.props.tripAdvisorId
从在 Contentful 中创建的个人 posts
中提取。每个 post
(属性)都有一个单独的 locationId
,当在脚本 src
中更改时,它会显示相关的评论。
componentDidMount () {
const tripadvisorLeft = document.createElement("script");
tripadvisorLeft.src = "https://www.jscache.com/wejs?wtype=selfserveprop&uniq=789&locationId=" + this.props.tripAdvisorId + "&lang=en_AU&rating=true&nreviews=0&writereviewlink=true&popIdx=true&iswide=true&border=false&display_version=2";
tripadvisorLeft.async = true;
document.body.appendChild(tripadvisorLeft);
const tripadvisorRight = document.createElement("script");
tripadvisorRight.src = "https://www.jscache.com/wejs?wtype=selfserveprop&uniq=998&locationId=" + this.props.tripAdvisorId + "&lang=en_AU&rating=false&nreviews=4&writereviewlink=false&popIdx=false&iswide=true&border=false&display_version=2";
tripadvisorRight.async = true;
document.body.appendChild(tripadvisorRight);
}
我在页面级别的 componentDidMount
中也有一个函数,用于重写上面 TripAdvisor 脚本中的数据。 TripAdvisor 脚本创建了一个名为 injectselfserveprop*** 的函数(其中 *** 是随机数)。没有这个,当使用 Link
/templates/properties/reviews.js
componentDidMount() {
Object.keys(window).forEach((key) => {
if (key.match(/^injectselfserveprop[0-9]+$/)) {
window[key]();
}
});
}
在 /templates/properties/reviews.js 的同一个文件中,我使用 shouldComponentUpdate
来返回 false
,因为它停止了 TripAdvisor 在使用 link
shouldComponentUpdate() {
return false;
}
现在,此解决方案的失败之处在于更改脚本 src
的 locationId
。如果我不需要为每个 post
更改 locationId
,它工作得很好。
当 link
到另一个具有不同 locationId
的 post
并且评论组件未更新时,它会失败。但是,然后链接
并返回到新评论。
您可以看到这种情况发生 here并按照这些步骤 -
完整站点有一个 GitHub 存储库 here .要查找的两个文件位于 /src/templates/properties/reviews.js
和 src/components/properties/TripAdvisor.js
现在我已经概述了我的问题,我认为最好的解决方案是在 gatsby-browser.js
中将 TripAdvisor 脚本包装在 replaceRouterComponent
中,并使用条件语句仅应用于通过 Link
直接访问 reviews.js
的页面。
但是,我找不到在 gatsby-browser.js
( gatsby browser API ) 中使用 tripAdvisorID
数据的解决方案。然而,我可以从 Contentful 访问数据 使用 GraphQL。
如果您有其他解决方案,请告诉我。
最佳答案
好吧,如果您的问题是更新组件,那么问题可能出在您处理副作用的方式上(TripAdvisor 中的 componentDidMount
获取)。
就我所见,你在 props 中收到的数据都很好,应该可以获取,但是有一个错误。 componentDidMount
将ONLY BE CALLED ONCE,这一次是组件第一次加载到页面中。所以你的 props 改变和你再次渲染并不重要,componentDidMount
中的代码 不会被再次调用。
您可以通过两种方式进行修复。而是在
中添加键 <TripAdvisor key={tripAdvisorId} name={name} starRating={starRating} location={location} tripAdvisorId={tripAdvisorId} * />
这种方式 react 将卸载以前的 TripAdvisor 并安装一个新的,从而再次调用 componentDidMount 方法......如果你必须重新安装所有东西只是为了来自 Prop 的不同数据,那可能会有点问题...... ..
我可以向您推荐第二种方式,这也是他们在 React Documentation. 中推荐的方式不要在 componentDidMount
中实现您的更改,而是在 componentDidUpdate(prevProps, prevState)
中执行它们(注意:您需要通过 this.props.tripAdvisorId 来保护您的提取!== prevProps.tripAdvisorId
否则你将进入无限循环)。
我认为这是您更新数据的问题,与 gatsby 无关...但如果问题仍然存在,请评论我,我可以进一步检查您遇到的 GraphQL 问题。
关于javascript - 将 GraphQL 数据拉入 gatsby-browser.js(或请提供更好的解决方案),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50206298/
我试图通过屏幕截图捕获带有突出显示的元素,但在屏幕截图中,该元素不带有突出显示。有谁知道解决办法吗?当我捕获文本时会出现突出显示:automatests@gmail.com 查看我的代码: Utili
大家好,我是编码的新手,我正在和一位老师一起上 Java 入门课,希望您已经了解一切。我必须对冰雹序列进行编码,它表示为: 选择一些正整数并将其命名为 n。如果 n 是偶数,则将其除以二。如果 n 是
如果存在名称相同的SCOM组,则尝试制作一个请求更多信息(组ID)的脚本: function myFunction { [CmdletBinding()] Param(
我有这张表: id | CUPNAME | FRENCHNAME 1 | 2 | null 2 | null | 4 我想从非空的 CUPNAME 和 FRENCHNAME 中提
我是 Collection View 的新手,想知道这是否是创建它们的最佳方式,我还想了解一些关于从哪里转到启用分页的详细 View 的建议。 #import "MarbleCollectionVie
好的,这是非常好的 jquery slider 。 http://srobbin.com/jquery-plugins/pageslide 我所做的是 http://mbu.mn/test 问题来了。
...有人可以解释一下区别吗? 我在命令提示符下输入的内容: sys.path.append('M:/PythonMods') import qrcode myqr = qrcode.make("ra
我不时在我的服务器上运行 bash 脚本,我正在尝试编写一个脚本来监视日志文件夹并在文件夹超出定义的容量时压缩日志文件。我知道有更好的方法来做我目前正在尝试做的事情,非常欢迎您提出建议。下面的脚本抛出
我是 Groovy & Grails 的新手,我觉得事情不必那么难看……那么我怎样才能让这段代码更好看呢? 这是一个 Grails Controller 类,去掉了一些无趣的部分。尽量不要太挂断我的
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 7年前关闭。 Improve this questi
在这个查询中,除了 5 个连接表之外,我试图使用第 6 个表“Days”将值与连接中的三个表进行比较。但它给了我错误,我不能在连接中使用子查询。 select a.ID, a.Name, a.AMT,
我不想通过 Xpath 提取,我想要更清晰的代码。谢谢我的世界兄弟 来自 Xpath,好的!! Assert.assertEquals("Digite um e-mail ou número de t
这个问题已经有答案了: Google Map is not loading due to inflate exception (3 个回答) 已关闭 9 年前。 我知道有很多关于此的帖子,但我就是无法
我的问题.. a.) 使用内存分配创建一个 float 组来存储 GPA 分数10名学生。为其分配值(您的选择) b.) 找出该数组中的最大 GPA。 c.) 将此数组的内容写入文件 alloc.tx
我最近要制作 Sequelize 。 我有 2 个表,data_track 和 car_detail。我想尝试关联那 2 个表,但它从未关联过。 总是返回错误SequelizeEagerLoading
我有一些代码在 LINQ 中根本无法工作的问题,但它确实可以作为一个简单的 for..each 工作。任何解释和解决方案将不胜感激。 我有 3 个类,Users、User 和 UserPermissi
我正在设计我的第一个大型数据库,并想检查我是否可以提供表关系。 我正在设计一个网络应用程序,其中 用户可以在团队中玩游戏 每个游戏都有其类别 用户为游戏创建他们的团队并选择他们的团队类别 每个游戏都启
我很抱歉成为一个 CSS 菜鸟,希望有人能指导我正确的方向。 我需要帮助的网页可以在 http://filefx.com 找到 当您点击该页面时,您会注意到“选择文件”图标和“上传文件”图标不在同一行
我已经尝试过这个我在网上找到的演示代码练习并创建了这个 slider ,使用滚动条更容易获得它,因为它们已经是为此制作的脚本。现在我正在尝试修改此脚本及其 css,以将滚动条更改为左右两侧的箭头。我已
最近我对 CSS 很感兴趣。学习不同的东西。 我正在尝试像这样放置三个 div: http://i.stack.imgur.com/miN9G.png 我得到的: http://i.stack.img
我是一名优秀的程序员,十分优秀!