{"id":24128,"date":"2021-12-09T09:00:55","date_gmt":"2021-12-09T00:00:55","guid":{"rendered":"https:\/\/www.agent-grow.com\/self20percent\/?p=24128"},"modified":"2021-12-02T10:16:08","modified_gmt":"2021-12-02T01:16:08","slug":"rail7%e3%81%a7%e3%81%aeimportmap%e3%82%92%e7%b4%b9%e4%bb%8b%e3%80%90agent-grow-advent-calendar-2021%ef%bc%9a9%e6%97%a5%e7%9b%ae%e3%80%91","status":"publish","type":"post","link":"https:\/\/www.agent-grow.com\/self20percent\/2021\/12\/09\/rail7%e3%81%a7%e3%81%aeimportmap%e3%82%92%e7%b4%b9%e4%bb%8b%e3%80%90agent-grow-advent-calendar-2021%ef%bc%9a9%e6%97%a5%e7%9b%ae%e3%80%91\/","title":{"rendered":"Rail7\u3067\u306eimportmap\u3092\u7d39\u4ecb\u3010Agent Grow Advent Calendar 2021\uff1a9\u65e5\u76ee\u3011"},"content":{"rendered":"<p>\u3053\u306e\u8a18\u4e8b\u306f <a href=\"https:\/\/adventar.org\/calendars\/6791\">Agent Grow Advent Calendar 2021<\/a> 9 \u65e5\u76ee\u306e\u8a18\u4e8b\u3067\u3059\u3002<\/p>\n<p>\u521d\u3081\u307e\u3057\u3066\u3002\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u30b0\u30ed\u30fc\u3067Ruby\u6848\u4ef6\u306b\u53c2\u753b\u3055\u305b\u3066\u3044\u305f\u3060\u3044\u3066\u3044\u308bKasano\u3068\u7533\u3057\u307e\u3059\u3002<\/p>\n<p>\u4ee5\u4e0b\u30c4\u30a4\u30fc\u30c8\u3088\u308a\u30012021\u5e7411\u6708\u6642\u70b9\u3067\u306f\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u30b0\u30ed\u30fc\u3067\u306fRuby(Ruby on Rails)\u3092\u3084\u3063\u3066\u3044\u308b\u4eba\u306f\u5c11\u6570\u6d3e\u3067\u3059\u304c\u3001\u4eca\u56de\u306f\u6562\u3048\u3066Rails7\u306e\u65b0\u6a5f\u80fd\u3092\u53d6\u308a\u4e0a\u3052\u3066\u307f\u305f\u3044\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<blockquote class=\"twitter-tweet\">\n<p dir=\"ltr\" lang=\"ja\">\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u30b0\u30ed\u30fc\u306e\u6280\u8853\u8005\u5272\u5408\u3001\u8d85\u6700\u65b0\u7248\u306e\u4f5c\u6210\u304c\u5b8c\u4e86\u3044\u305f\u3057\u307e\u3057\u305f\u3002\u66f4\u65b0\u65e5\u304c\u66f8\u304b\u308c\u3066\u3044\u306a\u3044\u65b9\u304c\u6700\u65b0\u3067\u3059\uff01<\/p>\n<p>\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u6307\u5411\u8a00\u8a9e\u304c\u5727\u5012\u7684\u306b\u591a\u3044\u3067\u3059\u306d\u3002Python\u306f\u3084\u306f\u308a\u5c11\u306a\u3044\u304c\u3001\u53bb\u5e74\u3068\u6bd4\u8f03\u3057\u30660.7%\u30a2\u30c3\u30d7\u3002 <a href=\"https:\/\/t.co\/fAotDSLbRZ\">pic.twitter.com\/fAotDSLbRZ<\/a><\/p>\n<p>\u2014 \u30d5\u30a7\u30a2\u30cd\u30b9\u4f0a\u85e4@\u63a1\u7528\u62c5\u5f53 (@atsu_itou) <a href=\"https:\/\/twitter.com\/atsu_itou\/status\/1463134852148957191?ref_src=twsrc%5Etfw\">November 23, 2021<\/a><\/p><\/blockquote>\n<p><script async src=\"https:\/\/platform.twitter.com\/widgets.js\" charset=\"utf-8\"><\/script><\/p>\n<p>\u57fa\u672c\u7684\u306b\u3061\u3087\u3063\u3068\u306fRails\u3092\u77e5\u3063\u3066\u3044\u308b\u4eba\u5411\u3051\u306e\u5185\u5bb9\u3068\u306a\u308a\u307e\u3059\u304c\u3001Rails\u3092\u77e5\u3089\u306a\u3044\u65b9\u3084\u3061\u3087\u3053\u3063\u3068\u89e6\u3063\u305f\u3053\u3068\u304c\u3042\u308b\u3068\u3044\u3046\u65b9\u306b\u3082\u300c\u307b\u30fc\u3093\u3002Rails\u3063\u3066\u4eca\u305d\u3093\u306a\u3053\u3068\u306b\u306a\u3063\u3066\u306e\u304b\u3041\u3002\u300d\u3063\u3066\u601d\u3063\u3066\u3044\u305f\u3060\u3051\u308c\u3070\u5e78\u3044\u3067\u3054\u3056\u3044\u307e\u3059\u3002<\/p>\n<p>&nbsp;<\/p>\n<h1>Rails7\u306b\u3064\u3044\u3066<\/h1>\n<p><a href=\"https:\/\/github.com\/rails\/rails\">Rails<\/a>\u306f\u8a00\u308f\u305a\u3068\u77e5\u308c\u305fRuby\u306e\u4ee3\u8868\u7684\u306a\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3067\u3059\u3002<\/p>\n<p>\u57f7\u7b46\u4e2d\u306e2021\u5e7412\u6708\u982d\u6642\u70b9\u3067\u3001\u307e\u3060\u30a2\u30eb\u30d5\u30a1\u7248\u3067\u3059\u304c<code>rail7.0.0.alpha2<\/code>\u304c\u6700\u65b0\u30d0\u30fc\u30b8\u30e7\u30f3\u3067\u3059\u3002Rails7\u3067\u306f\u4e3b\u306b<strong>\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u306e\u7ba1\u7406\u65b9\u6cd5\u3067\u5927\u304d\u306a\u5909\u5316<\/strong>\u304c\u3042\u308a\u307e\u3057\u305f\u306e\u3067\u3001\u305d\u3061\u3089\u306e\u4e00\u90e8\u3092\u7d39\u4ecb\u3055\u305b\u3066\u3044\u305f\u3060\u3053\u3046\u3068\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>\u3055\u3066\u3001Rails\u306e\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u4e8b\u60c5\u306e\u6b74\u53f2\u7684\u306a\u7d4c\u7def\u3082\u542b\u3081\u305f\u8a73\u7d30\u306b\u3064\u3044\u3066\u306f\u3053\u3061\u3089\u306e<a href=\"https:\/\/www.wantedly.com\/companies\/wantedly\/post_articles\/354873\">wantedly\u3055\u3093\u306e\u30a8\u30f3\u30b8\u30cb\u30a2\u3055\u3093\u304c\u66f8\u304b\u308c\u305f\u8a18\u4e8b<\/a>\u304c\u8a73\u3057\u3044\u306e\u3067\u3059\u304c\u3061\u3087\u3063\u3068\u30cf\u30fc\u30c9\u30eb\u304c\u9ad8\u3044&#8230;&#8230;\u306e\u3067\u3001\u7b46\u8005\u306e\u76ee\u7dda\u3067Rails7\u306b\u304a\u3051\u308b\u5909\u66f4\u70b9\u3092\u8d85\u3056\u3063\u304f\u308a\u8aac\u660e\u3057\u307e\u3059\uff01<\/p>\n<p>\u5f93\u6765\u306e\u3088\u3046\u306bnode_modules\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u4ee5\u4e0b\u306b\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3057\u3066\u3001webpack\u306a\u3069\u3067\u30d3\u30eb\u30c9\u3059\u308b\u3088\u3046\u306a\u65b9\u6cd5<span class=\"footnote_referrer\"><a role=\"button\" tabindex=\"0\" onclick=\"footnote_moveToReference_24128_1('footnote_plugin_reference_24128_1_1');\" onkeypress=\"footnote_moveToReference_24128_1('footnote_plugin_reference_24128_1_1');\" ><sup id=\"footnote_plugin_tooltip_24128_1_1\" class=\"footnote_plugin_tooltip_text\">1)<\/sup><\/a><span id=\"footnote_plugin_tooltip_text_24128_1_1\" class=\"footnote_tooltip\">\u5f93\u6765\u306e\u65b9\u6cd5\u3092\u4f7f\u3044\u7d9a\u3051\u308b\u3053\u3068\u3082\u53ef\u80fd<\/span><\/span><script type=\"text\/javascript\"> jQuery('#footnote_plugin_tooltip_24128_1_1').tooltip({ tip: '#footnote_plugin_tooltip_text_24128_1_1', tipClass: 'footnote_tooltip', effect: 'fade', predelay: 0, fadeInSpeed: 200, delay: 400, fadeOutSpeed: 200, position: 'top center', relative: true, offset: [10, 10], });<\/script>\u3068\u306f\u5225\u306e\u30a2\u30d7\u30ed\u30fc\u30c1\u3067\u3001\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u4f7f\u3046\u3053\u3068\u304c\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<p>\u3053\u306e\u65b9\u6cd5\u3060\u3068\u306a\u3093\u3068node\u3084npm\u81ea\u4f53\u4e0d\u8981\u3067\u3059\u3002\u306a\u304b\u306a\u304b\u30d5\u30a1\u30f3\u30ad\u30fc\u306a\u5909\u66f4\u3067\u3059\u306d\u3002\u3053\u308c\u3092\u5b9f\u73fe\u3059\u308b\u306e\u306b\u4e00\u5f79\u8cb7\u3063\u3066\u3044\u308b\u306e\u304c<strong>importmap<\/strong>\u3067\u3059\u3002<\/p>\n<h1>importmap\u3063\u3066\u306a\u306b<\/h1>\n<p>importmap\u3068\u306f\u4f55\u306a\u306e\u3067\u3057\u3087\u3046\u304b\u3002<\/p>\n<p>importmap\u3068\u306f\u5225\u306bRails\u306b\u9650\u3063\u305f\u8a71\u3067\u306f\u3042\u308a\u307e\u305b\u3093\u3002<span class=\"footnote_referrer\"><a role=\"button\" tabindex=\"0\" onclick=\"footnote_moveToReference_24128_1('footnote_plugin_reference_24128_1_2');\" onkeypress=\"footnote_moveToReference_24128_1('footnote_plugin_reference_24128_1_2');\" ><sup id=\"footnote_plugin_tooltip_24128_1_2\" class=\"footnote_plugin_tooltip_text\">2)<\/sup><\/a><span id=\"footnote_plugin_tooltip_text_24128_1_2\" class=\"footnote_tooltip\">\u5b9f\u969b\u3001Next.js\u306a\u3093\u304b\u3067\u3082importmap\u304c\u4f7f\u3048\u308b\u3088\u3046\u306b\u3059\u308b\u6a5f\u80fd\u304c\u30ea\u30ea\u30fc\u30b9\u3055\u308c\u308b\u3068\u304b\u3002<\/span><\/span><script type=\"text\/javascript\"> jQuery('#footnote_plugin_tooltip_24128_1_2').tooltip({ tip: '#footnote_plugin_tooltip_text_24128_1_2', tipClass: 'footnote_tooltip', effect: 'fade', predelay: 0, fadeInSpeed: 200, delay: 400, fadeOutSpeed: 200, position: 'top center', relative: true, offset: [10, 10], });<\/script><br \/>\n\u3053\u306e\u8a00\u3044\u65b9\u306f\u6b63\u78ba\u3067\u306f\u306a\u3044\u6c17\u304c\u3057\u307e\u3059\u304c\u6700\u521d\u306e\u3046\u3061\u306f\u300cHTTP\u306e\u6a5f\u80fd\u300d\u3068\u3044\u3046\u8a8d\u8b58\u3067\u3044\u3044\u601d\u3044\u307e\u3059\u3002\u3053\u306e\u70b9\u306f\u7b46\u8005\u304c\u3054\u3061\u3083\u3054\u3061\u3083\u8aac\u660e\u3059\u308b\u3088\u308a\u3082\u4ee5\u4e0b\u306e\u5148\u4eba\u306e\u304a\u77e5\u6075\u3092\u3054\u89a7\u3044\u305f\u3060\u3044\u305f\u65b9\u304c\u8ce2\u660e\u3067\u3059\u3002<\/p>\n<ul>\n<li class=\"article-title\"><a href=\"http:\/\/var.blog.jp\/archives\/84173363.html\"><span style=\"font-size: 12pt;\">Chrome 89 \u304b\u3089\u4f7f\u3048\u308b\u3088\u3046\u306b\u306a\u3063\u305f importmap \u3092\u4f7f\u3063\u3066\u307f\u305f<\/span><\/a><\/li>\n<li class=\"article-title\"><a href=\"https:\/\/blog.leko.jp\/post\/package-management-in-deno-with-import-map\/#import-maps-%E3%81%A8%E3%81%AF\">Import maps\u3067Deno\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u306e\u30d0\u30fc\u30b8\u30e7\u30f3\u3092\u7ba1\u7406\u3057\u305f\u3044 &#8211; Import maps\u3068\u306f<\/a><\/li>\n<\/ul>\n<blockquote><p>\u301c\u4ee5\u4e0b\u3001\u5f8c\u8005\u306e\u30d6\u30ed\u30b0\u3088\u308a\u5f15\u7528\u301c<br \/>\nImport maps \u306f\u3053\u308c\u307e\u3067\u306e Node.js \u3084 webpack \u306a\u3069\u306e module bundler \u3092\u7528\u3044\u305f\u958b\u767a\u4f53\u9a13\u306e\u3088\u3046\u306bimport _ from &#8216;lodash&#8217;\u3068\u30d1\u30c3\u30b1\u30fc\u30b8\u540d\u3060\u3051\u6307\u5b9a\u3059\u308b import \u3092\u4f7f\u3044\u7d9a\u3051\u3064\u3064 ES Modules \u306e\u4e16\u754c\u89b3\u306b\u5f15\u3063\u8d8a\u3057\u3067\u304d\u308b\u7de9\u885d\u6750\u307f\u305f\u3044\u306a\u3082\u306e\u3060\u3068\u601d\u3048\u3070\u304a\u304a\u3080\u306d\u5408\u3063\u3066\u308b\u3068\u601d\u3044\u307e\u3059\u3002<br \/>\n\u301c\u5f15\u7528\u7d42\u308f\u308a\u301c\n<\/p><\/blockquote>\n<p>\u4f55\u306f\u3068\u3082\u3042\u308cRails7\u3067\u306f<strong>importmap-rails\u3068\u3044\u3046<\/strong>gem<span class=\"footnote_referrer\"><a role=\"button\" tabindex=\"0\" onclick=\"footnote_moveToReference_24128_1('footnote_plugin_reference_24128_1_3');\" onkeypress=\"footnote_moveToReference_24128_1('footnote_plugin_reference_24128_1_3');\" ><sup id=\"footnote_plugin_tooltip_24128_1_3\" class=\"footnote_plugin_tooltip_text\">3)<\/sup><\/a><span id=\"footnote_plugin_tooltip_text_24128_1_3\" class=\"footnote_tooltip\">Ruby\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u306e\u3053\u3068<\/span><\/span><script type=\"text\/javascript\"> jQuery('#footnote_plugin_tooltip_24128_1_3').tooltip({ tip: '#footnote_plugin_tooltip_text_24128_1_3', tipClass: 'footnote_tooltip', effect: 'fade', predelay: 0, fadeInSpeed: 200, delay: 400, fadeOutSpeed: 200, position: 'top center', relative: true, offset: [10, 10], });<\/script>\u306e\u304a\u529b\u306b\u3088\u308a\u3001Rails\u3067importmap\u6a5f\u80fd\u3092\u7c21\u5358\u306b\u4f7f\u3048\u308b\u3088\u3046\u306b\u3057\u3066\u304f\u308c\u308b\u3082\u306e\u3067\u3059\u3002<\/p>\n<p>\u3053\u308c\u306b\u3088\u3063\u3066\u30d6\u30e9\u30a6\u30b6\u304c\u6307\u5b9a\u3057\u305f\u30d1\u30c3\u30b1\u30fc\u30b8\u3092CDN\u7d4c\u7531\u3067\u30ed\u30fc\u30c9\u3057\u3066\u4f7f\u3048\u308b\u3088\u3046\u306b\u3057\u3066\u304f\u308c\u307e\u3059\u3002<\/p>\n<h1>\u30b5\u30f3\u30d7\u30eb\u30b3\u30fc\u30c9<\/h1>\n<p>\u306f\u3044\u3002\u8aac\u660e\u3059\u308b\u3088\u308a\u5b9f\u969b\u306b\u52d5\u304b\u3057\u3066\u898b\u3066\u3044\u305f\u3060\u304f\u306e\u304c\u4e00\u756a\u826f\u3044\u3067\u3057\u3087\u3046\u3002<\/p>\n<p>\u4eca\u56de\u4f7f\u3046\u30b5\u30f3\u30d7\u30eb\u30b3\u30fc\u30c9\u3092<a href=\"https:\/\/github.com\/hamilton-keisuke\/rails7-importmap-sample\">\u2605\u3053\u3061\u3089\u2605<\/a>\u306b\u7528\u610f\u3057\u307e\u3057\u305f\u3002\u3069\u3046\u305egit clone\u3057\u3066\u898b\u3066\u3084\u3063\u3066\u304f\u3060\u3055\u3044\u3002\u74b0\u5883\u306f\u4ee5\u4e0b\u306e\u901a\u308a\u3067\u3059\u3002(\u5225\u9014\u3001anyenv\u306a\u3069\u3067ruby 3.0.1\u306e\u7528\u610f\u3092\u304a\u9858\u3044\u3044\u305f\u3057\u307e\u3059\u3002\uff09<\/p>\n<ul>\n<li>Rails 7.0.0.alpha2<\/li>\n<li>Ruby 3.0.1<\/li>\n<\/ul>\n<p>git clone\u3057\u305f\u3089\u30b3\u30de\u30f3\u30c9<\/p>\n<pre>$ rails s -b 0.0.0.0<\/pre>\n<p>\u3092\u5b9f\u884c\u3057\u3001\u30d6\u30e9\u30a6\u30b6\u304b\u3089localhost:3000\u3078\u30a2\u30af\u30bb\u30b9\u3057\u3066\u307f\u307e\u3057\u3087\u3046\u3002<\/p>\n<p>\u3059\u308b\u3068\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306b Item1 \u301c Item4 \u306b\u3064\u3044\u3066\u30c9\u30e9\u30c3\u30b0&amp;\u30c9\u30ed\u30c3\u30d7\u3067\u30bd\u30fc\u30c8\u304c\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002\u3053\u308c\u306fsortable.js\u3068\u3044\u3046js\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u304c\u4f7f\u3048\u3066\u3044\u308b\u305f\u3081\u3067\u3059\u3002sortable.js\u81ea\u4f53\u306e\u7d30\u304b\u3044\u8aac\u660e\u306f\u5272\u611b\u3057\u307e\u3059\u3002<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" data-attachment-id=\"24209\" data-permalink=\"https:\/\/www.agent-grow.com\/self20percent\/2021\/12\/09\/rail7%e3%81%a7%e3%81%aeimportmap%e3%82%92%e7%b4%b9%e4%bb%8b%e3%80%90agent-grow-advent-calendar-2021%ef%bc%9a9%e6%97%a5%e7%9b%ae%e3%80%91\/ag-kasano2021-11-30-0-53-17-mov\/\" data-orig-file=\"https:\/\/www.agent-grow.com\/self20percent\/wp-content\/uploads\/2021\/11\/ag-kasano2021-11-30-0.53.17.mov.gif\" data-orig-size=\"600,400\" data-comments-opened=\"1\" data-image-meta=\"{&quot;aperture&quot;:&quot;0&quot;,&quot;credit&quot;:&quot;&quot;,&quot;camera&quot;:&quot;&quot;,&quot;caption&quot;:&quot;&quot;,&quot;created_timestamp&quot;:&quot;0&quot;,&quot;copyright&quot;:&quot;&quot;,&quot;focal_length&quot;:&quot;0&quot;,&quot;iso&quot;:&quot;0&quot;,&quot;shutter_speed&quot;:&quot;0&quot;,&quot;title&quot;:&quot;&quot;,&quot;orientation&quot;:&quot;0&quot;}\" data-image-title=\"ag-kasano2021-11-30 0.53.17.mov\" data-image-description=\"\" data-image-caption=\"\" data-large-file=\"https:\/\/www.agent-grow.com\/self20percent\/wp-content\/uploads\/2021\/11\/ag-kasano2021-11-30-0.53.17.mov.gif\" class=\"aligncenter wp-image-24209 size-full\" src=\"https:\/\/www.agent-grow.com\/self20percent\/wp-content\/uploads\/2021\/11\/ag-kasano2021-11-30-0.53.17.mov.gif\" alt=\"\" width=\"600\" height=\"400\" \/><\/p>\n<p>\u5f93\u6765\u306e\u3084\u308a\u65b9\u3067sortablejs\u3092\u4f7f\u3046\u5834\u5408\u306f\u3001<\/p>\n<pre>$ npm install sortablejs<\/pre>\n<p>\u3068\u30b3\u30de\u30f3\u30c9\u3092\u53e9\u3044\u3066node_modules\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u4ee5\u4e0b\u306bsortable.js\u304c\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9\u3055\u308c\u3001\u81ea\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u3067\u4f7f\u3046\u5834\u5408\u306f\u305d\u308c\u3092\u4f7f\u3046\u306e\u304c\u4e00\u822c\u7684\u3067\u3057\u3087\u3046\u3002<\/p>\n<p>\u3057\u304b\u3057\u4eca\u56de\u306e\u30b5\u30f3\u30d7\u30eb\u30b3\u30fc\u30c9\u3092\u898b\u3066\u3082\u3001npm install\u306b\u4f7f\u3046package.json\u306f\u3069\u3053\u306b\u3082\u3042\u308a\u307e\u305b\u3093\u3002node_modules\u30c7\u30a3\u30ec\u30af\u30c8\u30ea\u306f\u901a\u5e38gitignore\u306b\u8a2d\u5b9a\u3055\u308c\u308b\u306e\u3067\u7121\u304f\u3066\u5f53\u7136<\/p>\n<pre>&lt;script src=\"https:\/\/cdnjs.cloudflare.com\/ajax\/libs\/Sortable\/1.14.0\/Sortable.min.js\"&gt;\n<\/pre>\n<p>\u307f\u305f\u3044\u306a\u5358\u306bHTML\u306bCDN\u3092\u57cb\u3081\u8fbc\u3093\u3067\u3044\u308b\u30b3\u30fc\u30c9\u3082\u3042\u308a\u307e\u305b\u3093\u3002\u3067\u306fsortable.js\u306f\u4e00\u4f53\u3069\u3053\u304b\u3089\u53d6\u3063\u3066\u304d\u3066\u5229\u7528\u3057\u3066\u3044\u308b\u306e\u3067\u3057\u3087\u3046\u304b\uff1f<\/p>\n<p>\u305d\u306e\u7b54\u3048\u306f\u3001\u30b5\u30f3\u30d7\u30eb\u30b3\u30fc\u30c9\u306e<\/p>\n<ul>\n<li><a href=\"https:\/\/github.com\/hamilton-keisuke\/rails7-importmap-sample\/blob\/main\/app\/views\/layouts\/application.html.erb#L9\">app\/views\/layouts\/application.html.erb<\/a><\/li>\n<li><a href=\"https:\/\/github.com\/hamilton-keisuke\/rails7-importmap-sample\/blob\/main\/config\/importmap.rb\">config\/importmap.rb<\/a><\/li>\n<\/ul>\n<p>\u306b\u3042\u308a\u307e\u3059\u3002<\/p>\n<div>\n<div>\n<p>app\/views\/layouts\/application.html.erb\u306e<\/p>\n<pre>&lt;%=javascript_importmap_tags%&gt;\n<\/pre>\n<p>\u3067\u3001importmap.rb\u306b\u8a18\u8f09\u3055\u308c\u3066\u3044\u308b\u5404\u30d1\u30c3\u30b1\u30fc\u30b8\u3092include\u3057\u3066\u304f\u308c\u3066\u3044\u307e\u3059\u3002sortablejs\u306fCDN\u7d4c\u7531\u3067<strong>\u30d6\u30e9\u30a6\u30b6\u304c<\/strong>\u53d6\u5f97\u3057\u3066\u304f\u308c\u3066\u4f7f\u3048\u308b\u3088\u3046\u306b\u3057\u3066\u304f\u308c\u3066\u3044\u308b\u3093\u3067\u3059\u3002<\/p>\n<\/div>\n<\/div>\n<div><\/div>\n<div>\u6b21\u306b\u30d6\u30e9\u30a6\u30b6\u306e\u30c7\u30d9\u30ed\u30c3\u30d1\u30fc\u30c4\u30fc\u30eb\u306a\u3069\u3067head\u30bf\u30b0\u5185\u3092\u898b\u3066\u307f\u307e\u3057\u3087\u3046\u3002<code>&lt;script type=\"importmap\"...<\/code>\u3068\u3044\u3046\u306e\u304c\u3042\u308a\u307e\u3059\u3002\u3053\u308c\u304cimportmap\u306e\u6b63\u4f53\u3067\u3059\u3002<\/div>\n<div><\/div>\n<div><\/div>\n<div><img loading=\"lazy\" decoding=\"async\" data-attachment-id=\"24177\" data-permalink=\"https:\/\/www.agent-grow.com\/self20percent\/2021\/12\/09\/rail7%e3%81%a7%e3%81%aeimportmap%e3%82%92%e7%b4%b9%e4%bb%8b%e3%80%90agent-grow-advent-calendar-2021%ef%bc%9a9%e6%97%a5%e7%9b%ae%e3%80%91\/%e3%82%b9%e3%82%af%e3%83%aa%e3%83%bc%e3%83%b3%e3%82%b7%e3%83%a7%e3%83%83%e3%83%88-2021-11-30-18-19-22\/\" data-orig-file=\"https:\/\/www.agent-grow.com\/self20percent\/wp-content\/uploads\/2021\/11\/3738c4922f8d58165462500f4012b646.jpg\" data-orig-size=\"727,800\" data-comments-opened=\"1\" data-image-meta=\"{&quot;aperture&quot;:&quot;0&quot;,&quot;credit&quot;:&quot;&quot;,&quot;camera&quot;:&quot;&quot;,&quot;caption&quot;:&quot;&quot;,&quot;created_timestamp&quot;:&quot;0&quot;,&quot;copyright&quot;:&quot;&quot;,&quot;focal_length&quot;:&quot;0&quot;,&quot;iso&quot;:&quot;0&quot;,&quot;shutter_speed&quot;:&quot;0&quot;,&quot;title&quot;:&quot;&quot;,&quot;orientation&quot;:&quot;0&quot;}\" data-image-title=\"\u30b9\u30af\u30ea\u30fc\u30f3\u30b7\u30e7\u30c3\u30c8 2021-11-30 18.19.22\" data-image-description=\"\" data-image-caption=\"\" data-large-file=\"https:\/\/www.agent-grow.com\/self20percent\/wp-content\/uploads\/2021\/11\/3738c4922f8d58165462500f4012b646.jpg\" class=\"aligncenter wp-image-24177 size-full\" src=\"https:\/\/www.agent-grow.com\/self20percent\/wp-content\/uploads\/2021\/11\/3738c4922f8d58165462500f4012b646.jpg\" alt=\"\" width=\"727\" height=\"800\" srcset=\"https:\/\/www.agent-grow.com\/self20percent\/wp-content\/uploads\/2021\/11\/3738c4922f8d58165462500f4012b646.jpg 727w, https:\/\/www.agent-grow.com\/self20percent\/wp-content\/uploads\/2021\/11\/3738c4922f8d58165462500f4012b646-273x300.jpg 273w\" sizes=\"auto, (max-width: 727px) 100vw, 727px\" \/><\/div>\n<div><\/div>\n<div>\n<div><\/div>\n<div>Rails(importmap-rails)\u3067importmap\u306b\u3088\u3063\u3066\u4f7f\u3044\u305f\u3044\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u6307\u5b9a\u3059\u308b\u306e\u306f\u4ee5\u4e0b\u306e\u30b3\u30de\u30f3\u30c9\u3067\u3059\u3002<\/div>\n<\/div>\n<div>\n<pre>$ bin\/importmap pin &lt;\u30d1\u30c3\u30b1\u30fc\u30b8\u540d&gt;\n<\/pre>\n<\/div>\n<div><\/div>\n<div>\u3053\u306epin\u30b3\u30de\u30f3\u30c9\u3067\u6307\u5b9a\u3057\u305f\u30d1\u30c3\u30b1\u30fc\u30b8\u304c<code>config\/importmap.rb<\/code>\u306b\u8ffd\u52a0\u3055\u308c\u307e\u3059\u3002\u4f9d\u5b58\u3059\u308b\u30d1\u30c3\u30b1\u30fc\u30b8\u304c\u3042\u308c\u3070\u305d\u308c\u3082\u4e00\u7dd2\u306b\u8ffd\u52a0\u3057\u3066\u304f\u308c\u307e\u3059\u3002<\/div>\n<div>\u3061\u306a\u307f\u306bpin\u3068\u3044\u3046\u306e\u306f<code>&lt;script type=\"importmap\"&gt;<\/code>\u306b\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u66f8\u304f\u3053\u3068\u300c\u30d4\u30f3\u7559\u3081\u300d\u3068\u3044\u3046\u305f\u3081\u3001\u3053\u306e\u3088\u3046\u306a\u540d\u524d\u306b\u306a\u3063\u3066\u3044\u308b\u3088\u3046\u3067\u3059\u3002<\/div>\n<div><\/div>\n<div>importmap\u306e\u304a\u304b\u3052\u3067\u3001<code>import _ from 'sortable.js'<\/code>\u3068\u3059\u308b\u3060\u3051\u3067sortablejs\u3092\u4f7f\u3046\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/div>\n<div>\n<h1>\u7d50\u5c40importmap\u3063\u3066\u4f55\u306e\u30e1\u30ea\u30c3\u30c8\u304c\u3042\u308b\u306e\uff1f<\/h1>\n<\/div>\n<div>Rails\u3067importmap\u4f7f\u3063\u3066\u4f55\u304c\u5b09\u3057\u3044\u304b\u3068\u3044\u3046\u3068\u4ee5\u4e0b2\u70b9\u304b\u306a\u3068\u601d\u3063\u3066\u3044\u307e\u3059\u3002\u79c1\u306e\u7406\u89e3\u5ea6\u304c\u4e4f\u3057\u3044\u306e\u3067\u4ee5\u4e0b2\u3064\u3057\u304b\u5206\u304b\u3063\u3066\u306a\u3044\u3067\u3059\u3002<\/div>\n<div><\/div>\n<div><\/div>\n<p><strong>\u2460HTTP2\u306e\u4ed5\u69d8\u306b\u3088\u308a\u901a\u4fe1\u306e\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u304c\u826f\u304f\u306a\u308a\u30e6\u30fc\u30b6\u30fc\u4f53\u9a13\u306e\u5411\u4e0a\u306b\u7e4b\u304c\u308b<\/strong><\/p>\n<blockquote><p>webpack\u3068\u304b\u306e\u30d0\u30f3\u30c9\u30e9\u30fc\u3067\u4f5c\u3063\u305f\u5927\u304d\u3044\u30b5\u30a4\u30ba\u306ejs\u30d5\u30a1\u30a4\u30eb\u30921\u3064\u3069\u30fc\u3093\u3068\u9001\u308b\u3088\u308a\u3001\u5c0f\u3055\u3044\u30b5\u30a4\u30ba\u306e\u30d5\u30a1\u30a4\u30eb\u3092HTTP2\u306b\u3088\u308b1\u30b9\u30c8\u30ea\u30fc\u30e0\u3067\u4f55\u500b\u3082\u9001\u308b\u65b9\u304c\u9ad8\u901f\u3089\u3057\u3044\u3067\u3059\u3002\u304c\u3001<a href=\"https:\/\/takehora.hatenadiary.jp\/entry\/2017\/12\/27\/011121\" target=\"_blank\" rel=\"noopener\">\u305d\u3093\u306a\u306b\u9ad8\u901f\u306b\u306a\u3089\u306a\u3044\u3068\u3044\u3046\u53cd\u8ad6\u3082\u3042\u308b<\/a>\u306e\u3067\u5b9f\u969b\u306e\u3068\u3053\u308d\u306f\u307e\u3060\u3088\u304f\u308f\u304b\u3089\u306a\u3044\u3068\u3044\u3046\u5370\u8c61\u3067\u3059\u3002<\/p><\/blockquote>\n<p><strong>\u2461\u958b\u767a\u6642\u306b\u3044\u3061\u3044\u3061\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u306e\u30d5\u30a1\u30a4\u30eb\u3092\u30d3\u30eb\u30c9\u3057\u306a\u304f\u3066\u3044\u3044<\/strong><\/p>\n<blockquote><p>webpack\u3068\u304bdev-server\u8d77\u52d5\u3057\u3066\u304a\u3044\u3066js\u30d5\u30a1\u30a4\u30eb\u3092\u66f4\u65b0\u3059\u308b\u305f\u3073\u306b\u518d\u30d3\u30eb\u30c9\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u304b\u3089\u306d\u3001\u305d\u308c\u306b\u6642\u9593\u3092\u53d6\u3089\u308c\u306a\u3044\u306e\u306f\u9006\u306b\u65b0\u9bae\u3067\u3059\u3002<\/p><\/blockquote>\n<p>&nbsp;<\/p>\n<h1>importmap-rails\u306e\u554f\u984c\u70b9?<\/h1>\n<p>\u8a8d\u8b58\u3057\u3066\u3044\u308b\u554f\u984c\u70b9\u306f\u4ee5\u4e0b3\u3064\u3067\u3059<\/p>\n<p><strong>\u2460 \u66f4\u65b0\u306e\u5fc5\u8981\u304c\u3042\u308b\u30d1\u30c3\u30b1\u30fc\u30b8\u304c\u308f\u304b\u3089\u306a\u3044<\/strong><\/p>\n<blockquote><p>npm\u3084yarn\u3067\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u7ba1\u7406\u3067\u306f\u3001audit\u3084outdated\u3068\u3044\u3046\u30b5\u30d6\u30b3\u30de\u30f3\u30c9\u3067\u8106\u5f31\u6027\u304c\u898b\u3064\u304b\u3063\u305f\u30d1\u30c3\u30b1\u30fc\u30b8\u3084\u3001\u66f4\u65b0\u3067\u304d\u308b\u30d1\u30c3\u30b1\u30fc\u30b8\u3092\u7c21\u5358\u306b\u63a2\u3059\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002\u3053\u308c\u306b\u3088\u3063\u3066\u30b7\u30b9\u30c6\u30e0\u306e\u8106\u5f31\u6027\u5bfe\u5fdc\u306a\u3069\u62c5\u4fdd\u3067\u304d\u308b\u306e\u3067\u7b46\u8005\u3082\u3088\u304f\u4f7f\u3063\u3066\u304a\u308a\u307e\u3059\u3002\u3057\u304b\u3057importmap-rails\u3067\u306f\u8abf\u3079\u305f\u9650\u308a\u305d\u306e\u3088\u3046\u306a\u6a5f\u80fd\u304c\u307e\u3060\u7121\u3044\u3088\u3046\u3067\u3059\u3002\u4e00\u5fdcimportmap-rails\u306e<a href=\"https:\/\/github.com\/rails\/importmap-rails\/issues\/19\" target=\"_blank\" rel=\"noopener\">issue<\/a>\u306b\u306f\u3053\u306e\u554f\u984c\u304c\u4e0a\u304c\u3063\u3066\u304a\u308a\u306a\u3093\u3068\u304b\u3057\u3088\u3046\u3068\u3057\u3066\u304f\u308c\u3066\u3044\u308b\u3088\u3046\u3067\u3059\u3002CDN\u3092\u4f7f\u3046\u524d\u63d0\u3060\u3068\u30ed\u30fc\u30ab\u30eb\u306b\u305d\u306e\u30d1\u30c3\u30b1\u30fc\u30b8\u304c\u3042\u308b\u308f\u3051\u3067\u306f\u7121\u3044\u3053\u3068\u3082\u3042\u308a\u3001\u306a\u304b\u306a\u304b\u3053\u306e\u8fba\u308a\u306e\u89e3\u6c7a\u304c\u4e00\u7b4b\u7e04\u3067\u306f\u3044\u304b\u306a\u3044\u3088\u3046\u3067\u3059\u306d\u3002\u3002\u3002<\/p><\/blockquote>\n<p><strong>\u2461\u305d\u3082\u305d\u3082\u6bd4\u8f03\u7684\u65b0\u3057\u3044\u30d6\u30e9\u30a6\u30b6\u3067\u306a\u3044\u3068importmap\u306f\u4f7f\u3048\u306a\u3044<\/strong><\/p>\n<blockquote><p>\u53e4\u3044\u30d0\u30fc\u30b8\u30e7\u30f3\u306e\u30d6\u30e9\u30a6\u30b6\u3060\u3068\u4f7f\u3048\u306a\u3044\u3088\u3046\u3067\u3059\u3002\uff08\u3053\u306e\u3042\u305f\u308a\u306e\u5bfe\u5fdc\u72b6\u6cc1\u306b\u95a2\u3059\u308b\u308f\u304b\u308a\u3084\u3059\u3044\u8cc7\u6599\u304c\u898b\u3064\u304b\u3089\u306a\u304b\u3063\u305f\uff09<\/p><\/blockquote>\n<p><strong>\u2462React\u3084Typescript\u306a\u3069\u306f\u7d50\u5c40\u30c8\u30e9\u30f3\u30b9\u30d1\u30a4\u30eb\u304c\u5fc5\u8981<\/strong><\/p>\n<blockquote><p>importmap\u3067React\u3092\u52d5\u304b\u3059\u306e\u306fDHH\u3055\u3093<span class=\"footnote_referrer\"><a role=\"button\" tabindex=\"0\" onclick=\"footnote_moveToReference_24128_1('footnote_plugin_reference_24128_1_4');\" onkeypress=\"footnote_moveToReference_24128_1('footnote_plugin_reference_24128_1_4');\" ><sup id=\"footnote_plugin_tooltip_24128_1_4\" class=\"footnote_plugin_tooltip_text\">4)<\/sup><\/a><span id=\"footnote_plugin_tooltip_text_24128_1_4\" class=\"footnote_tooltip\">Rails\u3092\u4f5c\u3063\u305f\u3059\u3054\u3044\u4eba<\/span><\/span><script type=\"text\/javascript\"> jQuery('#footnote_plugin_tooltip_24128_1_4').tooltip({ tip: '#footnote_plugin_tooltip_text_24128_1_4', tipClass: 'footnote_tooltip', effect: 'fade', predelay: 0, fadeInSpeed: 200, delay: 400, fadeOutSpeed: 200, position: 'top center', relative: true, offset: [10, 10], });<\/script>\u304c\u3069\u3063\u304b\u3067\u30c7\u30e2\u3057\u3066\u304f\u308c\u3066\u305f\u6c17\u304c\u3057\u307e\u3059\u304c\u3001\u6b63\u5f0f\u306b\u306f\u96e3\u3057\u3044\u3088\u3046\u3067\u3059\u3002<\/p><\/blockquote>\n<p>&nbsp;<\/p>\n<p>\u3067\u3059\u306e\u3067\u3001\u66ab\u304f\u306fwebpack\u3084sprockets\u306a\u3069\u3067js\u3092\u30d3\u30eb\u30c9\u3057\u3066include\u3059\u308b\u5f93\u6765\u306e\u624b\u6cd5\u304c\u307e\u3060\u307e\u3060\u73fe\u5f79\u3060\u308d\u3046\u306a\u3041\u3068\u3044\u3046\u5370\u8c61\u3067\u3059\u3002\u3042\u3068\u306fCDN\u304b\u3089\u4f7f\u3046\u306e\u3063\u3066\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u7684\u306b\u5927\u4e08\u592b\u306a\u3093\uff1f\u3068\u3044\u3046\u4eba\u3082\u4e00\u5b9a\u6570\u3044\u308b\u3088\u3046\u306a\u6c17\u304c\u3057\u307e\u3059\u3002<\/p>\n<h1>\u3055\u3044\u3054\u306b<\/h1>\n<p>\u4ee5\u4e0a\u3001\u99c6\u3051\u8db3\u306b\u306a\u308a\u307e\u3057\u305f\u304cRails7 \u00d7 importmap\u306e\u7d39\u4ecb\u3067\u3057\u305f\u3002importmap\u304c\u30d0\u30f3\u30d0\u30f3\u4f7f\u308f\u308c\u308b\u3088\u3046\u306b\u306a\u308b\u306e\u306f\u307e\u3060\u5148\u306e\u8a71\u3060\u3068\u601d\u3044\u307e\u3059\u304c\u3001\u65b0\u3057\u3044\u6280\u8853\u3092\u65e9\u3081\u306b\u30ad\u30e3\u30c3\u30c1\u30a2\u30c3\u30d7\u3057\u3066\u9078\u629e\u80a2\u3068\u3057\u3066\u77e5\u3063\u3066\u304a\u304f\u3053\u3068\u306f\u91cd\u8981\u3067\u3059\u3088\u306d\u3002\u3053\u308c\u304b\u3089\u3082\u60c5\u5831\u53ce\u96c6\u3092\u6020\u3089\u305a\u306b\u7cbe\u9032\u3057\u3066\u53c2\u308a\u307e\u3059\u3002<\/p>\n<p>\u306a\u304a\u3001\u5192\u982d\u306b\u8a18\u8f09\u3057\u305f\u901a\u308a<a href=\"https:\/\/www.agent-grow.com\/Pages\/Recruit\" target=\"_blank\" rel=\"noopener\">\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u30b0\u30ed\u30fc\u3067\u306fRubyist\u52df\u96c6\u4e2d\u3067\u3059\uff01\u3082\u3061\u308d\u3093Rubyist\u4ee5\u5916\u306e\u30a8\u30f3\u30b8\u30cb\u30a2\u3055\u3093\u3082\u52df\u96c6\u3057\u3066\u304a\u308a\u307e\u3059\u3002 \ud83d\ude42<\/a><\/p>\n<p>\u4ee5\u4e0a\u3001\u3042\u308a\u304c\u3068\u3046\u3054\u3056\u3044\u307e\u3057\u305f\u3002<\/p>\n<h1>\u53c2\u8003\u8a18\u4e8b<\/h1>\n<ul style=\"list-style-type: circle;\">\n<li><a href=\"https:\/\/www.wantedly.com\/companies\/wantedly\/post_articles\/354873\">Rails 7.0\u3067\u30a2\u30bb\u30c3\u30c8\u30d1\u30a4\u30d7\u30e9\u30a4\u30f3\u306f\u3069\u3046\u5909\u308f\u308b\u304b<\/a><\/li>\n<li><span style=\"font-size: 12pt;\"><a href=\"https:\/\/www.youtube.com\/watch?v=PtxZvFnL2i0\">Alpha preview: Modern JavaScript in Rails 7 without Webpack<\/a><\/span><\/li>\n<li><a href=\"https:\/\/zenn.dev\/kenzan100\/articles\/0f9b100655a4bf\">Rails7\u304c\u3082\u3064\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u3078\u306e\u300c\u7b54\u3048\u300d<\/a><\/li>\n<li><a href=\"http:\/\/var.blog.jp\/archives\/84173363.html\">Chrome 89 \u304b\u3089\u4f7f\u3048\u308b\u3088\u3046\u306b\u306a\u3063\u305f importmap \u3092\u4f7f\u3063\u3066\u307f\u305f<\/a><\/li>\n<li><a href=\"https:\/\/www.youtube.com\/watch?v=veWpot6zfUQ\"><span class=\"style-scope yt-formatted-string\" dir=\"auto\">Episode #312<\/span><span class=\"style-scope yt-formatted-string\" dir=\"auto\">&#8211; Importmaps in Rails 7<\/span><\/a><\/li>\n<li><a href=\"https:\/\/knowledge.sakura.ad.jp\/7734\/\">\u666e\u53ca\u304c\u9032\u3080\u300cHTTP\/2\u300d\u306e\u4ed5\u7d44\u307f\u3068\u30e1\u30ea\u30c3\u30c8\u3068\u306f<\/a><\/li>\n<li><a href=\"https:\/\/github.com\/WICG\/import-maps\">Github WICG\/import-map<\/a><\/li>\n<li><a href=\"https:\/\/takehora.hatenadiary.jp\/entry\/2017\/12\/27\/011121\">HTTP\/2\u304c\u901f\u3044\u3068\u3044\u3046\u5e7b\u60f3<\/a><\/li>\n<\/ul>\n<div class=\"speaker-mute footnotes_reference_container\"> <div class=\"footnote_container_prepare\"><p><span role=\"button\" tabindex=\"0\" class=\"footnote_reference_container_label pointer\" onclick=\"footnote_expand_collapse_reference_container_24128_1();\">\u6ce8\u8a33\u306f\u3053\u3061\u3089<\/span><span role=\"button\" tabindex=\"0\" class=\"footnote_reference_container_collapse_button\" style=\"display: none;\" onclick=\"footnote_expand_collapse_reference_container_24128_1();\">[<a id=\"footnote_reference_container_collapse_button_24128_1\">+<\/a>]<\/span><\/p><\/div> <div id=\"footnote_references_container_24128_1\" style=\"\"><table class=\"footnotes_table footnote-reference-container\"><caption class=\"accessibility\">\u6ce8\u8a33\u306f\u3053\u3061\u3089<\/caption> <tbody> \r\n\r\n<tr class=\"footnotes_plugin_reference_row\"> <th scope=\"row\" class=\"footnote_plugin_index_combi pointer\"  onclick=\"footnote_moveToAnchor_24128_1('footnote_plugin_tooltip_24128_1_1');\"><a id=\"footnote_plugin_reference_24128_1_1\" class=\"footnote_backlink\"><span class=\"footnote_index_arrow\">&#8593;<\/span>1<\/a><\/th> <td class=\"footnote_plugin_text\">\u5f93\u6765\u306e\u65b9\u6cd5\u3092\u4f7f\u3044\u7d9a\u3051\u308b\u3053\u3068\u3082\u53ef\u80fd<\/td><\/tr>\r\n\r\n<tr class=\"footnotes_plugin_reference_row\"> <th scope=\"row\" class=\"footnote_plugin_index_combi pointer\"  onclick=\"footnote_moveToAnchor_24128_1('footnote_plugin_tooltip_24128_1_2');\"><a id=\"footnote_plugin_reference_24128_1_2\" class=\"footnote_backlink\"><span class=\"footnote_index_arrow\">&#8593;<\/span>2<\/a><\/th> <td class=\"footnote_plugin_text\">\u5b9f\u969b\u3001Next.js\u306a\u3093\u304b\u3067\u3082importmap\u304c\u4f7f\u3048\u308b\u3088\u3046\u306b\u3059\u308b\u6a5f\u80fd\u304c\u30ea\u30ea\u30fc\u30b9\u3055\u308c\u308b\u3068\u304b\u3002<\/td><\/tr>\r\n\r\n<tr class=\"footnotes_plugin_reference_row\"> <th scope=\"row\" class=\"footnote_plugin_index_combi pointer\"  onclick=\"footnote_moveToAnchor_24128_1('footnote_plugin_tooltip_24128_1_3');\"><a id=\"footnote_plugin_reference_24128_1_3\" class=\"footnote_backlink\"><span class=\"footnote_index_arrow\">&#8593;<\/span>3<\/a><\/th> <td class=\"footnote_plugin_text\">Ruby\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u306e\u3053\u3068<\/td><\/tr>\r\n\r\n<tr class=\"footnotes_plugin_reference_row\"> <th scope=\"row\" class=\"footnote_plugin_index_combi pointer\"  onclick=\"footnote_moveToAnchor_24128_1('footnote_plugin_tooltip_24128_1_4');\"><a id=\"footnote_plugin_reference_24128_1_4\" class=\"footnote_backlink\"><span class=\"footnote_index_arrow\">&#8593;<\/span>4<\/a><\/th> <td class=\"footnote_plugin_text\">Rails\u3092\u4f5c\u3063\u305f\u3059\u3054\u3044\u4eba<\/td><\/tr>\r\n\r\n <\/tbody> <\/table> <\/div><\/div><script type=\"text\/javascript\"> function footnote_expand_reference_container_24128_1() { jQuery('#footnote_references_container_24128_1').show(); jQuery('#footnote_reference_container_collapse_button_24128_1').text('\u2212'); } function footnote_collapse_reference_container_24128_1() { jQuery('#footnote_references_container_24128_1').hide(); jQuery('#footnote_reference_container_collapse_button_24128_1').text('+'); } function footnote_expand_collapse_reference_container_24128_1() { if (jQuery('#footnote_references_container_24128_1').is(':hidden')) { footnote_expand_reference_container_24128_1(); } else { footnote_collapse_reference_container_24128_1(); } } function footnote_moveToReference_24128_1(p_str_TargetID) { footnote_expand_reference_container_24128_1(); var l_obj_Target = jQuery('#' + p_str_TargetID); if (l_obj_Target.length) { jQuery( 'html, body' ).delay( 0 ); jQuery('html, body').animate({ scrollTop: l_obj_Target.offset().top - window.innerHeight * 0.2 }, 380); } } function footnote_moveToAnchor_24128_1(p_str_TargetID) { footnote_expand_reference_container_24128_1(); var l_obj_Target = jQuery('#' + p_str_TargetID); if (l_obj_Target.length) { jQuery( 'html, body' ).delay( 0 ); jQuery('html, body').animate({ scrollTop: l_obj_Target.offset().top - window.innerHeight * 0.2 }, 380); } }<\/script>","protected":false},"excerpt":{"rendered":"<p>\u3053\u306e\u8a18\u4e8b\u306f Agent Grow Advent Calendar 2021 9 \u65e5\u76ee\u306e\u8a18\u4e8b\u3067\u3059\u3002 \u521d\u3081\u307e\u3057\u3066\u3002\u30a8\u30fc\u30b8\u30a7\u30f3\u30c8\u30b0\u30ed\u30fc\u3067Ruby\u6848\u4ef6\u306b\u53c2\u753b\u3055\u305b\u3066\u3044\u305f\u3060\u3044\u3066\u3044\u308bKasano\u3068\u7533\u3057\u307e\u3059\u3002 \u4ee5\u4e0b\u30c4\u30a4\u30fc\u30c8\u3088\u308a\u30012021 [&hellip;]<\/p>\n","protected":false},"author":68,"featured_media":24240,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[10],"tags":[809,823,824],"class_list":["post-24128","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-tech","tag-agent-grow-advent-calendar-2021","tag-ruby","tag-ruby-on-rails"],"jetpack_featured_media_url":"https:\/\/www.agent-grow.com\/self20percent\/wp-content\/uploads\/2021\/12\/diamond-gd29fe99dd_640.jpg","jetpack_shortlink":"https:\/\/wp.me\/p7Bq4F-6ha","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/www.agent-grow.com\/self20percent\/wp-json\/wp\/v2\/posts\/24128","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.agent-grow.com\/self20percent\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.agent-grow.com\/self20percent\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.agent-grow.com\/self20percent\/wp-json\/wp\/v2\/users\/68"}],"replies":[{"embeddable":true,"href":"https:\/\/www.agent-grow.com\/self20percent\/wp-json\/wp\/v2\/comments?post=24128"}],"version-history":[{"count":0,"href":"https:\/\/www.agent-grow.com\/self20percent\/wp-json\/wp\/v2\/posts\/24128\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.agent-grow.com\/self20percent\/wp-json\/wp\/v2\/media\/24240"}],"wp:attachment":[{"href":"https:\/\/www.agent-grow.com\/self20percent\/wp-json\/wp\/v2\/media?parent=24128"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.agent-grow.com\/self20percent\/wp-json\/wp\/v2\/categories?post=24128"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.agent-grow.com\/self20percent\/wp-json\/wp\/v2\/tags?post=24128"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}