- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 React 和 Javascript 世界的 super 新手,并试图通过制作 Magic 8 Ball 应用程序投入到一些开发工作中。
我已经设置了两个页面:
游戏页面功能有效(使用下面 server.js 文件中的代码段),但我现在想将有关所问问题总数的信息从游戏页面传递到统计页面。
我的基本思路是:
我遇到过几种不同的方法,但只需要一些关于最佳方法的指导。
在实现之前,我已经整理了一些片段:
index.js 文件
<form className="question-input" method="POST" action="/">
<input type="text" ref="inputquestion" placeholder="Ask your question..."style={{ width: "300px", fontSize:18 }}/>
<button id="submitquestion" style={{ width: "100px", fontSize:17 }}>Shake Me!</button>
</form>
server.js 文件
server.post('/', (req,res) => {
console.log("Received request.")
const answers = [
"It is certain.",
"It is decidedly so.",
"Without a doubt.",
"Yes - definitely.",
"You may rely on it.",
"As I see it, yes.",
"Most likely.",
"Outlook good.",
"Yes.",
"Signs point to yes.",
"Reply hazy, try again.",
"Ask again later.",
"Better not tell you now.",
"Cannot predict now.",
"Concentrate and ask again.",
"Don't count on it.",
"My reply is no.",
"My sources say no.",
"Outlook not so good.",
"Very doubtful."
]
const number = Math.floor(Math.random()*20);
res.status(200).send(answers[number]);
stats.js 文件
class StatsPage extends Component {
render() {
return (
<main>
<Header />
<h1>Game Statistics</h1>
<p> Count: </p>
<style jsx>{`
h1 {
font-family:"Arial";
font-size:50px;
}`}
</style>
</main>
)
}
}
export default StatsPage;
我的问题是:每次在 index.js 文件中按下按钮(即提出问题)时,如何在 stats.js 中呈现一个计数器变量?我是否应该使用 saveToLocalStorage 来确保计数器保持保存状态并且不会在每次刷新应用程序时恢复为零?
此外 - 如果有人有任何改进意见,请分享!
感谢您的宝贵时间。
最佳答案
如果您不熟悉 React 和 JavaScript,最好为此使用 localStorage。这是该问题最简单的解决方案,并且是阻止您的应用程序状态在您刷新浏览器时消失的好方法。
像这样需要跨页面共享的状态可以保存在包装两个页面组件的父组件中。然后父组件可以将状态作为 props 传递给子组件。此父组件还可以在安装时尝试从 localStorage 加载其初始状态(请参阅 componentDidMount ),并处理将状态写入 localStorage。
Here's a jsfiddle用我上面描述的一个非常简单的例子。
作为旁注,我看到您使用 action
处理您的表单提交属性。这将导致您的页面刷新,这可能不是您想要的。 React 的处理方式是使用 onSubmit
<form>
的 Prop .查看examples in the React docs .
关于javascript - React - 当按钮增加并在另一个页面中呈现结果时增加计数器的最佳方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55132059/
我需要从 1024 增加 FD_SETSIZE 值至 4096 .我知道最好使用 poll()/epoll()但我想了解什么是优点/缺点。主要问题是:我要重新编译glibc吗? ?我读了几个线程,其中
已关闭。这个问题是 not reproducible or was caused by typos 。目前不接受答案。 这个问题是由拼写错误或无法再重现的问题引起的。虽然类似的问题可能是 on-top
我在 HTML 文件中有这样的内容: var value = 0; add(x){ x++; do
有没有办法在用户向上滚动时增加变量,并在用户使用 JavaScript 向下滚动时减少变量?变量没有最大值或最小值,如果能够调整灵敏度就好了。我不知道从哪里开始,感谢您的帮助! 编辑:没有滚动条,因为
我是 ios 新手,遇到以下问题。 我想根据表格 View 中元素的数量增加和减少表格 View 的高度大小。如果在输入时客户端在输出时给出 3 个或超过 3 个元素,我希望看到一个比默认行大 2 行
所以我一直在四处搜索,似乎大多数人认为以下列方式递增 indexPath 是正确的方法: NSIndexPath *newIndexPath = [NSIndexPath indexPathForRo
我有一个关于 connSupervisionTimeout 的问题。 我正在使用 CoreBluetooth 编写应用程序。我检查了连接参数和 connSupervisionTimeout = 720
我正在尝试根据页面的滚动位置更改元素的填充;当用户向下滚动页面时,填充会增加,而当他们向上滚动时,填充会减少。 我的主要问题是滚动不是很流畅,有时如果我滚动到页面顶部太快,每次元素的填充大小都不一样。
我正在尝试计算 18456 个基因的相关性度量,但编译器 (Dev C) 在将宏 GENE 或 INDEX 增加到 4000 到 5000 之间的值后退出或大。例如,它适用于: # define GE
我有一个带有 position: absolute 和 CSS3 过渡的圆形元素(a 元素)。在 hover 事件中,我想增加圆的高度和宽度,但我想在所有边上添加像素,而不仅仅是在左侧或右侧。 示例如
为了改善用户体验,我计划在我网站的所有页面(A-、A、A+)上增加/减少/重置字体大小 我面临的问题是页面上不同元素使用的字体大小不统一。有些是 14px,有些是 18px,有些是 12px,有些是
本文实例讲述了Yii框架数据库查询、增加、删除操作。分享给大家供大家参考,具体如下: Yii 数据库查询 模型代码: ?
sql替换语句,用该命令可以整批替换某字段的内容,也可以批量在原字段内容上加上或去掉字符。 命令总解:update 表的名称 set 此表要替换的字段名=REPLACE(此表要替换的字段名, '原
sql不常用函数总结以及事务,增加,删除触发器 distinct 删除重复行 declare @x 申明一个变量 convert(varchar(20),t
要增加我使用的最大可用内存: export SPARK_MEM=1 g 或者我可以使用 val conf = new SparkConf() .setMaster("loca
我正在尝试将文本(自定义文本按钮)放入 AppBar 的前导属性中。但是,当文本太长时,文本会变成多行 Scaffold( appBar: AppBar( centerTi
我正在使用最新版本的 NetBeans,我需要增加输出和菜单的字体大小(不是代码部分)。我试过: netbeans_default_options=".... --fontsize 16" 但是当我将
我必须将 180000 个点绘制到一个 EPS 文件中。 使用标准 gnuplot 输出尺寸点彼此太接近,这使得它们无法区分。有没有办法增加图像的宽度和高度? 最佳答案 是的。 set termina
我有一个带有输入字段的 twitter bootstrap 3 导航栏。我想增加输入字段的宽度。我已尝试设置 col 大小,但它不起作用。 html比较长,请引用bootply http://www.
我正在尝试增加 ggplot 标题中下划线的大小/宽度/厚度。我曾尝试使用大小、宽度和长度,但没有成功。 这是我所做的一个例子。 test <- tibble(x = 1:5, y = 1, z =
我是一名优秀的程序员,十分优秀!