{"id":1128,"date":"2024-04-19T15:03:39","date_gmt":"2024-04-19T06:03:39","guid":{"rendered":"https:\/\/shinke1987.net\/?p=1128"},"modified":"2024-04-19T15:03:40","modified_gmt":"2024-04-19T06:03:40","slug":"react%e9%96%8b%e7%99%ba%e7%92%b0%e5%a2%83%e3%81%abtailwindcss%e7%ad%89%e3%82%92%e3%82%a4%e3%83%b3%e3%82%b9%e3%83%88%e3%83%bc%e3%83%ab","status":"publish","type":"post","link":"https:\/\/shinke1987.net\/?p=1128","title":{"rendered":"React\u958b\u767a\u74b0\u5883\u306btailwindcss\u7b49\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb"},"content":{"rendered":"\n<h2 id=\"toc0\" class=\"wp-block-heading\">\u76ee\u7684<\/h2>\n\n\n\n<p>\u4e0b\u8a18\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3001\u52d5\u4f5c\u78ba\u8a8d\u3092\u884c\u3046\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><a href=\"https:\/\/tailwindcss.com\/\" target=\"_blank\" rel=\"noreferrer noopener\">tailwindcss<\/a><\/li>\n\n\n\n<li><a href=\"https:\/\/daisyui.com\/\" target=\"_blank\" rel=\"noreferrer noopener\">daisyUI<\/a><\/li>\n\n\n\n<li><a href=\"https:\/\/iconify.design\/\" target=\"_blank\" rel=\"noreferrer noopener\">iconify<\/a><\/li>\n<\/ul>\n\n\n\n<h2 id=\"toc1\" class=\"wp-block-heading\">\u524d\u63d0<\/h2>\n\n\n\n<p><a href=\"https:\/\/shinke1987.net\/?p=1123\" data-type=\"post\" data-id=\"1123\">Vite + React\u958b\u767a\u74b0\u5883\u3092Docker\u30b3\u30f3\u30c6\u30ca\u3067\u69cb\u7bc9<\/a>\u306b\u3066\u74b0\u5883\u3092\u69cb\u7bc9\u3057\u3066\u3044\u308b\u3053\u3068\u3002<\/p>\n\n\n\n<p>\u4e0b\u8a18\u30b3\u30de\u30f3\u30c9\u3067node-react\u30b3\u30f3\u30c6\u30ca\u5185\u3078\u5165\u3063\u3066\u4f5c\u696d\u3059\u308b\u3002<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: bash; title: ; notranslate\" title=\"\">\n% docker container exec -it node-react \/bin\/bash\n<\/pre><\/div>\n\n\n<h2 id=\"toc2\" class=\"wp-block-heading\">tailwindcss<\/h2>\n\n\n\n<h3 id=\"toc3\" class=\"wp-block-heading\">\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/h3>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: bash; title: ; notranslate\" title=\"\">\n$ npm install -D tailwindcss postcss autoprefixer\n$ npx tailwindcss init -p\n<\/pre><\/div>\n\n\n<h3 id=\"toc4\" class=\"wp-block-heading\">tailwind.config.js \u306e\u7de8\u96c6<\/h3>\n\n\n\n<p>\u4e0b\u8a18\u5185\u5bb9\u306e\u3088\u3046\u306b\u7de8\u96c6\u3059\u308b\u3002<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\n\/** @type {import(&#039;tailwindcss&#039;).Config} *\/\nexport default {\n  content: &#x5B;\n    &quot;.\/src\/*.tsx&quot;,\n  ],\n  theme: {\n    extend: {},\n  },\n  plugins: &#x5B;],\n}\n<\/pre><\/div>\n\n\n<h3 id=\"toc5\" class=\"wp-block-heading\">src\/App.tsx \u306e\u7de8\u96c6<\/h3>\n\n\n\n<p>\u4e0b\u8a18\u5185\u5bb9\u306e\u3088\u3046\u306b\u7de8\u96c6\u3059\u308b\u3002<br>\uff08\u30c7\u30d5\u30a9\u30eb\u30c8\u306e\u8868\u793a\u5185\u5bb9\u3092\u30b3\u30e1\u30f3\u30c8\u30a2\u30a6\u30c8\u3084\u524a\u9664\u3057\u3066\u3001h1\u30bf\u30b0\u306btailwindcss\u306e\u30af\u30e9\u30b9\u3092\u6307\u5b9a\u3057\u305f\u3060\u3051\uff09<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\nfunction App() {\n  return (\n    &lt;&gt;\n        &lt;h1 className=&quot;bg-red-500&quot;&gt;\u3042\u3044\u3046\u3048\u304a&lt;\/h1&gt;\n    &lt;\/&gt;\n  )\n}\n\nexport default App\n<\/pre><\/div>\n\n\n<h3 id=\"toc6\" class=\"wp-block-heading\">src\/index.css \u306e\u7de8\u96c6<\/h3>\n\n\n\n<p>\u4e0b\u8a18\u5185\u5bb9\u306e\u3088\u3046\u306b\u7de8\u96c6\u3059\u308b\u3002<br>\uff08\u30c7\u30d5\u30a9\u30eb\u30c8\u306eCSS\u3092\u30b3\u30e1\u30f3\u30c8\u30a2\u30a6\u30c8\u3084\u524a\u9664\u3092\u3057\u3066\u3001tailwindcss\u7528\u306e3\u884c\u3092\u8ffd\u52a0\u3057\u305f\u3060\u3051\uff09<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\n@tailwind base;\n@tailwind components;\n@tailwind utilities;\n<\/pre><\/div>\n\n\n<h3 id=\"toc7\" class=\"wp-block-heading\">tailwindcss \u306e\u52d5\u4f5c\u78ba\u8a8d<\/h3>\n\n\n\n<p>\u958b\u767a\u7528\u30b5\u30fc\u30d0\u3092\u8d77\u52d5\u3057\u3001Web\u30d6\u30e9\u30a6\u30b6\u3067\u30a2\u30af\u30bb\u30b9\u3057\u3066\u3001<\/p>\n\n\n\n<p>\u300c\u3042\u3044\u3046\u3048\u304a\u300d\u306e\u80cc\u666f\u8272\u304c\u8d64\u306b\u306a\u3063\u3066\u3044\u308c\u3070\u826f\u3044\u3002<\/p>\n\n\n\n<h2 id=\"toc8\" class=\"wp-block-heading\">daisyUI<\/h2>\n\n\n\n<h3 id=\"toc9\" class=\"wp-block-heading\">\u524d\u63d0<\/h3>\n\n\n\n<p>\u4e0a\u8a18\u306etailwindcss\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u6e08\u307f\u3002<\/p>\n\n\n\n<h3 id=\"toc10\" class=\"wp-block-heading\">\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/h3>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: bash; title: ; notranslate\" title=\"\">\n$ npm install -D daisyui@latest\n<\/pre><\/div>\n\n\n<h3 id=\"toc11\" class=\"wp-block-heading\">tailwind.config.js \u306e\u7de8\u96c6<\/h3>\n\n\n\n<p>\u4e0b\u8a18\u5185\u5bb9\u306e\u3088\u3046\u306b\u7de8\u96c6\u3059\u308b\u3002<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\n\/** @type {import(&#039;tailwindcss&#039;).Config} *\/\nexport default {\n  content: &#x5B;\n    &quot;.\/src\/*.tsx&quot;,\n  ],\n  theme: {\n    extend: {},\n  },\n  plugins: &#x5B;\n    \/\/ daisyUI\n    require(&quot;daisyui&quot;),\n  ],\n}\n<\/pre><\/div>\n\n\n<h3 id=\"toc12\" class=\"wp-block-heading\">src\/App.tsx \u306e\u7de8\u96c6<\/h3>\n\n\n\n<p>\u4e0b\u8a18\u5185\u5bb9\u306e\u3088\u3046\u306b\u7de8\u96c6\u3059\u308b\u3002<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\nfunction App() {\n  return (\n      &lt;&gt;\n          &lt;h1 className=&quot;bg-red-500&quot;&gt;\u3042\u3044\u3046\u3048\u304a&lt;\/h1&gt;\n          &lt;button className=&quot;btn btn-primary&quot;&gt;primary&lt;\/button&gt;&lt;br\/&gt;\n      &lt;\/&gt;\n  )\n}\n\nexport default App\n<\/pre><\/div>\n\n\n<h3 id=\"toc13\" class=\"wp-block-heading\">daisyUI \u306e\u52d5\u4f5c\u78ba\u8a8d<\/h3>\n\n\n\n<p>\u958b\u767a\u7528\u30b5\u30fc\u30d0\u3092\u8d77\u52d5\u3057\u3001Web\u30d6\u30e9\u30a6\u30b6\u3067\u30a2\u30af\u30bb\u30b9\u3057\u3066\u3001<\/p>\n\n\n\n<p>\u300c\u3042\u3044\u3046\u3048\u304a\u300d\u306e\u4e0b\u306bdaisyUI\u306e\u30dc\u30bf\u30f3\u304c\u8868\u793a\u3055\u308c\u308c\u3070\u826f\u3044\u3002<\/p>\n\n\n\n<h2 id=\"toc14\" class=\"wp-block-heading\">iconify<\/h2>\n\n\n\n<h3 id=\"toc15\" class=\"wp-block-heading\">\u524d\u63d0<\/h3>\n\n\n\n<p>\u4e0a\u8a18\u306edaisyUI\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u6e08\u307f\u3002<\/p>\n\n\n\n<h3 id=\"toc16\" class=\"wp-block-heading\">\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb<\/h3>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: bash; title: ; notranslate\" title=\"\">\n# npm install -D @iconify\/tailwind\n\n\/\/ \u52d5\u4f5c\u78ba\u8a8d\u7528\u306e\u30a2\u30a4\u30b3\u30f3\u30bb\u30c3\u30c8\u306e\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3002\n# npm install -D @iconify-json\/material-symbols\n<\/pre><\/div>\n\n\n<h3 id=\"toc17\" class=\"wp-block-heading\">\u30a2\u30a4\u30b3\u30f3\u30bb\u30c3\u30c8\u306e\u88dc\u8db3<\/h3>\n\n\n\n<p>\u30a2\u30a4\u30b3\u30f3\u30bb\u30c3\u30c8\u3092\u78ba\u8a8d\u3059\u308b\u306b\u306f\u6b21\u306e\u30b5\u30a4\u30c8\u3067\u597d\u307f\u306e\u30a2\u30a4\u30b3\u30f3\u3092\u542b\u3080\u30a2\u30a4\u30b3\u30f3\u30bb\u30c3\u30c8\u3092\u78ba\u8a8d\u3059\u308b\u3002<\/p>\n\n\n\n<p><a href=\"https:\/\/icon-sets.iconify.design\" target=\"_blank\" rel=\"noreferrer noopener\">https:\/\/icon-sets.iconify.design<\/a><\/p>\n\n\n\n<p>\u6b21\u306eGitHub\u30da\u30fc\u30b8\u3067\u3001\u6307\u5b9a\u3057\u305f\u3044\u30a2\u30a4\u30b3\u30f3\u30bb\u30c3\u30c8\u306eprefix\u306e\u5024\u3092\u78ba\u8a8d\u3059\u308b\u3002<\/p>\n\n\n\n<p><a href=\"https:\/\/github.com\/iconify\/icon-sets\/tree\/master\/json\" target=\"_blank\" rel=\"noreferrer noopener\">https:\/\/github.com\/iconify\/icon-sets\/tree\/master\/json<\/a><\/p>\n\n\n\n<p>\u78ba\u8a8d\u3057\u305fprefix\u306e\u5024\u304c\u300cabc\u300d\u3060\u3068\u3057\u305f\u3089\u3001\u6b21\u306e\u30b3\u30de\u30f3\u30c9\u3067\u30a2\u30a4\u30b3\u30f3\u30bb\u30c3\u30c8\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u3002<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: bash; title: ; notranslate\" title=\"\">\n# npm install -D @iconify-json\/abc\n<\/pre><\/div>\n\n\n<h3 id=\"toc18\" class=\"wp-block-heading\">tailwind.config.js \u306e\u7de8\u96c6<\/h3>\n\n\n\n<p>\u4e0b\u8a18\u5185\u5bb9\u306e\u3088\u3046\u306b\u7de8\u96c6\u3059\u308b\u3002<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\nconst { addDynamicIconSelectors } = require(&#039;@iconify\/tailwind&#039;);\n\n\/** @type {import(&#039;tailwindcss&#039;).Config} *\/\nexport default {\n  content: &#x5B;\n    &quot;.\/src\/*.tsx&quot;,\n  ],\n  theme: {\n    extend: {},\n  },\n  plugins: &#x5B;\n    \/\/ daisyUI\n    require(&quot;daisyui&quot;),\n    \/\/ Iconify\n    addDynamicIconSelectors(),\n  ],\n}\n<\/pre><\/div>\n\n\n<h3 id=\"toc19\" class=\"wp-block-heading\">src\/App.tsx \u306e\u7de8\u96c6<\/h3>\n\n\n\n<p>\u4e0b\u8a18\u5185\u5bb9\u306e\u3088\u3046\u306b\u7de8\u96c6\u3059\u308b\u3002<\/p>\n\n\n<div class=\"wp-block-syntaxhighlighter-code \"><pre class=\"brush: jscript; title: ; notranslate\" title=\"\">\nfunction App() {\n    return (\n        &lt;&gt;\n            &lt;h1 className=&quot;bg-red-500&quot;&gt;\u3042\u3044\u3046\u3048\u304a&lt;\/h1&gt;\n            &lt;button className=&quot;btn btn-primary&quot;&gt;primary&lt;\/button&gt;&lt;br\/&gt;\n            &lt;span className=&quot;icon-&#x5B;material-symbols--add-circle]&quot;&gt;&lt;\/span&gt;&lt;br\/&gt;\n        &lt;\/&gt;\n    )\n}\n\nexport default App\n<\/pre><\/div>\n\n\n<h3 id=\"toc20\" class=\"wp-block-heading\">iconify \u306e\u52d5\u4f5c\u78ba\u8a8d<\/h3>\n\n\n\n<p>\u958b\u767a\u7528\u30b5\u30fc\u30d0\u3092\u8d77\u52d5\u3057\u3001Web\u30d6\u30e9\u30a6\u30b6\u3067\u30a2\u30af\u30bb\u30b9\u3057\u3066\u3001<br>daisyUI\u306e\u30dc\u30bf\u30f3\u306e\u4e0b\u306b\u30d7\u30e9\u30b9\u304c\u4e38\u3067\u56f2\u307e\u308c\u305f\u30a2\u30a4\u30b3\u30f3\u304c\u8868\u793a\u3055\u308c\u308c\u3070\u826f\u3044\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u76ee\u7684 \u4e0b\u8a18\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3001\u52d5\u4f5c\u78ba\u8a8d\u3092\u884c\u3046\u3002 \u524d\u63d0 Vite + React\u958b\u767a\u74b0\u5883\u3092Docker\u30b3\u30f3\u30c6\u30ca\u3067\u69cb\u7bc9\u306b\u3066\u74b0\u5883\u3092\u69cb\u7bc9\u3057\u3066\u3044\u308b\u3053\u3068\u3002 \u4e0b\u8a18\u30b3\u30de\u30f3\u30c9\u3067node-react\u30b3\u30f3\u30c6\u30ca\u5185\u3078\u5165\u3063\u3066\u4f5c\u696d\u3059\u308b\u3002 ta [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[104],"tags":[108,109,105,107],"class_list":["post-1128","post","type-post","status-publish","format-standard","hentry","category-react","tag-daisyui","tag-iconify","tag-react","tag-tailwindcss"],"_links":{"self":[{"href":"https:\/\/shinke1987.net\/index.php?rest_route=\/wp\/v2\/posts\/1128","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/shinke1987.net\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/shinke1987.net\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/shinke1987.net\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/shinke1987.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1128"}],"version-history":[{"count":1,"href":"https:\/\/shinke1987.net\/index.php?rest_route=\/wp\/v2\/posts\/1128\/revisions"}],"predecessor-version":[{"id":1129,"href":"https:\/\/shinke1987.net\/index.php?rest_route=\/wp\/v2\/posts\/1128\/revisions\/1129"}],"wp:attachment":[{"href":"https:\/\/shinke1987.net\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1128"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/shinke1987.net\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1128"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/shinke1987.net\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1128"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}