{"id":4206,"date":"2019-05-06T13:49:30","date_gmt":"2019-05-06T04:49:30","guid":{"rendered":"https:\/\/greentown.tokyo\/?p=4206"},"modified":"2019-05-06T13:57:01","modified_gmt":"2019-05-06T04:57:01","slug":"react-state","status":"publish","type":"post","link":"https:\/\/greentown.tokyo\/?p=4206","title":{"rendered":"React - State"},"content":{"rendered":"<p>GW\u6700\u7d42\u65e5\u3067\u3059\u3002GO\u3067\u304d\u306a\u304b\u3063\u305f\u3002\u3002<\/p>\n<p>\u4eca\u65e5\u3082\u3053\u3061\u3089\u3002<\/p>\n<p><a href=\"https:\/\/oukayuka.booth.pm\/items\/1312652\">https:\/\/oukayuka.booth.pm\/items\/1312652<\/a><\/p>\n<p><a href=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/b58a45d3559cc75109305d27be6d5ea8.png\"><img decoding=\"async\" class=\"alignnone size-medium wp-image-4130\" src=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/b58a45d3559cc75109305d27be6d5ea8-300x300.png\" alt=\"\" width=\"300\" height=\"300\" srcset=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/b58a45d3559cc75109305d27be6d5ea8-300x300.png 300w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/b58a45d3559cc75109305d27be6d5ea8-150x150.png 150w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/b58a45d3559cc75109305d27be6d5ea8-768x766.png 768w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/b58a45d3559cc75109305d27be6d5ea8-100x100.png 100w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/b58a45d3559cc75109305d27be6d5ea8-400x400.png 400w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/b58a45d3559cc75109305d27be6d5ea8-60x60.png 60w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/b58a45d3559cc75109305d27be6d5ea8.png 1012w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>\u67f4\u54b2\u5148\u751f\u3067\u3059\u3002<\/p>\n<p>\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4f5c\u308b<\/p>\n<pre class=\"theme:dark-terminal lang:default decode:true \">$ npx create-react-app counter-test --typescript<\/pre>\n<p>&nbsp;<\/p>\n<h2>Local State<\/h2>\n<ul>\n<li>\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u304c\u5185\u90e8\u306b\u6301\u3064\u72b6\u614b\u306e\u3053\u3068<\/li>\n<\/ul>\n<p>\u672c\u306e\u30b5\u30f3\u30d7\u30eb\u3060\u3051\u3069\uff08GitHub\u306e\u65b9\u306f\u898b\u3066\u306a\u3044\u301c\uff09<\/p>\n<p>import { Button, Card, Statistic } from &#8216;semantic-ui-react&#8217;;<\/p>\n<p>\u3053\u308c\u3060\u3051\u3058\u3083\u3001\u753b\u9762\u304c\u88c5\u98fe\u3055\u308c\u306a\u304f\u3066<\/p>\n<pre class=\"theme:dark-terminal lang:default decode:true \">$ yarn add semantic-ui-css<\/pre>\n<p>\u3053\u308c\u3082\u5fc5\u8981\u3060\u3063\u305f\u3002\u3053\u308c\u5165\u308c\u305f\u3089\u88c5\u98fe\u3055\u308c\u305f\u3002<\/p>\n<p><a href=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/55d395f5de7665ec7b088790324acd5f.png\"><img decoding=\"async\" class=\"alignnone size-medium wp-image-4214\" src=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/55d395f5de7665ec7b088790324acd5f-300x173.png\" alt=\"\" width=\"300\" height=\"173\" srcset=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/55d395f5de7665ec7b088790324acd5f-300x173.png 300w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/55d395f5de7665ec7b088790324acd5f.png 618w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>import\u306f<\/p>\n<pre class=\"lang:js decode:true \">import { Button, Card, Statistic } from 'semantic-ui-react';\r\nimport 'semantic-ui-css\/semantic.min.css';\r\n<\/pre>\n<p>\u3053\u3046\u3002<\/p>\n<p>&nbsp;<\/p>\n<h6>this.State<\/h6>\n<pre class=\"lang:js decode:true \">  constructor(props: {}) {\r\n    super(props);\r\n    \/\/ this.state \u3053\u3053\u5927\u4e8b\r\n    \/\/ \u521d\u671f\u5316\u3057\u3066\u3044\u308b\r\n    this.state = { count:0 };\r\n  }<\/pre>\n<h6><\/h6>\n<h6>setState()<\/h6>\n<ul>\n<li>\u300csetState = hoge\u300dState \u3092\u8a2d\u5b9a\u3059\u308b\u3002<span style=\"color: #ff0000;\"><strong>\u5024\u3092\u56fa\u5b9a\u3057\u305f\u3044\u3068\u304d\u306b\u4f7f\u3046\u3002<\/strong><\/span><\/li>\n<li>\u300c(hogeState, props) =&gt; newState\u300dState\u3068Props\u3092\u5f15\u6570\u3067\u53d7\u3051\u53d6\u308a\u65b0\u3057\u3044State\u3092\u8fd4\u3059\u95a2\u6570\u3002<span style=\"color: #ff0000;\"><strong>\u52d5\u7684\u306b\u5909\u66f4\u3057\u305f\u3044\u5834\u5408\u306b\u4f7f\u3046\u3002<\/strong><\/span><\/li>\n<\/ul>\n<p>\u52d5\u7684\u306b\u5909\u66f4\u3057\u305f\u3044\u5834\u5408<\/p>\n<pre class=\"lang:js decode:true\">  increment() {\r\n    \/\/ this.state\u306b\u5024\u3092\u5165\u308c\u308b\u3053\u3068\u306f\u3067\u304d\u306a\u3044\r\n    \/\/ this.state\u3067\u53c2\u7167\u306f\u3067\u304d\u308b\r\n    this.setState(prevState =&gt; ({\r\n      count: prevState.count + 1,\r\n    }));\r\n  }<\/pre>\n<p>\u2191 Props\u306f\u7701\u7565\u3057\u3066\u3044\u308b\u3002<\/p>\n<p>&nbsp;<\/p>\n<h6>\u89aa\u306e\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306e\u4e2d\u8eab\u3092\u5909\u3048\u305f\u3044\u3068\u304d<\/h6>\n<ul>\n<li>\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306f<strong><span style=\"color: #ff0000;\">\u5358\u65b9\u5411\u30c7\u30fc\u30bf\u30d5\u30ed\u30fc<\/span><\/strong><\/li>\n<li>React\u3067\u306f<strong><span style=\"color: #ff0000;\">\u30c7\u30fc\u30bf\u306f\u5fc5\u305a\u89aa\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u304b\u3089\u5b50\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3078\u4e00\u65b9\u5411<\/span><\/strong><\/li>\n<li><span style=\"color: #ff0000;\"><strong>\u4e0b\u306e\u968e\u5c64\u304b\u3089\u4e0a\u306e\u968e\u5c64\u306b\u30c7\u30fc\u30bf\u306e\u5909\u66f4\u3092\u53cd\u6620\u3059\u308b\u3053\u3068\u306f\u3067\u304d\u306a\u3044<\/strong><\/span><\/li>\n<\/ul>\n<p>\u4e0b\u306e\u968e\u5c64\u304b\u3089\u4e0a\u306e\u968e\u5c64\u306b\u30c7\u30fc\u30bf\u306e\u5909\u66f4\u3092\u53cd\u6620\u3059\u308b\u3053\u3068\u306f\u3067\u304d\u306a\u3044\u3051\u3069\u3001<strong><span style=\"color: #ff0000;\">\u89aa\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u304c\u81ea\u8eab\u306e\u72b6\u614b\u3092\u5909\u66f4\u3059\u308b\u95a2\u6570\u3092\u5b50\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306b\u6e21\u3057\u3066\u5909\u66f4\u3059\u308b\u3068\u3044\u3046\u3084\u308a\u65b9\u304c\u3042\u308b<\/span><\/strong><\/p>\n<pre class=\"lang:js decode:true\">  &lt;Button color=\"blue\" onClick={() =&gt; this.increment()}&gt; \r\n    +1\r\n  &lt;\/Button&gt;\r\n<\/pre>\n<p>\u300c() =&gt; this.increment() \u300dLacalState\u306e\u5024\u3092\uff11\u52a0\u7b97\u3059\u308b\u95a2\u6570\u3092\u3001\u5b50\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u306bProps\u3067\u6e21\u3057\u3066\u3001\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u5185\u90e8\u306eClick\u30a4\u30d9\u30f3\u30c8\u306b\u4ed5\u8fbc\u3093\u3067\u4e0a\u306e\u968e\u5c64\u306e\u95a2\u6570\u3092\u767a\u706b\u3055\u305b\u308b\u3063\u3066\u3053\u3068\u304c\u3067\u304d\u308b\u3002<\/p>\n<p>&nbsp;<\/p>\n<h6>this\u6319\u52d5\u306e\u78ba\u8a8d<\/h6>\n<pre class=\"lang:js decode:true\">  &lt;Button color=\"blue\" onClick={() =&gt; this.increment()}&gt;<\/pre>\n<p>\u2193<\/p>\n<pre class=\"lang:js decode:true \">  &lt;Button color=\"blue\" onClick={this.increment}&gt;\r\n<\/pre>\n<p><a href=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/dc620d1d8bb9bea8527f3c6391bd41e2.png\"><img decoding=\"async\" class=\"alignnone wp-image-4218 size-full\" src=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/dc620d1d8bb9bea8527f3c6391bd41e2.png\" alt=\"\" width=\"1088\" height=\"670\" srcset=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/dc620d1d8bb9bea8527f3c6391bd41e2.png 1088w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/dc620d1d8bb9bea8527f3c6391bd41e2-300x185.png 300w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/dc620d1d8bb9bea8527f3c6391bd41e2-768x473.png 768w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/dc620d1d8bb9bea8527f3c6391bd41e2-1024x631.png 1024w\" sizes=\"(max-width: 1088px) 100vw, 1088px\" \/><\/a><\/p>\n<p>this.setState \u306a\u3093\u3066\u306a\u3044\u3088\u3068\u8a00\u308f\u308c\u308b\u3002<\/p>\n<p>\u2193 \u95a2\u6570\u5b9a\u7fa9\u3067\u66f8\u3044\u3066\u3044\u308b\u304b\u3089 this.setState \u306a\u3044\u3063\u3066\u8a00\u308f\u308c\u308b\uff08\u95a2\u6570\u3067\u304b\u304f\u3068this\u306f\u5b9f\u884c\u6642\u306e\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306b\u306a\u308b\u304b\u3089\uff09<\/p>\n<pre class=\"lang:js decode:true\">  increment() {\r\n    this.setState(prevState =&gt; ({\r\n      count: prevState.count + 1,\r\n    }));\r\n  }<\/pre>\n<p>\u2193 \u00a0\u30a2\u30ed\u30fc\u95a2\u6570\u306b\u66f8\u304d\u63db\u3048\u308b<\/p>\n<pre class=\"lang:less decode:true\">  increment = () =&gt; {\r\n    this.setState(prevState =&gt; ({\r\n      count: prevState.count + 1,\r\n    }));\r\n  }<\/pre>\n<h6><\/h6>\n<h6>SyntheticEvent\u578b\u3067\u5b9a\u7fa9\u3059\u308b<\/h6>\n<p><a href=\"https:\/\/ja.reactjs.org\/docs\/events.html\">\u516c\u5f0f\u30da\u30fc\u30b8<\/a><\/p>\n<p><a href=\"https:\/\/udomomo.hatenablog.com\/entry\/2017\/10\/14\/125704\">\u3061\u3087\u3063\u3068\u308f\u304b\u308a\u3084\u3059\u3044\u304b\u3082\uff08\u53e4\u3044\u3051\u3069\uff09<\/a><\/p>\n<pre class=\"lang:js decode:true \">  decrement() {\r\n    this.setState(prevState =&gt; ({\r\n      count: prevState.count - 1,\r\n    }));\r\n  }<\/pre>\n<p>\u2193<\/p>\n<pre class=\"lang:default decode:true \">  decrement = (e: SyntheticEvent) =&gt; {\r\n    e.preventDefault();\r\n    this.setState(prevState =&gt; ({\r\n      count: prevState.count - 1,\r\n    }));\r\n  }<\/pre>\n<p>\u30e1\u30bd\u30c3\u30c8\u5185\u90e8\u3067\u64cd\u4f5c\u3059\u308b\u3068\u304d\u306b\u3001\u30a4\u30d9\u30f3\u30c8\u30cf\u30f3\u30c9\u30e9\u306e\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3092\u5f15\u6570\u3068\u3057\u3066\u53d7\u3051\u53d6\u308c\u308b\u3002<\/p>\n<p><a href=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3d6e42f371b58f9933ec946712e4067b.png\"><img decoding=\"async\" class=\"alignnone wp-image-4220 size-full\" src=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3d6e42f371b58f9933ec946712e4067b.png\" alt=\"\" width=\"1162\" height=\"572\" srcset=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3d6e42f371b58f9933ec946712e4067b.png 1162w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3d6e42f371b58f9933ec946712e4067b-300x148.png 300w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3d6e42f371b58f9933ec946712e4067b-768x378.png 768w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3d6e42f371b58f9933ec946712e4067b-1024x504.png 1024w\" sizes=\"(max-width: 1162px) 100vw, 1162px\" \/><\/a><\/p>\n<p>\u30a8\u30e9\u30fc\u306b\u306a\u3063\u305f<\/p>\n<p><a href=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3bead599722f0513816128074fae1f28.png\"><img decoding=\"async\" class=\"alignnone wp-image-4221 size-full\" src=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3bead599722f0513816128074fae1f28.png\" alt=\"\" width=\"994\" height=\"318\" srcset=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3bead599722f0513816128074fae1f28.png 994w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3bead599722f0513816128074fae1f28-300x96.png 300w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/3bead599722f0513816128074fae1f28-768x246.png 768w\" sizes=\"(max-width: 994px) 100vw, 994px\" \/><\/a><\/p>\n<pre class=\"lang:js decode:true \">  &lt;Button color=\"pink\" onClick={() =&gt; this.decrement()}&gt;<\/pre>\n<p>\u2193<\/p>\n<pre class=\"lang:js decode:true \">  &lt;Button color=\"pink\" onClick={this.decrement}&gt;<\/pre>\n<p><a href=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/11b6e44110ab2c6d27fb7436a9534675.png\"><img decoding=\"async\" class=\"alignnone wp-image-4222 size-medium\" src=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/11b6e44110ab2c6d27fb7436a9534675-e1557118058947-300x170.png\" alt=\"\" width=\"300\" height=\"170\" srcset=\"https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/11b6e44110ab2c6d27fb7436a9534675-e1557118058947-300x170.png 300w, https:\/\/greentown.tokyo\/wp-content\/uploads\/2019\/05\/11b6e44110ab2c6d27fb7436a9534675-e1557118058947.png 596w\" sizes=\"(max-width: 300px) 100vw, 300px\" \/><\/a><\/p>\n<p>&nbsp;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>GW\u6700\u7d42\u65e5\u3067\u3059\u3002GO\u3067\u304d\u306a\u304b\u3063\u305f\u3002\u3002 \u4eca\u65e5\u3082\u3053\u3061\u3089\u3002 https:\/\/oukayuka.booth.pm\/items\/1312652 \u67f4\u54b2\u5148\u751f\u3067\u3059\u3002 \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u4f5c\u308b $ npx create-rea &#8230; <\/p>\n","protected":false},"author":1,"featured_media":4130,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[97],"tags":[],"class_list":["post-4206","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-react"],"_links":{"self":[{"href":"https:\/\/greentown.tokyo\/index.php?rest_route=\/wp\/v2\/posts\/4206"}],"collection":[{"href":"https:\/\/greentown.tokyo\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/greentown.tokyo\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/greentown.tokyo\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/greentown.tokyo\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=4206"}],"version-history":[{"count":13,"href":"https:\/\/greentown.tokyo\/index.php?rest_route=\/wp\/v2\/posts\/4206\/revisions"}],"predecessor-version":[{"id":4225,"href":"https:\/\/greentown.tokyo\/index.php?rest_route=\/wp\/v2\/posts\/4206\/revisions\/4225"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/greentown.tokyo\/index.php?rest_route=\/wp\/v2\/media\/4130"}],"wp:attachment":[{"href":"https:\/\/greentown.tokyo\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=4206"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/greentown.tokyo\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=4206"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/greentown.tokyo\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=4206"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}