{"id":8521,"date":"2025-03-17T11:45:00","date_gmt":"2025-03-17T02:45:00","guid":{"rendered":"https:\/\/fastcoding.jp\/blog\/?p=8521"},"modified":"2025-03-15T20:11:10","modified_gmt":"2025-03-15T11:11:10","slug":"javascript-scatter-plot-plugins","status":"publish","type":"post","link":"https:\/\/fastcoding.jp\/blog\/all\/frontend\/javascript-scatter-plot-plugins\/","title":{"rendered":"\u3010\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u5c4b\u306e\u30cd\u30bf\u5e33\u3011\u30c7\u30fc\u30bf\u53ef\u8996\u5316\u306f\u3053\u308c\u3067\u6c7a\u307e\u308a\uff01\u6563\u5e03\u56f3\u4f5c\u6210\u306b\u5f79\u7acb\u3064JavaScript\u30e9\u30a4\u30d6\u30e9\u30ea5\u9078"},"content":{"rendered":"<div class=\"the_content\">\n<p>\u30c7\u30fc\u30bf\u3092\u308f\u304b\u308a\u3084\u3059\u304f\u4f1d\u3048\u308b\u65b9\u6cd5\u306e\u3072\u3068\u3064\u306b\u300c\u30b0\u30e9\u30d5\u300d\u304c\u3042\u308a\u307e\u3059\u3002\u672c\u30b7\u30ea\u30fc\u30ba\u3067\u306f\u3001\u3055\u307e\u3056\u307e\u306a\u30b0\u30e9\u30d5\u306e\u7279\u5fb4\u3084\u4f7f\u3044\u65b9\u3092\u7d39\u4ecb\u3057\u3001Web\u30b5\u30a4\u30c8\u3067\u7c21\u5358\u306b\u4f7f\u3048\u308bJavaScript\u30e9\u30a4\u30d6\u30e9\u30ea\u3082\u89e3\u8aac\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u3053\u308c\u307e\u3067\u306b\u3001\u68d2\u30b0\u30e9\u30d5\u30fb\u5186\u30b0\u30e9\u30d5\u30fb\u6298\u308c\u7dda\u30b0\u30e9\u30d5\u30fb\u30ec\u30fc\u30c0\u30fc\u30c1\u30e3\u30fc\u30c8\u3092\u53d6\u308a\u4e0a\u3052\u3066\u304d\u307e\u3057\u305f\u3002\u4eca\u56de\u306f\u3001<strong>\u6563\u5e03\u56f3\uff08\u30b9\u30ad\u30e3\u30c3\u30bf\u30fc\u30d7\u30ed\u30c3\u30c8\uff09<\/strong>\u306b\u6ce8\u76ee\u3057\u307e\u3059\u3002\u6563\u5e03\u56f3\u306f\u30012\u3064\u306e\u6570\u5024\u30c7\u30fc\u30bf\u3092XY\u5ea7\u6a19\u4e0a\u306b\u914d\u7f6e\u3057\u3066\u3001\u30c7\u30fc\u30bf\u306e\u5206\u5e03\u3084\u95a2\u4fc2\u6027\u3092\u8996\u899a\u7684\u306b\u8868\u73fe\u3059\u308b\u30b0\u30e9\u30d5\u3067\u3001\u30c7\u30fc\u30bf\u306e\u50be\u5411\u3084\u76f8\u95a2\u3092\u898b\u3064\u3051\u308b\u306e\u306b\u3088\u304f\u4f7f\u308f\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u3053\u306e\u8a18\u4e8b\u306f\u3001\u6b21\u306e\u3088\u3046\u306a\u4eba\u306b\u5411\u3051\u3066\u66f8\u3044\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li>Web\u30b5\u30a4\u30c8\u306b\u30b0\u30e9\u30d5\u3092\u53d6\u308a\u5165\u308c\u305f\u3044\u65b0\u4eba\u30a8\u30f3\u30b8\u30cb\u30a2<\/li>\n\n\n\n<li>\u4eca\u4f7f\u3063\u3066\u3044\u308b\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u5225\u306e\u3082\u306e\u306b\u5909\u3048\u3088\u3046\u3068\u8003\u3048\u3066\u3044\u308b\u4e2d\u7d1a\u30a8\u30f3\u30b8\u30cb\u30a2<\/li>\n\n\n\n<li>\u30c7\u30b6\u30a4\u30f3\u306b\u3053\u3060\u308f\u3063\u305f\u30b0\u30e9\u30d5\u3092\u63a2\u3057\u3066\u3044\u308bWeb\u30c7\u30b6\u30a4\u30ca\u30fc<\/li>\n<\/ul>\n\n\n\n<p>\u300c\u3069\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u4f7f\u3048\u3070\u3044\u3044\u306e\uff1f\u300d \u3068\u3044\u3046\u7591\u554f\u3092\u89e3\u6c7a\u3067\u304d\u308b\u3088\u3046\u3001\u305d\u308c\u305e\u308c\u306e\u7279\u9577\u3092\u6bd4\u8f03\u3057\u306a\u304c\u3089\u8aac\u660e\u3059\u308b\u306e\u3067\u3001\u305c\u3072\u53c2\u8003\u306b\u3057\u3066\u304f\u3060\u3055\u3044\uff01<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u6563\u5e03\u56f3\u3068\u306f\uff1f<\/h2>\n\n\n\n<p>\u6563\u5e03\u56f3\uff08\u30b9\u30ad\u30e3\u30c3\u30bf\u30fc\u30d7\u30ed\u30c3\u30c8\uff09\u306f\u30012\u3064\u306e\u6570\u5024\u30c7\u30fc\u30bf\u3092XY\u5ea7\u6a19\u4e0a\u306b\u70b9\u3068\u3057\u3066\u30d7\u30ed\u30c3\u30c8\u3057\u3001\u305d\u308c\u3089\u306e\u95a2\u4fc2\u6027\u3092\u8996\u899a\u7684\u306b\u8868\u73fe\u3059\u308b\u30b0\u30e9\u30d5\u3067\u3059\u3002\u30c7\u30fc\u30bf\u306e\u50be\u5411\u3084\u76f8\u95a2\u3092\u5206\u6790\u3059\u308b\u969b\u306b\u5229\u7528\u3055\u308c\u3001\u7d71\u8a08\u89e3\u6790\u3084\u30de\u30fc\u30b1\u30c6\u30a3\u30f3\u30b0\u5206\u6790\u306a\u3069\u5e45\u5e83\u3044\u5206\u91ce\u3067\u6d3b\u7528\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">\u6563\u5e03\u56f3\u306e\u6d3b\u7528\u4f8b<\/h3>\n\n\n\n<p>\u6563\u5e03\u56f3\u306f\u3001\u4ee5\u4e0b\u306e\u3088\u3046\u306a\u30b7\u30fc\u30f3\u3067\u3088\u304f\u4f7f\u308f\u308c\u307e\u3059\u3002<\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u30c7\u30fc\u30bf\u306e\u95a2\u4fc2\u6027\u3092\u8abf\u3079\u308b<\/strong><br>\u30fb\u4f8b\uff1a\u5e83\u544a\u8cbb\u3068\u58f2\u4e0a\u306e\u95a2\u4fc2\u3092\u898b\u308b<br>\u30fb\u4f8b\uff1a\u6c17\u6e29\u3068\u30a2\u30a4\u30b9\u30af\u30ea\u30fc\u30e0\u306e\u58f2\u4e0a\u306e\u95a2\u4fc2\u3092\u8abf\u3079\u308b<\/li>\n\n\n\n<li><strong>\u30c7\u30fc\u30bf\u306e\u5206\u5e03\u3092\u77e5\u308b<\/strong><br>\u30fb\u4f8b\uff1a\u5b66\u751f\u306e\u30c6\u30b9\u30c8\u306e\u70b9\u6570\u5206\u5e03<br>\u30fb\u4f8b\uff1a\u88fd\u54c1\u306e\u4fa1\u683c\u3068\u8ca9\u58f2\u6570\u306e\u95a2\u4fc2<\/li>\n\n\n\n<li><strong>\u7570\u5e38\u5024\uff08\u5916\u308c\u5024\uff09\u3092\u767a\u898b\u3059\u308b<\/strong><br>\u30fb\u4f8b\uff1a\u5de5\u5834\u306e\u54c1\u8cea\u7ba1\u7406\u3067\u3001\u4e0d\u826f\u54c1\u306e\u767a\u751f\u30d1\u30bf\u30fc\u30f3\u3092\u63a2\u3059<br>\u30fb\u4f8b\uff1a\u9867\u5ba2\u306e\u8cfc\u8cb7\u30c7\u30fc\u30bf\u304b\u3089\u7279\u7570\u306a\u884c\u52d5\u3092\u3059\u308b\u30e6\u30fc\u30b6\u30fc\u3092\u898b\u3064\u3051\u308b<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">\u6563\u5e03\u56f3\u306e\u7a2e\u985e<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u57fa\u672c\u306e\u6563\u5e03\u56f3<\/strong>\uff1a2\u3064\u306e\u6570\u5024\u30c7\u30fc\u30bf\u3092XY\u5ea7\u6a19\u4e0a\u306b\u30d7\u30ed\u30c3\u30c8\u3059\u308b\u30b7\u30f3\u30d7\u30eb\u306a\u5f62\u5f0f\u3002<\/li>\n\n\n\n<li><strong>\u30d0\u30d6\u30eb\u30c1\u30e3\u30fc\u30c8<\/strong>\uff1a\u30c7\u30fc\u30bf\u70b9\u306e\u5927\u304d\u3055\u3092\u5909\u3048\u3066\u3001\u3082\u30461\u3064\u306e\u30c7\u30fc\u30bf\u8981\u7d20\u3092\u8ffd\u52a0\u3002<\/li>\n\n\n\n<li><strong>\u8272\u4ed8\u304d\u6563\u5e03\u56f3<\/strong>\uff1a\u70b9\u306e\u8272\u3092\u5909\u3048\u308b\u3053\u3068\u3067\u3001\u30c7\u30fc\u30bf\u306e\u30b0\u30eb\u30fc\u30d7\u3092\u533a\u5225\u3002<\/li>\n\n\n\n<li><strong>\u56de\u5e30\u7dda\u4ed8\u304d\u6563\u5e03\u56f3<\/strong>\uff1a\u30c7\u30fc\u30bf\u306e\u50be\u5411\u3092\u793a\u3059\u76f4\u7dda\uff08\u56de\u5e30\u7dda\uff09\u3092\u8ffd\u52a0\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">\u6563\u5e03\u56f3\u306e\u30e1\u30ea\u30c3\u30c8\u30fb\u30c7\u30e1\u30ea\u30c3\u30c8<\/h3>\n\n\n\n<p><strong>\u30e1\u30ea\u30c3\u30c8<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u30c7\u30fc\u30bf\u306e\u95a2\u4fc2\u6027\u304c\u4e00\u76ee\u3067\u308f\u304b\u308b<\/strong>\uff1a\u70b9\u306e\u4e26\u3073\u65b9\u3067\u3001\u30c7\u30fc\u30bf\u540c\u58eb\u306e\u95a2\u9023\u304c\u76f4\u611f\u7684\u306b\u898b\u3048\u308b\u3002<\/li>\n\n\n\n<li><strong>\u30c7\u30fc\u30bf\u306e\u5206\u5e03\u3092\u628a\u63e1\u3057\u3084\u3059\u3044<\/strong>\uff1a\u70b9\u306e\u5bc6\u96c6\u5177\u5408\u3067\u3001\u3069\u3053\u306b\u30c7\u30fc\u30bf\u304c\u591a\u3044\u304b\u304c\u308f\u304b\u308b\u3002<\/li>\n\n\n\n<li><strong>\u7570\u5e38\u5024\u3092\u3059\u3050\u306b\u767a\u898b\u3067\u304d\u308b<\/strong>\uff1a\u4ed6\u306e\u70b9\u3068\u96e2\u308c\u3066\u3044\u308b\u30c7\u30fc\u30bf\u304c\u3059\u3050\u306b\u76ee\u306b\u3064\u304f\u3002<\/li>\n<\/ul>\n\n\n\n<p><strong>\u30c7\u30e1\u30ea\u30c3\u30c8<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u30c7\u30fc\u30bf\u304c\u591a\u3059\u304e\u308b\u3068\u898b\u3065\u3089\u304f\u306a\u308b<\/strong>\uff1a\u70b9\u304c\u5bc6\u96c6\u3059\u308b\u3068\u3001\u500b\u3005\u306e\u30c7\u30fc\u30bf\u3092\u5224\u5225\u3057\u306b\u304f\u304f\u306a\u308b\u3002<\/li>\n\n\n\n<li><strong>\u56e0\u679c\u95a2\u4fc2\u306f\u5224\u65ad\u3067\u304d\u306a\u3044<\/strong>\uff1a\u30c7\u30fc\u30bf\u306e\u76f8\u95a2\u306f\u308f\u304b\u308b\u304c\u3001\u3069\u3061\u3089\u304c\u539f\u56e0\u3067\u3069\u3061\u3089\u304c\u7d50\u679c\u304b\u306f\u5224\u65ad\u3067\u304d\u306a\u3044\u3002<\/li>\n\n\n\n<li><strong>\u30ab\u30c6\u30b4\u30ea\u30fc\u3054\u3068\u306e\u6bd4\u8f03\u306b\u306f\u5411\u304b\u306a\u3044<\/strong>\uff1a\u68d2\u30b0\u30e9\u30d5\u3084\u5186\u30b0\u30e9\u30d5\u306e\u3088\u3046\u306b\u3001\u30b0\u30eb\u30fc\u30d7\u3054\u3068\u306e\u30c7\u30fc\u30bf\u6bd4\u8f03\u306f\u3057\u3065\u3089\u3044\u3002<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">JavaScript\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u9078\u3076\u969b\u306e\u30c1\u30a7\u30c3\u30af\u30dd\u30a4\u30f3\u30c8<\/h2>\n\n\n\n<p>\u30b0\u30e9\u30d5\u3092Web\u30b5\u30a4\u30c8\u306b\u8868\u793a\u3059\u308b\u305f\u3081\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u306f\u6570\u591a\u304f\u3042\u308a\u307e\u3059\u304c\u3001\u9078\u3073\u65b9\u3092\u9593\u9055\u3048\u308b\u3068\u4f7f\u3044\u3065\u3089\u304b\u3063\u305f\u308a\u3001\u76ee\u7684\u306b\u5408\u308f\u306a\u304b\u3063\u305f\u308a\u3059\u308b\u3053\u3068\u304c\u3042\u308a\u307e\u3059\u3002\u30e9\u30a4\u30d6\u30e9\u30ea\u9078\u5b9a\u306e\u969b\u306b\u306f\u4e0b\u8a186\u3064\u306e\u30dd\u30a4\u30f3\u30c8\u3092\u30c1\u30a7\u30c3\u30af\u3059\u308b\u3053\u3068\u3092\u304a\u3059\u3059\u3081\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u5c0e\u5165\u306e\u3057\u3084\u3059\u3055<\/strong><br>\u521d\u5fc3\u8005\u3067\u3082\u3059\u3050\u306b\u4f7f\u3048\u308b\u304b\u3069\u3046\u304b\u306f\u91cd\u8981\u3067\u3059\u3002CDN\u3092\u4f7f\u3063\u3066\u7c21\u5358\u306b\u8aad\u307f\u8fbc\u3081\u308b\u3082\u306e\u3084\u3001\u8a2d\u5b9a\u304c\u5c11\u306a\u304f\u3066\u3082\u52d5\u4f5c\u3059\u308b\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u9078\u3076\u3068\u3088\u3044\u3067\u3057\u3087\u3046\u3002<\/li>\n\n\n\n<li><strong>\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u6027<\/strong><br>\u30c7\u30b6\u30a4\u30f3\u3084\u8272\u3001\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u306a\u3069\u3092\u67d4\u8edf\u306b\u5909\u66f4\u3067\u304d\u308b\u304b\u3092\u78ba\u8a8d\u3057\u307e\u3057\u3087\u3046\u3002\u30d6\u30e9\u30f3\u30c9\u3084\u30c7\u30b6\u30a4\u30f3\u30c6\u30fc\u30de\u306b\u5408\u308f\u305b\u305f\u8abf\u6574\u304c\u5fc5\u8981\u306a\u5834\u5408\u306f\u3001\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u6027\u306e\u9ad8\u3044\u3082\u306e\u304c\u304a\u3059\u3059\u3081\u3067\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30ec\u30b9\u30dd\u30f3\u30b7\u30d6\u5bfe\u5fdc<\/strong><br>\u30b9\u30de\u30db\u3084\u30bf\u30d6\u30ec\u30c3\u30c8\u306a\u3069\u3001\u753b\u9762\u30b5\u30a4\u30ba\u304c\u7570\u306a\u308b\u30c7\u30d0\u30a4\u30b9\u3067\u3082\u304d\u308c\u3044\u306b\u8868\u793a\u3055\u308c\u308b\u304b\u3092\u30c1\u30a7\u30c3\u30af\u3057\u307e\u3057\u3087\u3046\u3002\u7279\u306b\u3001\u30d3\u30b8\u30cd\u30b9\u30b5\u30a4\u30c8\u3067\u306f\u30e2\u30d0\u30a4\u30eb\u5bfe\u5fdc\u304c\u91cd\u8981\u3067\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9<\/strong><br>\u8868\u73fe\u3059\u308b\u30b0\u30e9\u30d5\u306b\u3082\u3088\u308a\u307e\u3059\u304c\u3001\u5927\u898f\u6a21\u30c7\u30fc\u30bf\u3092\u6271\u3046\u5834\u5408\u3001\u8868\u793a\u901f\u5ea6\u3084\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3082\u6c17\u306b\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u7279\u306b\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u30c7\u30fc\u30bf\u3092\u8868\u793a\u3059\u308b\u7528\u9014\u3067\u306f\u3001\u8efd\u91cf\u3067\u9ad8\u901f\u306a\u30e9\u30a4\u30d6\u30e9\u30ea\u304c\u6c42\u3081\u3089\u308c\u307e\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30b5\u30dd\u30fc\u30c8\u3068\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8<\/strong><br>\u516c\u5f0f\u30b5\u30a4\u30c8\u3084GitHub\u3067\u306e\u30b5\u30dd\u30fc\u30c8\u72b6\u6cc1\u3084\u3001\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306e\u5145\u5b9f\u5ea6\u3092\u78ba\u8a8d\u3057\u307e\u3057\u3087\u3046\u3002\u4f7f\u3044\u65b9\u304c\u308f\u304b\u3089\u306a\u3044\u3068\u304d\u306b\u53c2\u8003\u306b\u306a\u308b\u60c5\u5831\u304c\u3042\u308b\u304b\u3069\u3046\u304b\u306f\u91cd\u8981\u3067\u3059\u3002<\/li>\n\n\n\n<li><strong>\u30e9\u30a4\u30bb\u30f3\u30b9\u3068\u5229\u7528\u6599<\/strong><br>\u5229\u7528\u898f\u7d04\u3084\u30e9\u30a4\u30bb\u30f3\u30b9\u5f62\u614b\u3082\u78ba\u8a8d\u3057\u3066\u304a\u304d\u307e\u3057\u3087\u3046\u3002\u5546\u7528\u5229\u7528\u304c\u53ef\u80fd\u304b\u3069\u3046\u304b\u3001\u7121\u6599\u3067\u4f7f\u3048\u308b\u304b\u3001\u6709\u6599\u30d7\u30e9\u30f3\u304c\u5fc5\u8981\u304b\u306a\u3069\u3092\u4e8b\u524d\u306b\u30c1\u30a7\u30c3\u30af\u3059\u308b\u3053\u3068\u304c\u5927\u5207\u3067\u3059\u3002<br><\/li>\n<\/ol>\n\n\n\n<div style=\"height:100px\" aria-hidden=\"true\" class=\"wp-block-spacer\"><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">\u304a\u3059\u3059\u3081\u30e9\u30a4\u30d6\u30e9\u30ea\u7d39\u4ecb<\/h2>\n\n\n\n<p>\u6563\u5e03\u56f3\u3092Web\u30b5\u30a4\u30c8\u3067\u8868\u793a\u3059\u308b\u305f\u3081\u306b\u3001\u3055\u307e\u3056\u307e\u306aJavaScript\u30e9\u30a4\u30d6\u30e9\u30ea\u304c\u5229\u7528\u3067\u304d\u307e\u3059\u3002\u3053\u3053\u3067\u306f\u3001\u7279\u306b\u304a\u3059\u3059\u3081\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u7d39\u4ecb\u3057\u307e\u3059\u3002<\/p>\n\n\n\n<h3 class=\"wp-block-heading\">1 Chart.js<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u516c\u5f0fURL<\/strong>: <a href=\"https:\/\/www.chartjs.org\/\" title=\"https:\/\/www.chartjs.org\/\">https:\/\/www.chartjs.org\/<\/a><\/li>\n\n\n\n<li><strong>\u7279\u5fb4<\/strong>\uff1a\u8efd\u91cf\u3067\u30b7\u30f3\u30d7\u30eb\u306aAPI\u3092\u6301\u3061\u3001\u521d\u5fc3\u8005\u3067\u3082\u6271\u3044\u3084\u3059\u3044\u3002\u6563\u5e03\u56f3\u3082\u6a19\u6e96\u3067\u30b5\u30dd\u30fc\u30c8\u3055\u308c\u3066\u304a\u308a\u3001\u8a2d\u5b9a\u304c\u30b7\u30f3\u30d7\u30eb\u3002HTML5 Canvas \u30d9\u30fc\u30b9\u3067\u52d5\u4f5c\u3057\u3001\u30ec\u30b9\u30dd\u30f3\u30b7\u30d6\u30c7\u30b6\u30a4\u30f3\u306b\u5bfe\u5fdc\u3057\u3066\u3044\u308b\u3002\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306e\u5e45\u304c\u5e83\u304f\u3001\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u7f8e\u3057\u3044\u30c7\u30b6\u30a4\u30f3\u304c\u63d0\u4f9b\u3055\u308c\u3066\u3044\u308b\u305f\u3081\u3001\u30b9\u30bf\u30a4\u30ea\u30f3\u30b0\u306e\u624b\u9593\u3092\u7701\u3051\u308b\u3002<\/li>\n\n\n\n<li><strong>\u30e1\u30ea\u30c3\u30c8<\/strong><br>\u30fb\u5c0e\u5165\u304c\u7c21\u5358\u3067\u3001\u5c11\u306a\u3044\u30b3\u30fc\u30c9\u3067\u6563\u5e03\u56f3\u3092\u63cf\u753b\u3067\u304d\u308b\u3002<br>\u30fb\u30ec\u30b9\u30dd\u30f3\u30b7\u30d6\u5bfe\u5fdc\u3067\u3001\u753b\u9762\u30b5\u30a4\u30ba\u306b\u5fdc\u3058\u305f\u8abf\u6574\u304c\u81ea\u52d5\u3067\u884c\u308f\u308c\u308b\u3002<br>\u30fb\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u6027\u304c\u9ad8\u304f\u3001\u30c7\u30b6\u30a4\u30f3\u306e\u8abf\u6574\u304c\u5bb9\u6613\u3002<\/li>\n\n\n\n<li><strong>\u30c7\u30e1\u30ea\u30c3\u30c8<\/strong><br>\u30fb\u9ad8\u5ea6\u306a\u30c7\u30fc\u30bf\u51e6\u7406\u3084\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u306b\u306f\u5236\u9650\u304c\u3042\u308b\u3002<br>\u30fb\u5927\u898f\u6a21\u30c7\u30fc\u30bf\u306e\u63cf\u753b\u306b\u306f\u5411\u304b\u306a\u3044\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">2 D3.js<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u516c\u5f0fURL<\/strong>: <a href=\"https:\/\/d3js.org\/\" title=\"\">https:\/\/d3js.org\/<\/a><\/li>\n\n\n\n<li><strong>\u7279\u5fb4<\/strong>\uff1a\u30c7\u30fc\u30bf\u99c6\u52d5\u578b\u306e\u5f37\u529b\u306a\u53ef\u8996\u5316\u30e9\u30a4\u30d6\u30e9\u30ea\u3002SVG\u3084Canvas\u3092\u6d3b\u7528\u3057\u3066\u52d5\u7684\u306a\u30c7\u30fc\u30bf\u306e\u63cf\u753b\u304c\u53ef\u80fd\u3067\u3001\u81ea\u7531\u5ea6\u304c\u975e\u5e38\u306b\u9ad8\u3044\u3002\u6563\u5e03\u56f3\u306e\u30c7\u30fc\u30bf\u30dd\u30a4\u30f3\u30c8\u306b\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u3084\u30ab\u30b9\u30bf\u30e0\u30b9\u30bf\u30a4\u30eb\u3092\u9069\u7528\u3067\u304d\u308b\u305f\u3081\u3001\u8996\u899a\u7684\u306b\u30ea\u30c3\u30c1\u306a\u30b0\u30e9\u30d5\u304c\u4f5c\u6210\u3067\u304d\u308b\u3002\u305f\u3060\u3057\u3001\u57fa\u672c\u7684\u306a\u6563\u5e03\u56f3\u306e\u4f5c\u6210\u306b\u3082\u3042\u308b\u7a0b\u5ea6\u306e\u30b3\u30fc\u30c7\u30a3\u30f3\u30b0\u304c\u5fc5\u8981\u3002<\/li>\n\n\n\n<li><strong>\u30e1\u30ea\u30c3\u30c8<\/strong><br>\u30fb\u30c7\u30fc\u30bf\u306b\u5fdc\u3058\u305f\u52d5\u7684\u306a\u6563\u5e03\u56f3\u306e\u63cf\u753b\u304c\u53ef\u80fd\u3002<br>\u30fb\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306e\u5e45\u304c\u5e83\u304f\u3001\u3042\u3089\u3086\u308b\u7a2e\u985e\u306e\u30c7\u30fc\u30bf\u53ef\u8996\u5316\u304c\u53ef\u80fd\u3002<br>\u30fb\u5927\u898f\u6a21\u30c7\u30fc\u30bf\u306e\u51e6\u7406\u80fd\u529b\u304c\u9ad8\u3044\u3002<\/li>\n\n\n\n<li><strong>\u30c7\u30e1\u30ea\u30c3\u30c8<\/strong><br>\u30fb\u521d\u5fc3\u8005\u306b\u306f\u5b66\u7fd2\u30b3\u30b9\u30c8\u304c\u9ad8\u3044\u3002<br>\u30fb\u30ec\u30b9\u30dd\u30f3\u30b7\u30d6\u5bfe\u5fdc\u306f\u81ea\u5206\u3067\u5b9f\u88c5\u3059\u308b\u5fc5\u8981\u304c\u3042\u308b\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">3 ApexCharts<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u516c\u5f0fURL<\/strong>: <a href=\"https:\/\/apexcharts.com\/\">https:\/\/apexcharts.com\/<\/a><\/li>\n\n\n\n<li><strong>\u7279\u5fb4<\/strong>\uff1a\u7f8e\u3057\u3044\u30c7\u30b6\u30a4\u30f3\u3068\u4f7f\u3044\u3084\u3059\u3055\u3092\u4e21\u7acb\u3057\u305f\u30b0\u30e9\u30d5\u30e9\u30a4\u30d6\u30e9\u30ea\u3002\u6563\u5e03\u56f3\u306e\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306a\u8868\u73fe\u304c\u5f97\u610f\u3067\u3001\u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u3084\u30c7\u30fc\u30bf\u30dd\u30a4\u30f3\u30c8\u306e\u30db\u30d0\u30fc\u30a8\u30d5\u30a7\u30af\u30c8\u304c\u6a19\u6e96\u642d\u8f09\u3055\u308c\u3066\u3044\u308b\u3002Canvas \u30d9\u30fc\u30b9\u3067\u30b9\u30e0\u30fc\u30ba\u306a\u63cf\u753b\u304c\u53ef\u80fd\u3067\u3042\u308a\u3001\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u30c7\u30fc\u30bf\u306e\u66f4\u65b0\u306b\u3082\u5bfe\u5fdc\u3002\u7279\u306b\u3001\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u306e\u6d17\u7df4\u3055\u308c\u305f\u52d5\u304d\u304c\u7279\u5fb4\u3002<\/li>\n\n\n\n<li><strong>\u30e1\u30ea\u30c3\u30c8<\/strong><br>\u30fb\u76f4\u611f\u7684\u306aAPI\u8a2d\u8a08\u3067\u3001\u5c0e\u5165\u304c\u7c21\u5358\u3002<br>\u30fb\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306a\u6563\u5e03\u56f3\u3092\u4f5c\u6210\u3067\u304d\u308b\u3002<br>\u30fb\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u30c7\u30fc\u30bf\u306e\u53ef\u8996\u5316\u306b\u3082\u5bfe\u5fdc\u3002<\/li>\n\n\n\n<li><strong>\u30c7\u30e1\u30ea\u30c3\u30c8<\/strong><br>\u30fb\u9ad8\u5ea6\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306b\u306f\u5236\u9650\u304c\u3042\u308b\u3002<br>\u30fbD3.js\u307b\u3069\u306e\u81ea\u7531\u5ea6\u306f\u306a\u3044\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">4 Plotly.js<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u516c\u5f0fURL<\/strong>: <a href=\"https:\/\/plotly.com\/javascript\/\">https:\/\/plotly.com\/javascript\/<\/a><\/li>\n\n\n\n<li><strong>\u7279\u5fb4<\/strong>\uff1a\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306a\u30b0\u30e9\u30d5\u4f5c\u6210\u306b\u7279\u5316\u3057\u305f\u30e9\u30a4\u30d6\u30e9\u30ea\u3067\u3001\u6563\u5e03\u56f3\u306b\u95a2\u3057\u3066\u3082\u8c4a\u5bcc\u306a\u6a5f\u80fd\u3092\u5099\u3048\u3066\u3044\u308b\u3002\u30c7\u30fc\u30bf\u30dd\u30a4\u30f3\u30c8\u306e\u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u8868\u793a\u3084\u30c9\u30e9\u30c3\u30b0\u306b\u3088\u308b\u30ba\u30fc\u30e0\u6a5f\u80fd\u304c\u6a19\u6e96\u3067\u30b5\u30dd\u30fc\u30c8\u3055\u308c\u3066\u304a\u308a\u3001\u63a2\u7d22\u7684\u30c7\u30fc\u30bf\u5206\u6790\u306b\u3082\u9069\u3057\u3066\u3044\u308b\u3002WebGL \u3092\u5229\u7528\u3057\u305f 3D\u6563\u5e03\u56f3\u3082\u4f5c\u6210\u53ef\u80fd\u3067\u3001Python\u306a\u3069\u306e\u4ed6\u306e\u8a00\u8a9e\u3068\u3082\u7d71\u5408\u3067\u304d\u308b\u70b9\u304c\u5f37\u307f\u3002<\/li>\n\n\n\n<li><strong>\u30e1\u30ea\u30c3\u30c8<\/strong><br>\u30fb\u6563\u5e03\u56f3\u306e\u30ba\u30fc\u30e0\u3084\u30db\u30d0\u30fc\u6642\u306e\u8a73\u7d30\u8868\u793a\u304c\u53ef\u80fd\u3002<br>\u30fbPython\u306a\u3069\u4ed6\u306e\u8a00\u8a9e\u3068\u306e\u4e92\u63db\u6027\u304c\u3042\u308b\u3002<br>\u30fb3D\u6563\u5e03\u56f3\u306e\u63cf\u753b\u3082\u53ef\u80fd\u3002<\/li>\n\n\n\n<li><strong>\u30c7\u30e1\u30ea\u30c3\u30c8<\/strong><br>\u30fb\u4ed6\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u306b\u6bd4\u3079\u308b\u3068\u30d5\u30a1\u30a4\u30eb\u30b5\u30a4\u30ba\u304c\u5927\u304d\u3044\u3002<br>\u30fb\u5927\u898f\u6a21\u30c7\u30fc\u30bf\u3067\u306f\u3084\u3084\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u304c\u4f4e\u4e0b\u3059\u308b\u3002<\/li>\n<\/ul>\n\n\n\n<h3 class=\"wp-block-heading\">5 ECharts<\/h3>\n\n\n\n<ul class=\"wp-block-list\">\n<li><strong>\u516c\u5f0fURL<\/strong>: <a href=\"https:\/\/echarts.apache.org\/\" title=\"\">https:\/\/echarts.apache.org\/<\/a><\/li>\n\n\n\n<li><strong>\u7279\u5fb4<\/strong>\uff1a\u5927\u898f\u6a21\u30c7\u30fc\u30bf\u5411\u3051\u306b\u6700\u9069\u5316\u3055\u308c\u305f\u30d1\u30ef\u30d5\u30eb\u306a\u53ef\u8996\u5316\u30e9\u30a4\u30d6\u30e9\u30ea\u3002WebGL \u3092\u6d3b\u7528\u3057\u3066\u304a\u308a\u3001\u5927\u91cf\u306e\u30c7\u30fc\u30bf\u30dd\u30a4\u30f3\u30c8\u3092\u9ad8\u901f\u306b\u63cf\u753b\u3067\u304d\u308b\u3002\u6563\u5e03\u56f3\u306b\u95a2\u3057\u3066\u3082\u3001\u30d0\u30d6\u30eb\u30c1\u30e3\u30fc\u30c8\u3084\u56de\u5e30\u5206\u6790\u3068\u7d44\u307f\u5408\u308f\u305b\u305f\u9ad8\u5ea6\u306a\u53ef\u8996\u5316\u304c\u53ef\u80fd\u3002\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u6a5f\u80fd\u304c\u8c4a\u5bcc\u3067\u3001\u30c7\u30fc\u30bf\u30d5\u30a3\u30eb\u30bf\u30ea\u30f3\u30b0\u3084\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u4ed8\u304d\u306e\u30c8\u30e9\u30f3\u30b8\u30b7\u30e7\u30f3\u306a\u3069\u304c\u5229\u7528\u3067\u304d\u308b\u70b9\u304c\u7279\u5fb4\u3002<\/li>\n\n\n\n<li><strong>\u30e1\u30ea\u30c3\u30c8<\/strong><br>\u30fb\u6563\u5e03\u56f3\u306e\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u3084\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u8981\u7d20\u304c\u8c4a\u5bcc\u3002<br>\u30fb\u9ad8\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9\u3067\u3001\u5927\u91cf\u306e\u30c7\u30fc\u30bf\u30dd\u30a4\u30f3\u30c8\u3092\u51e6\u7406\u53ef\u80fd\u3002<br>\u30fb\u30d0\u30d6\u30eb\u30c1\u30e3\u30fc\u30c8\u3084\u56de\u5e30\u5206\u6790\u306e\u30b5\u30dd\u30fc\u30c8\u3082\u5145\u5b9f\u3002<\/li>\n\n\n\n<li><strong>\u30c7\u30e1\u30ea\u30c3\u30c8<\/strong><br>\u30fb\u8a2d\u5b9a\u30aa\u30d7\u30b7\u30e7\u30f3\u304c\u591a\u3044\u305f\u3081\u3001\u521d\u5fc3\u8005\u306b\u306f\u3084\u3084\u8907\u96d1\u3002<br>\u30fb\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u306e\u4e00\u90e8\u304c\u4e2d\u56fd\u8a9e\u3067\u63d0\u4f9b\u3055\u308c\u3066\u3044\u308b\u305f\u3081\u3001\u82f1\u8a9e\u306e\u60c5\u5831\u304c\u4e0d\u8db3\u3059\u308b\u3053\u3068\u304c\u3042\u308b\u3002<\/li>\n<\/ul>\n\n\n\n<h2 class=\"wp-block-heading\">\u30e9\u30a4\u30d6\u30e9\u30ea\u6bd4\u8f03\u8868<\/h2>\n\n\n\n<p>\u524d\u8ff0\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u9078\u5b9a\u30dd\u30a4\u30f3\u30c8\u3092\u307e\u3068\u3081\u305f\u8868\u306f\u4e0b\u8a18\u306e\u3068\u304a\u308a<\/p>\n\n\n\n<figure class=\"wp-block-table is-style-stripes\"><table><thead><tr><th>\u540d\u79f0<\/th><th>\u5c0e\u5165\u306e\u3057\u3084\u3059\u3055<\/th><th>\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u6027<\/th><th>\u30ec\u30b9\u30dd\u30f3\u30b7\u30d6\u5bfe\u5fdc<\/th><th>\u30d1\u30d5\u30a9\u30fc\u30de\u30f3\u30b9<\/th><th>\u30b5\u30dd\u30fc\u30c8\u3068\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8<\/th><th>\u30e9\u30a4\u30bb\u30f3\u30b9<\/th><\/tr><\/thead><tbody><tr><td>Chart.js<\/td><td>\u7c21\u5358<\/td><td>\u4e2d\u7a0b\u5ea6<\/td><td>\u6a19\u6e96\u5bfe\u5fdc<\/td><td>\u8efd\u91cf\u30fb\u9ad8\u901f<\/td><td>\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u5145\u5b9f<br>\u30b5\u30f3\u30d7\u30eb\u591a\u6570<\/td><td>MIT\u30e9\u30a4\u30bb\u30f3\u30b9<\/td><\/tr><tr><td>D3.js<\/td><td>\u96e3\u3057\u3044<\/td><td>\u975e\u5e38\u306b\u9ad8\u3044<\/td><td>\u624b\u52d5\u5bfe\u5fdc<\/td><td>\u5927\u898f\u6a21\u30c7\u30fc\u30bf\u5bfe\u5fdc\u53ef\u80fd<\/td><td>\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u304c\u8a73\u7d30<br>\u5b66\u7fd2\u30b3\u30b9\u30c8\u304c\u9ad8\u3081<\/td><td>BSD\u30e9\u30a4\u30bb\u30f3\u30b9<\/td><\/tr><tr><td>ApexCharts<\/td><td>\u7c21\u5358<\/td><td>\u9ad8\u3044<\/td><td>\u6a19\u6e96\u5bfe\u5fdc<\/td><td>\u9ad8\u901f\u30fb\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u5bfe\u5fdc<\/td><td>\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u304c\u5206\u304b\u308a\u3084\u3059\u304f\u3001\u30b5\u30f3\u30d7\u30eb\u3082\u8c4a\u5bcc<\/td><td>MIT\u30e9\u30a4\u30bb\u30f3\u30b9<\/td><\/tr><tr><td>Plotly.js<\/td><td>\u666e\u901a<\/td><td>\u9ad8\u3044<\/td><td>\u6a19\u6e96\u5bfe\u5fdc<\/td><td>\u30c7\u30fc\u30bf\u91cf\u304c\u5897\u3048\u308b\u3068\u3084\u3084\u8ca0\u8377<\/td><td>\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u304c\u8a73\u3057\u304f\u3001Python\u7248\u3068\u306e\u4e92\u63db\u6027\u3082\u3042\u308a<\/td><td>MIT\u30e9\u30a4\u30bb\u30f3\u30b9<\/td><\/tr><tr><td>ECharts<\/td><td>\u666e\u901a<\/td><td>\u975e\u5e38\u306b\u9ad8\u3044<\/td><td>\u6a19\u6e96\u5bfe\u5fdc<\/td><td>\u5927\u898f\u6a21\u30c7\u30fc\u30bf\u3068\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u66f4\u65b0\u306b\u6700\u9069<\/td><td>\u516c\u5f0f\u30c9\u30ad\u30e5\u30e1\u30f3\u30c8\u304c\u8a73\u7d30\u3060\u304c\u3001\u4e00\u90e8\u4e2d\u56fd\u8a9e\u30d9\u30fc\u30b9<\/td><td>Apache 2.0<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<p>\u5404\u30e9\u30a4\u30d6\u30e9\u30ea\u306b\u306f\u305d\u308c\u305e\u308c\u7279\u9577\u304c\u3042\u308a\u3001\u7528\u9014\u306b\u3088\u3063\u3066\u9069\u3057\u305f\u3082\u306e\u3092\u9078\u3076\u3053\u3068\u304c\u91cd\u8981\u3067\u3059\u3002\u4f8b\u3048\u3070\u3001<strong>\u624b\u8efd\u306b\u5b9f\u88c5\u3057\u305f\u3044\u306a\u3089 Chart.js \u3084 ApexCharts\u3001\u5927\u898f\u6a21\u30c7\u30fc\u30bf\u306e\u53ef\u8996\u5316\u306a\u3089 ECharts\u3001\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306a\u6a5f\u80fd\u3092\u6d3b\u7528\u3059\u308b\u306a\u3089 Plotly.js\u3001\u81ea\u7531\u306a\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u3092\u6c42\u3081\u308b\u306a\u3089 D3.js<\/strong> \u3068\u3044\u3063\u305f\u9078\u629e\u304c\u53ef\u80fd\u3067\u3059\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u30b5\u30f3\u30d7\u30eb\u30c7\u30fc\u30bf\u3092\u4f7f\u3063\u305f\u5c0e\u5165\u4f8b<\/h2>\n\n\n\n<p>\u4eca\u56de\u7d39\u4ecb\u3057\u305f\u5404\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u4f7f\u3063\u3066\u3001\u540c\u3058\u6761\u4ef6\u306e\u30b5\u30f3\u30d7\u30eb\u30c7\u30fc\u30bf\u304b\u3089\u30ec\u30fc\u30c0\u30fc\u30c1\u30e3\u30fc\u30c8\u3092\u8868\u793a\u3059\u308b\u624b\u9806\u3092\u4f5c\u6210\u3057\u3066\u307f\u307e\u3057\u305f\u3002\u305d\u308c\u305e\u308c\u306e\u7279\u5fb4\u3092\u6d3b\u304b\u3057\u305f\u30aa\u30d7\u30b7\u30e7\u30f3\u3082\u3064\u3051\u3066\u307f\u305f\u306e\u3067\u53c2\u8003\u306b\u3057\u3066\u304f\u3060\u3055\u3044\u306d\u3002<\/p>\n\n\n\n<div class=\"wp-block-group has-background\" style=\"background-color:#fbecec\"><div class=\"wp-block-group__inner-container is-layout-constrained wp-block-group-is-layout-constrained\">\n<h3 class=\"wp-block-heading has-text-align-center has-background\" style=\"background-color:#fbecec\">\u30b5\u30f3\u30d7\u30eb\u30c7\u30fc\u30bf\uff1a\u30e6\u30fc\u30b6\u30fc\u306e\u5e74\u9f62\u3068\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593\u306e\u95a2\u4fc2<\/h3>\n\n\n\n<figure class=\"wp-block-table\"><table class=\"has-fixed-layout\"><thead><tr><th class=\"has-text-align-center\" data-align=\"center\">\u30e6\u30fc\u30b6\u30fcID<\/th><th class=\"has-text-align-center\" data-align=\"center\">\u5e74\u9f62<\/th><th class=\"has-text-align-center\" data-align=\"center\">\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593(\u5206)<\/th><th class=\"has-text-align-center\" data-align=\"center\">\u5099\u8003<\/th><\/tr><\/thead><tbody><tr><td class=\"has-text-align-center\" data-align=\"center\">U001<\/td><td class=\"has-text-align-center\" data-align=\"center\">22<\/td><td class=\"has-text-align-center\" data-align=\"center\">3.5<\/td><td class=\"has-text-align-center\" data-align=\"center\">\u521d\u56de\u8a2a\u554f<\/td><\/tr><tr><td class=\"has-text-align-center\" data-align=\"center\">U002<\/td><td class=\"has-text-align-center\" data-align=\"center\">35<\/td><td class=\"has-text-align-center\" data-align=\"center\">8.0<\/td><td class=\"has-text-align-center\" data-align=\"center\">\u5e38\u9023\u30e6\u30fc\u30b6\u30fc<\/td><\/tr><tr><td class=\"has-text-align-center\" data-align=\"center\">U003<\/td><td class=\"has-text-align-center\" data-align=\"center\">28<\/td><td class=\"has-text-align-center\" data-align=\"center\">5.5<\/td><td class=\"has-text-align-center\" data-align=\"center\">&#8211;<\/td><\/tr><tr><td class=\"has-text-align-center\" data-align=\"center\">U004<\/td><td class=\"has-text-align-center\" data-align=\"center\">45<\/td><td class=\"has-text-align-center\" data-align=\"center\">12.0<\/td><td class=\"has-text-align-center\" data-align=\"center\">\u8cfc\u5165\u3042\u308a<\/td><\/tr><tr><td class=\"has-text-align-center\" data-align=\"center\">U005<\/td><td class=\"has-text-align-center\" data-align=\"center\">31<\/td><td class=\"has-text-align-center\" data-align=\"center\">7.2<\/td><td class=\"has-text-align-center\" data-align=\"center\">&#8211;<\/td><\/tr><tr><td class=\"has-text-align-center\" data-align=\"center\">U006<\/td><td class=\"has-text-align-center\" data-align=\"center\">27<\/td><td class=\"has-text-align-center\" data-align=\"center\">4.8<\/td><td class=\"has-text-align-center\" data-align=\"center\">&#8211;<\/td><\/tr><tr><td class=\"has-text-align-center\" data-align=\"center\">U007<\/td><td class=\"has-text-align-center\" data-align=\"center\">40<\/td><td class=\"has-text-align-center\" data-align=\"center\">9.1<\/td><td class=\"has-text-align-center\" data-align=\"center\">\u8cfc\u5165\u3042\u308a<\/td><\/tr><tr><td class=\"has-text-align-center\" data-align=\"center\">U008<\/td><td class=\"has-text-align-center\" data-align=\"center\">23<\/td><td class=\"has-text-align-center\" data-align=\"center\">3.8<\/td><td class=\"has-text-align-center\" data-align=\"center\">\u521d\u56de\u8a2a\u554f<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<p class=\"has-text-align-center\"><\/p>\n<\/div><\/div>\n\n\n\n<p>\u3053\u306e\u30b5\u30f3\u30d7\u30eb\u30c7\u30fc\u30bf\u306f\u3001\u30a6\u30a7\u30d6\u30b5\u30a4\u30c8\u306e\u30e6\u30fc\u30b6\u30fc\u306e\u5e74\u9f62\u3068\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593\u306e\u95a2\u4fc2\u6027\u3092\u8996\u899a\u7684\u306b\u628a\u63e1\u3059\u308b\u305f\u3081\u306b\u5229\u7528\u3067\u304d\u307e\u3059\u3002<\/p>\n\n\n\n<p>\u4eca\u56de\u306f\u3001\u3053\u306e\u30c7\u30fc\u30bf\u3092\u4e0b\u8a18\u306e\u3088\u3046\u306a\u3001\u5171\u901a\u306eJSON\u30c7\u30fc\u30bf\u3068\u3057\u3066\u6271\u3063\u3066\u3044\u304d\u307e\u3059\u3002<br>\uff08\u305d\u306e\u305f\u3081\u3001\u5404\u30e9\u30a4\u30d6\u30e9\u30ea\u306e\u30b3\u30fc\u30c9\u90e8\u3067\u306f\u30c7\u30fc\u30bf\u306e\u8a18\u8ff0\u306f\u5272\u611b\u3057\u3066\u3044\u307e\u3059\uff09<\/p>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-6ba8f98f1b1898161c8a6563ddc4000c\"><code>\n    const jsonData = {\n      \"title\": \"\u30e6\u30fc\u30b6\u30fc\u306e\u5e74\u9f62\u3068\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593\u306e\u95a2\u4fc2\",\n      \"data\": &#91;\n        {\"userId\": \"U001\", \"age\": 22, \"siteDuration\": 3.5, \"note\": \"\u521d\u56de\u8a2a\u554f\"},\n        {\"userId\": \"U002\", \"age\": 35, \"siteDuration\": 8.0, \"note\": \"\u5e38\u9023\u30e6\u30fc\u30b6\u30fc\"},\n        {\"userId\": \"U003\", \"age\": 28, \"siteDuration\": 5.5, \"note\": \"-\"},\n        {\"userId\": \"U004\", \"age\": 45, \"siteDuration\": 12.0, \"note\": \"\u8cfc\u5165\u3042\u308a\"},\n        {\"userId\": \"U005\", \"age\": 31, \"siteDuration\": 7.2, \"note\": \"-\"},\n        {\"userId\": \"U006\", \"age\": 27, \"siteDuration\": 4.8, \"note\": \"-\"},\n        {\"userId\": \"U007\", \"age\": 40, \"siteDuration\": 9.1, \"note\": \"\u8cfc\u5165\u3042\u308a\"},\n        {\"userId\": \"U008\", \"age\": 23, \"siteDuration\": 3.8, \"note\": \"\u521d\u56de\u8a2a\u554f\"}\n      ]\n    };\n<\/code><\/pre>\n\n\n\n<div class=\"wp-block-group\"><div class=\"wp-block-group__inner-container is-layout-constrained wp-block-group-is-layout-constrained\">\n<h3 class=\"wp-block-heading\">Chart.js<\/h3>\n\n\n\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/scatter-chartjs.gif\"><img loading=\"lazy\" decoding=\"async\" width=\"798\" height=\"594\" src=\"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/scatter-chartjs.gif\" alt=\"\" class=\"wp-image-8557\"\/><\/a><\/figure>\n\n\n\n<h4 class=\"wp-block-heading\"><strong>\u5c0e\u5165\u624b\u9806<\/strong><\/h4>\n\n\n\n<h5 class=\"wp-block-heading\"><strong>1.CDN\u30ea\u30f3\u30af\u306e\u8ffd\u52a0<\/strong> (HTML\u306e<code>&lt;head&gt;<\/code>\u5185\u306b\u8a18\u8ff0)<\/h5>\n\n\n\n<p><\/p>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-c8ef7a23cb35f0edadf82d0e64266cea\"><code>\n<code>&lt;script src=\"https:\/\/cdn.jsdelivr.net\/npm\/chart.js\"&gt;&lt;\/script&gt;<\/code>\n\n<code><span style=\"background-color: initial; font-family: inherit; font-size: inherit;\"><\/span><\/code><\/code><\/pre>\n\n\n\n<h5 class=\"wp-block-heading\"><strong>2.HTML\u3068JavaScript\u30b3\u30fc\u30c9<\/strong><\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-88c2c313064d5c55c7c8e406fa7949fe\"><code>\n  &lt;h2>Chart.js \u3067\u306e\u6563\u5e03\u56f3&lt;\/h2>\n  &lt;!-- \u30b0\u30e9\u30d5\u63cf\u753b\u7528\u306e\u30ad\u30e3\u30f3\u30d0\u30b9 -->\n  &lt;canvas id=\"chartjs-scatter\" width=\"600\" height=\"400\">&lt;\/canvas>\n\n  &lt;script>\n    \/\/ \u5168\u30e9\u30a4\u30d6\u30e9\u30ea\u5171\u901a\u306e\u30b5\u30f3\u30d7\u30eb\u30c7\u30fc\u30bf\n    \/* *\u5272\u611b* *\/\n\n     \/\/ Chart.js \u7528\u306b\u30c7\u30fc\u30bf\u3092\u6574\u5f62\uff08x: \u5e74\u9f62, y: \u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593\uff09\n    const scatterData = jsonData.data.map(item => ({ x: item.age, y: item.siteDuration }));\n\n    \/\/ \u30ad\u30e3\u30f3\u30d0\u30b9\u8981\u7d20\u306e\u53d6\u5f97\u3068\u30b3\u30f3\u30c6\u30ad\u30b9\u30c8\u306e\u4f5c\u6210\n    const ctx = document.getElementById('chartjs-scatter');\n    \n    \/\/ Chart.js \u3092\u5229\u7528\u3057\u3066\u6563\u5e03\u56f3\u3092\u63cf\u753b\n    const scatterChart = new Chart(ctx, {\n      type: 'scatter', \/\/ \u30b0\u30e9\u30d5\u30bf\u30a4\u30d7\u3092\u6563\u5e03\u56f3\u306b\u8a2d\u5b9a\n      data: {\n        datasets: &#91;{\n          label: jsonData.title,  \/\/ \u30b0\u30e9\u30d5\u30bf\u30a4\u30c8\u30eb\u3068\u3057\u3066\u8868\u793a\n          data: scatterData,        \/\/ x, y\u5ea7\u6a19\u306e\u30c7\u30fc\u30bf\u914d\u5217\n          backgroundColor: 'rgba(75, 192, 192, 0.6)', \/\/ \u30c7\u30fc\u30bf\u70b9\u306e\u8272\n          pointRadius: 5            \/\/ \u5404\u30c7\u30fc\u30bf\u70b9\u306e\u534a\u5f84\n        }]\n      },\n      options: {\n        scales: {\n          x: {\n            type: 'linear',      \/\/ x\u8ef8\u306f\u7dda\u5f62\u30b9\u30b1\u30fc\u30eb\n            position: 'bottom',  \/\/ x\u8ef8\u306e\u4f4d\u7f6e\uff08\u4e0b\u5074\uff09\n            title: {\n              display: true,\n              text: '\u5e74\u9f62'       \/\/ x\u8ef8\u30bf\u30a4\u30c8\u30eb\n            }\n          },\n          y: {\n            title: {\n              display: true,\n              text: '\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593 (\u5206)' \/\/ y\u8ef8\u30bf\u30a4\u30c8\u30eb\n            }\n          }\n        },\n        plugins: {\n          tooltip: {\n            callbacks: {\n              \/\/ \u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u5185\u306b\u8a73\u7d30\u60c5\u5831\u3092\u8868\u793a\u3059\u308b\u305f\u3081\u306e\u30ab\u30b9\u30bf\u30e0\u30d5\u30a9\u30fc\u30de\u30c3\u30bf\n              label: context => `\u5e74\u9f62: ${context.parsed.x}, \u6ede\u5728\u6642\u9593: ${context.parsed.y}\u5206`\n            }\n          }\n        }\n      }\n    });\n  &lt;\/script>\n      <\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\"> \u89e3\u8aac\u30fb\u30dd\u30a4\u30f3\u30c8<\/h4>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>Chart.js \u306e\u30e1\u30ea\u30c3\u30c8<\/strong>\n<ul class=\"wp-block-list\">\n<li><strong>\u30b7\u30f3\u30d7\u30eb\u306a\u8a2d\u5b9a<\/strong>: \u57fa\u672c\u7684\u306a\u30b0\u30e9\u30d5\u3092\u7c21\u5358\u306a\u30b3\u30fc\u30c9\u3067\u4f5c\u6210\u3067\u304d\u3001\u521d\u5fc3\u8005\u304b\u3089\u30d7\u30ed\u30d5\u30a7\u30c3\u30b7\u30e7\u30ca\u30eb\u307e\u3067\u5e45\u5e83\u304f\u5229\u7528\u3055\u308c\u3066\u3044\u307e\u3059\u3002 <\/li>\n\n\n\n<li><strong>\u30ec\u30b9\u30dd\u30f3\u30b7\u30d6\u30c7\u30b6\u30a4\u30f3<\/strong>: \u81ea\u52d5\u7684\u306b\u30ec\u30b9\u30dd\u30f3\u30b7\u30d6\u5bfe\u5fdc\u3068\u306a\u308b\u305f\u3081\u3001\u3055\u307e\u3056\u307e\u306a\u30c7\u30d0\u30a4\u30b9\u3067\u306e\u8868\u793a\u304c\u5bb9\u6613\u3067\u3059\u3002 <\/li>\n\n\n\n<li><strong>\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u3068\u30a4\u30f3\u30bf\u30e9\u30af\u30b7\u30e7\u30f3<\/strong>: \u5185\u8535\u306e\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u52b9\u679c\u3084\u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u306a\u3069\u306e\u30a4\u30f3\u30bf\u30e9\u30af\u30b7\u30e7\u30f3\u6a5f\u80fd\u306b\u3088\u308a\u3001\u30e6\u30fc\u30b6\u30fc\u306b\u3068\u3063\u3066\u8996\u899a\u7684\u306b\u9b45\u529b\u7684\u306a\u30b0\u30e9\u30d5\u304c\u4f5c\u6210\u53ef\u80fd\u3067\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>\u30b0\u30e9\u30d5\u306e\u57fa\u672c\u8a2d\u5b9a<\/strong>\n<ul class=\"wp-block-list\">\n<li><strong>\u30b0\u30e9\u30d5\u30bf\u30a4\u30d7<\/strong>: Chart.js \u306e\u30aa\u30d7\u30b7\u30e7\u30f3\u3067 <code>type: 'scatter'<\/code> \u3092\u6307\u5b9a\u3059\u308b\u3053\u3068\u3067\u6563\u5e03\u56f3\u304c\u63cf\u753b\u3055\u308c\u307e\u3059\u3002 <\/li>\n\n\n\n<li><strong>\u30c7\u30fc\u30bf\u30bb\u30c3\u30c8<\/strong>: <code>datasets<\/code> \u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u3088\u308a\u3001\u8868\u793a\u3059\u308b\u30c7\u30fc\u30bf\u70b9\u306e\u914d\u5217\u3068\u3001\u30b0\u30e9\u30d5\u30bf\u30a4\u30c8\u30eb\u3001\u80cc\u666f\u8272\u3001\u70b9\u306e\u5927\u304d\u3055\u306a\u3069\u306e\u30b9\u30bf\u30a4\u30eb\u3092\u5b9a\u7fa9\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>\u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u306e\u30ab\u30b9\u30bf\u30de\u30a4\u30ba<\/strong>\n<ul class=\"wp-block-list\">\n<li><code>plugins.tooltip.callbacks<\/code> \u3092\u5229\u7528\u3057\u3066\u3001\u30c7\u30fc\u30bf\u70b9\u306b\u30de\u30a6\u30b9\u30aa\u30fc\u30d0\u30fc\u3057\u305f\u969b\u306b\u8a73\u7d30\u306a\u60c5\u5831\uff08\u4f8b\uff1a\u5e74\u9f62\u3068\u6ede\u5728\u6642\u9593\uff09\u3092\u308f\u304b\u308a\u3084\u3059\u304f\u8868\u793a\u3059\u308b\u30ab\u30b9\u30bf\u30e0\u30d5\u30a9\u30fc\u30de\u30c3\u30bf\u3092\u5b9f\u88c5\u3057\u3066\u3044\u307e\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<div class=\"wp-block-group\"><div class=\"wp-block-group__inner-container is-layout-constrained wp-block-group-is-layout-constrained\">\n<h3 class=\"wp-block-heading\">D3.js<\/h3>\n\n\n\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/scatter-d3js.gif\"><img loading=\"lazy\" decoding=\"async\" width=\"612\" height=\"454\" src=\"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/scatter-d3js.gif\" alt=\"\" class=\"wp-image-8564\"\/><\/a><\/figure>\n\n\n\n<h4 class=\"wp-block-heading\"><strong>\u5c0e\u5165\u624b\u9806<\/strong><\/h4>\n\n\n\n<h5 class=\"wp-block-heading\"><strong>1.CDN\u30ea\u30f3\u30af\u306e\u8ffd\u52a0<\/strong> (HTML\u306e<code>&lt;head&gt;<\/code>\u5185\u306b\u8a18\u8ff0)<\/h5>\n\n\n\n<p><\/p>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-909a610adf5410d923378cc228dc3215\"><code>\n&lt;script src=\"https:\/\/d3js.org\/d3.v7.min.js\"&gt;&lt;\/script&gt;\n\n\n<code><span style=\"background-color: initial; font-family: inherit; font-size: inherit;\"><\/span><\/code><\/code><\/pre>\n\n\n\n<h5 class=\"wp-block-heading\"><strong>2.CSS\u3092\u8ffd\u52a0<\/strong><\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-b51bb764c977838428ee9cc580afbd4b\"><code>\n  &lt;style>\n    \/* \u8ef8\u306e\u30b9\u30bf\u30a4\u30eb *\/\n    .axis path,\n    .axis line {\n      fill: none;\n      stroke: #000;\n    }\n    \/* \u30c7\u30fc\u30bf\u70b9\u306e\u521d\u671f\u30b9\u30bf\u30a4\u30eb *\/\n    .dot {\n      fill: steelblue;\n      opacity: 0.8;\n    }\n    \/* \u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u306e\u30b9\u30bf\u30a4\u30eb *\/\n    .tooltip {\n      position: absolute;\n      text-align: center;\n      padding: 5px;\n      background: lightsteelblue;\n      border: 1px solid #333;\n      border-radius: 3px;\n      pointer-events: none;\n      font-size: 12px;\n    }\n  &lt;\/style>\n<code>\n<\/code><\/code><\/pre>\n\n\n\n<h5 class=\"wp-block-heading\">3<strong>.HTML\u3068JavaScript\u30b3\u30fc\u30c9<\/strong><\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-c991bfcd90f2bd5bff6f21f58f260e5a\"><code>\n  &lt;h2>D3.js \u9ad8\u5ea6\u306a\u6563\u5e03\u56f3&lt;\/h2>\n  &lt;svg id=\"d3-scatter\" width=\"600\" height=\"400\">&lt;\/svg>\n  &lt;script>\n    \/\/ \u5168\u30e9\u30a4\u30d6\u30e9\u30ea\u5171\u901a\u306e\u30b5\u30f3\u30d7\u30eb\u30c7\u30fc\u30bf\n    \/* *\u5272\u611b* *\/\n\n    \/\/ \u30de\u30fc\u30b8\u30f3\u3068\u63cf\u753b\u9818\u57df\u306e\u30b5\u30a4\u30ba\u8a2d\u5b9a\n    const margin = {top: 40, right: 30, bottom: 50, left: 60},\n          width = 600 - margin.left - margin.right,\n          height = 400 - margin.top - margin.bottom;\n\n    \/\/ SVG\u8981\u7d20\u306e\u751f\u6210\u3068\u30b0\u30eb\u30fc\u30d7\u8981\u7d20\u306e\u8ffd\u52a0\n    const svg = d3.select(\"#d3-scatter\")\n                  .attr(\"width\", width + margin.left + margin.right)\n                  .attr(\"height\", height + margin.top + margin.bottom)\n                  .append(\"g\")\n                  .attr(\"transform\", `translate(${margin.left},${margin.top})`);\n\n    \/\/ x\u8ef8\u30fby\u8ef8\u306e\u30b9\u30b1\u30fc\u30eb\u8a2d\u5b9a\uff08\u30c7\u30fc\u30bf\u306e\u6700\u5c0f\u5024\u30fb\u6700\u5927\u5024\u306b\u4f59\u88d5\u3092\u3082\u305f\u305b\u308b\uff09\n    const xScale = d3.scaleLinear()\n                     .domain(&#91;d3.min(jsonData.data, d => d.age) - 5, d3.max(jsonData.data, d => d.age) + 5])\n                     .range(&#91;0, width]);\n    const yScale = d3.scaleLinear()\n                     .domain(&#91;d3.min(jsonData.data, d => d.siteDuration) - 1, d3.max(jsonData.data, d => d.siteDuration) + 1])\n                     .range(&#91;height, 0]);\n\n    \/\/ \u8ef8\u306e\u751f\u6210\n    const xAxis = d3.axisBottom(xScale).ticks(8);\n    const yAxis = d3.axisLeft(yScale).ticks(8);\n\n    \/\/ x\u8ef8\u306e\u63cf\u753b\u3068\u30bf\u30a4\u30c8\u30eb\u306e\u8ffd\u52a0\n    svg.append(\"g\")\n       .attr(\"class\", \"x axis\")\n       .attr(\"transform\", `translate(0, ${height})`)\n       .call(xAxis)\n       .append(\"text\")\n       .attr(\"fill\", \"#000\")\n       .attr(\"x\", width \/ 2)\n       .attr(\"y\", 40)\n       .attr(\"text-anchor\", \"middle\")\n       .text(\"\u5e74\u9f62\");\n\n    \/\/ y\u8ef8\u306e\u63cf\u753b\u3068\u30bf\u30a4\u30c8\u30eb\u306e\u8ffd\u52a0\n    svg.append(\"g\")\n       .attr(\"class\", \"y axis\")\n       .call(yAxis)\n       .append(\"text\")\n       .attr(\"fill\", \"#000\")\n       .attr(\"transform\", \"rotate(-90)\")\n       .attr(\"x\", -height \/ 2)\n       .attr(\"y\", -50)\n       .attr(\"dy\", \"0.71em\")\n       .attr(\"text-anchor\", \"middle\")\n       .text(\"\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593 (\u5206)\");\n\n    \/\/ SVG\u5185\u306b\u30bf\u30a4\u30c8\u30eb\u30c6\u30ad\u30b9\u30c8\u3092\u8ffd\u52a0\n    svg.append(\"text\")\n       .attr(\"x\", width \/ 2)\n       .attr(\"y\", -10)\n       .attr(\"text-anchor\", \"middle\")\n       .style(\"font-size\", \"16px\")\n       .style(\"font-weight\", \"bold\")\n       .text(jsonData.title);\n\n    \/\/ \u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u8981\u7d20\u306e\u4f5c\u6210\uff08body\u76f4\u4e0b\u306b\u8ffd\u52a0\uff09\n    const tooltip = d3.select(\"body\").append(\"div\")\n                      .attr(\"class\", \"tooltip\")\n                      .style(\"opacity\", 0);\n\n    \/\/ \u30c7\u30fc\u30bf\u70b9\u306e\u63cf\u753b\uff08\u521d\u671f\u72b6\u614b\u3067\u306f\u534a\u5f840\u304b\u3089\u958b\u59cb\u3057\u3001\u30c8\u30e9\u30f3\u30b8\u30b7\u30e7\u30f3\u3067\u62e1\u5927\uff09\n    const dots = svg.selectAll(\".dot\")\n                    .data(jsonData.data)\n                    .enter()\n                    .append(\"circle\")\n                    .attr(\"class\", \"dot\")\n                    .attr(\"cx\", d => xScale(d.age))\n                    .attr(\"cy\", d => yScale(d.siteDuration))\n                    .attr(\"r\", 0)\n                    .on(\"mouseover\", function(event, d) {\n                        \/\/ \u30de\u30a6\u30b9\u30aa\u30fc\u30d0\u30fc\u6642\u306b\u30c7\u30fc\u30bf\u70b9\u3092\u62e1\u5927\u3057\u8272\u3092\u5909\u66f4\n                        d3.select(this)\n                          .transition().duration(200)\n                          .attr(\"r\", 8)\n                          .attr(\"fill\", \"orange\");\n                        \/\/ \u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u306e\u8868\u793a\n                        tooltip.transition().duration(200).style(\"opacity\", 0.9);\n                        tooltip.html(`\u30e6\u30fc\u30b6\u30fc: ${d.userId}&lt;br>\u5e74\u9f62: ${d.age}&lt;br>\u6ede\u5728\u6642\u9593: ${d.siteDuration}\u5206&lt;br>\u5099\u8003: ${d.note}`)\n                               .style(\"left\", (event.pageX + 10) + \"px\")\n                               .style(\"top\", (event.pageY - 28) + \"px\");\n                    })\n                    .on(\"mouseout\", function() {\n                        \/\/ \u30de\u30a6\u30b9\u30a2\u30a6\u30c8\u6642\u306b\u5143\u306e\u72b6\u614b\u306b\u623b\u3059\n                        d3.select(this)\n                          .transition().duration(200)\n                          .attr(\"r\", 5)\n                          .attr(\"fill\", \"steelblue\");\n                        tooltip.transition().duration(200).style(\"opacity\", 0);\n                    });\n\n    \/\/ \u521d\u671f\u30ed\u30fc\u30c9\u6642\u306b\u30c7\u30fc\u30bf\u70b9\u304c\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u3067\u73fe\u308c\u308b\n    dots.transition()\n        .duration(1000)\n        .attr(\"r\", 5);\n  &lt;\/script>\n<code>\n<\/code><\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\"> \u89e3\u8aac\u30fb\u30dd\u30a4\u30f3\u30c8<\/h4>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong>\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u306e\u5b9f\u88c5<\/strong>\n<ul class=\"wp-block-list\">\n<li>\u30c7\u30fc\u30bf\u70b9\u306f\u521d\u671f\u72b6\u614b\u3067\u534a\u5f84 0 \u306e\u72b6\u614b\u304b\u3089\u3001<code>transition()<\/code> \u3092\u5229\u7528\u3057\u3066 1000ms \u304b\u3051\u3066\u534a\u5f84 5 \u306b\u62e1\u5927\u3055\u308c\u3001\u30b0\u30e9\u30d5\u306b\u300c\u767b\u5834\u300d\u3059\u308b\u3088\u3046\u306a\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u52b9\u679c\u3092\u5b9f\u73fe\u3057\u3066\u3044\u307e\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong>\u30a4\u30f3\u30bf\u30e9\u30af\u30b7\u30e7\u30f3\u3068\u30c4\u30fc\u30eb\u30c1\u30c3\u30d7<\/strong>\n<ul class=\"wp-block-list\">\n<li>\u5404\u30c7\u30fc\u30bf\u70b9\u306b\u306f <code>mouseover<\/code> \u304a\u3088\u3073 <code>mouseout<\/code> \u30a4\u30d9\u30f3\u30c8\u3092\u8a2d\u5b9a\u3002\u30de\u30a6\u30b9\u30aa\u30fc\u30d0\u30fc\u6642\u306b\u5bfe\u8c61\u306e\u30c7\u30fc\u30bf\u70b9\u304c\u62e1\u5927\u3057\u3001\u8272\u304c\u5909\u5316\u3059\u308b\u3053\u3068\u3067\u30e6\u30fc\u30b6\u30fc\u306b\u6ce8\u76ee\u3055\u305b\u308b\u52b9\u679c\u304c\u3042\u308a\u307e\u3059\u3002<\/li>\n\n\n\n<li> \u3055\u3089\u306b\u3001\u30de\u30a6\u30b9\u30aa\u30fc\u30d0\u30fc\u6642\u306b\u306f\u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u3092\u8868\u793a\u3057\u3001\u8a73\u7d30\u306a\u60c5\u5831\uff08\u30e6\u30fc\u30b6\u30fcID\u3001\u5e74\u9f62\u3001\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593\u3001\u5099\u8003\uff09\u3092\u308f\u304b\u308a\u3084\u3059\u304f\u63d0\u793a\u3057\u3066\u3044\u307e\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<div class=\"wp-block-group\"><div class=\"wp-block-group__inner-container is-layout-constrained wp-block-group-is-layout-constrained\">\n<h3 class=\"wp-block-heading\">ApexCharts<\/h3>\n\n\n\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/scatter-apex.gif\"><img loading=\"lazy\" decoding=\"async\" width=\"760\" height=\"482\" src=\"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/scatter-apex.gif\" alt=\"\" class=\"wp-image-8577\"\/><\/a><\/figure>\n\n\n\n<h4 class=\"wp-block-heading\"><strong>\u5c0e\u5165\u624b\u9806<\/strong><\/h4>\n\n\n\n<h5 class=\"wp-block-heading\"><strong>1.CDN\u30ea\u30f3\u30af\u306e\u8ffd\u52a0<\/strong> <\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-2fa09eaf5758700d3f8579e632ed5535\"><code>\n&lt;script src=\"https:\/\/cdn.jsdelivr.net\/npm\/apexcharts\"&gt;&lt;\/script&gt;\n\n<code><span style=\"background-color: initial; font-family: inherit; font-size: inherit;\"><\/span><\/code><\/code><\/pre>\n\n\n\n<h5 class=\"wp-block-heading\"><strong>2.CSS\u3092\u8ffd\u52a0<\/strong><\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-5dbdf2d0c33284cbe60e9acfad438ea6\"><code>\n  &lt;style>\n    \/* \u6700\u5927\u5e45600px\u306b\u8a2d\u5b9a *\/\n    #apexcharts-scatter {\n      max-width: 600px;\n      margin: auto;\n    }\n  &lt;\/style>\n\n<code><span style=\"background-color: initial; font-family: inherit; font-size: inherit;\"><\/span><\/code><\/code><\/pre>\n\n\n\n<h5 class=\"wp-block-heading\">3<strong>.HTML\u3068JavaScript\u30b3\u30fc\u30c9<\/strong><\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-30a91ee91348ecefc1c025f716effd66\"><code>\n  &lt;h2>ApexCharts \u3067\u306e\u6563\u5e03\u56f3&lt;\/h2>\n  &lt;div id=\"apexcharts-scatter\">&lt;\/div>\n    \/\/ \u5168\u30e9\u30a4\u30d6\u30e9\u30ea\u5171\u901a\u306e\u30b5\u30f3\u30d7\u30eb\u30c7\u30fc\u30bf\n    \/* *\u5272\u611b* *\/\n\n  &lt;script>\n    \/\/ ApexCharts\u7528\u306e\u30c7\u30fc\u30bf\u6574\u5f62\n    const seriesData = jsonData.data.map(item => ({ x: item.age, y: item.siteDuration }));\n\n    const options = {\n      chart: {\n        height: 400,\n        type: 'scatter'\n      },\n      series: &#91;{\n        name: jsonData.title,\n        data: seriesData\n      }],\n      xaxis: {\n        title: { text: '\u5e74\u9f62' },\n        tickAmount: 10\n      },\n      yaxis: {\n        title: { text: '\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593 (\u5206)' }\n      },\n      markers: {\n        size: 5\n      },\n      tooltip: {\n        x: {\n          formatter: val => `\u5e74\u9f62: ${val}`\n        },\n        y: {\n          formatter: val => `\u6ede\u5728\u6642\u9593: ${val}\u5206`\n        }\n      }\n    };\n\n    const chart = new ApexCharts(document.querySelector(\"#apexcharts-scatter\"), options);\n    chart.render();\n  &lt;\/script>\n<code>\n<\/code><\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\"> \u89e3\u8aac\u30fb\u30dd\u30a4\u30f3\u30c8<\/h4>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong><strong>\u7f8e\u3057\u3044\u30c7\u30b6\u30a4\u30f3\u3068\u76f4\u611f\u7684\u306aAPI<\/strong><\/strong>\n<ul class=\"wp-block-list\">\n<li>ApexCharts\u306f\u3001\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u6d17\u7df4\u3055\u308c\u305f\u30c7\u30b6\u30a4\u30f3\u304c\u9069\u7528\u3055\u308c\u308b\u305f\u3081\u3001\u30b3\u30fc\u30c9\u91cf\u3092\u6700\u5c0f\u9650\u306b\u6291\u3048\u306a\u304c\u3089\u3082\u8996\u899a\u7684\u306b\u9b45\u529b\u7684\u306a\u6563\u5e03\u56f3\u3092\u4f5c\u6210\u3067\u304d\u307e\u3059\u3002\u30b7\u30f3\u30d7\u30eb\u306a\u30aa\u30d7\u30b7\u30e7\u30f3\u8a2d\u5b9a\u3067\u3001\u521d\u5fc3\u8005\u3067\u3082\u3059\u3050\u306b\u5229\u7528\u53ef\u80fd\u3067\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong><strong>\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u306a\u6a5f\u80fd<\/strong><\/strong>\n<ul class=\"wp-block-list\">\n<li>\u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u3084\u30db\u30d0\u30fc\u30a8\u30d5\u30a7\u30af\u30c8\u304c\u6a19\u6e96\u642d\u8f09\u3055\u308c\u3066\u304a\u308a\u3001\u30e6\u30fc\u30b6\u30fc\u304c\u30c7\u30fc\u30bf\u30dd\u30a4\u30f3\u30c8\u306b\u30de\u30a6\u30b9\u30aa\u30fc\u30d0\u30fc\u3057\u305f\u969b\u306b\u3001\u8a73\u7d30\u60c5\u5831\uff08\u4f8b\u3048\u3070\u3001\u5e74\u9f62\u3084\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593\uff09\u304c\u5373\u5ea7\u306b\u8868\u793a\u3055\u308c\u307e\u3059\u3002\u3053\u308c\u306b\u3088\u308a\u3001\u30c7\u30fc\u30bf\u306e\u7406\u89e3\u304c\u6df1\u307e\u308a\u3001\u30e6\u30fc\u30b6\u30fc\u30a8\u30af\u30b9\u30da\u30ea\u30a8\u30f3\u30b9\u304c\u5411\u4e0a\u3057\u307e\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong><strong>\u6ed1\u3089\u304b\u306a\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3<\/strong><\/strong>\n<ul class=\"wp-block-list\">\n<li>\u30b0\u30e9\u30d5\u306e\u521d\u671f\u63cf\u753b\u6642\u3084\u30c7\u30fc\u30bf\u66f4\u65b0\u6642\u306b\u3001\u6ed1\u3089\u304b\u306a\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u52b9\u679c\u304c\u81ea\u52d5\u7684\u306b\u9069\u7528\u3055\u308c\u308b\u305f\u3081\u3001\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u30c7\u30fc\u30bf\u306e\u5909\u5316\u306b\u3082\u81ea\u7136\u306b\u5bfe\u5fdc\u3067\u304d\u308b\u8a2d\u8a08\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002\u5b9f\u969b\u306e\u904b\u7528\u3067\u306f\u3001\u52d5\u7684\u306a\u30c7\u30fc\u30bf\u66f4\u65b0\u3092\u6d3b\u304b\u3057\u3066\u30c0\u30c3\u30b7\u30e5\u30dc\u30fc\u30c9\u306a\u3069\u306b\u3082\u5fdc\u7528\u3067\u304d\u307e\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong><strong>\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u30c7\u30fc\u30bf\u66f4\u65b0\u306e\u5bb9\u6613\u3055<\/strong><\/strong>\n<ul class=\"wp-block-list\">\n<li>ApexCharts\u306fAPI\u7d4c\u7531\u3067\u306e\u30ea\u30a2\u30eb\u30bf\u30a4\u30e0\u30c7\u30fc\u30bf\u66f4\u65b0\u304c\u5bb9\u6613\u306b\u884c\u3048\u308b\u8a2d\u8a08\u3068\u306a\u3063\u3066\u304a\u308a\u3001<code>chart.updateSeries()<\/code> \u306a\u3069\u306e\u30e1\u30bd\u30c3\u30c9\u3092\u4f7f\u3048\u3070\u3001\u30c7\u30fc\u30bf\u306e\u5909\u66f4\u306b\u4f34\u3044\u5373\u5ea7\u306b\u30b0\u30e9\u30d5\u306e\u66f4\u65b0\u304c\u53cd\u6620\u3055\u308c\u307e\u3059\u3002\u4eca\u56de\u306e\u30b3\u30fc\u30c9\u3067\u306f\u76f4\u63a5\u306e\u4f8b\u306f\u542b\u307e\u308c\u3066\u3044\u307e\u305b\u3093\u304c\u3001\u5b9f\u88c5\u306f\u975e\u5e38\u306b\u30b7\u30f3\u30d7\u30eb\u3067\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<div class=\"wp-block-group\"><div class=\"wp-block-group__inner-container is-layout-constrained wp-block-group-is-layout-constrained\">\n<h3 class=\"wp-block-heading\">Plotly.js<\/h3>\n\n\n\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/scatter-plotly.gif\"><img loading=\"lazy\" decoding=\"async\" width=\"912\" height=\"514\" src=\"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/scatter-plotly.gif\" alt=\"\" class=\"wp-image-8584\"\/><\/a><\/figure>\n\n\n\n<h4 class=\"wp-block-heading\"><strong>\u5c0e\u5165\u624b\u9806<\/strong><\/h4>\n\n\n\n<h5 class=\"wp-block-heading\"><strong>1.CDN\u30ea\u30f3\u30af\u306e\u8ffd\u52a0<\/strong> (HTML\u306e<code>&lt;head&gt;<\/code>\u5185\u306b\u8a18\u8ff0)<\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-caf598f687c6f1fb8d26ca59a47d3f42\"><code>\n  &lt;script src=\"https:\/\/cdn.plot.ly\/plotly-latest.min.js\"&gt;&lt;\/script&gt;\n\n<code><span style=\"background-color: initial; font-family: inherit; font-size: inherit;\"><\/span><\/code><\/code><\/pre>\n\n\n\n<h5 class=\"wp-block-heading\">2<strong>.HTML\u3068JavaScript\u30b3\u30fc\u30c9<\/strong><\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-ecc0b36347c897636c15abf50cb83795\"><code>\n    &lt;h2>Plotly.js \u3067\u306e\u6563\u5e03\u56f3&lt;\/h2>\n  &lt;div id=\"plotly-scatter\">&lt;\/div>\n  &lt;script>\n    \/\/ \u5168\u30e9\u30a4\u30d6\u30e9\u30ea\u5171\u901a\u306e\u30b5\u30f3\u30d7\u30eb\u30c7\u30fc\u30bf\n    \/* *\u5272\u611b* *\/\n\n    \/\/ Plotly\u7528\u306bx, y\u30c7\u30fc\u30bf\u3092\u5206\u96e2\n    const ages = jsonData.data.map(item => item.age);\n    const durations = jsonData.data.map(item => item.siteDuration);\n\n    const trace = {\n      x: ages,\n      y: durations,\n      mode: 'markers',\n      type: 'scatter',\n      marker: { size: 10 }\n    };\n\n    const layout = {\n      title: jsonData.title,\n      xaxis: { title: '\u5e74\u9f62' },\n      yaxis: { title: '\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593 (\u5206)' }\n    };\n\n    Plotly.newPlot('plotly-scatter', &#91;trace], layout);\n  &lt;\/script>\n<code>\n<\/code><\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\"> \u89e3\u8aac\u30fb\u30dd\u30a4\u30f3\u30c8<\/h4>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong><strong>\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u6027\u306e\u9ad8\u3055<\/strong><\/strong>\n<ul class=\"wp-block-list\">\n<li>Plotly.js \u306f\u30c7\u30d5\u30a9\u30eb\u30c8\u3067\u30c7\u30fc\u30bf\u30dd\u30a4\u30f3\u30c8\u306e\u30db\u30d0\u30fc\u6642\u306b\u8a73\u7d30\u306a\u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u3092\u8868\u793a\u3059\u308b\u6a5f\u80fd\u3092\u5099\u3048\u3066\u304a\u308a\u3001\u30e6\u30fc\u30b6\u30fc\u304c\u5404\u70b9\u306b\u30de\u30a6\u30b9\u30aa\u30fc\u30d0\u30fc\u3059\u308b\u3053\u3068\u3067\u3001\u77ac\u6642\u306b\u60c5\u5831\u3092\u628a\u63e1\u3067\u304d\u307e\u3059\u3002\u307e\u305f\u3001\u30c9\u30e9\u30c3\u30b0\u64cd\u4f5c\u306b\u3088\u308b\u30ba\u30fc\u30e0\u3084\u30d1\u30f3\u6a5f\u80fd\u3082\u6a19\u6e96\u3067\u30b5\u30dd\u30fc\u30c8\u3055\u308c\u3066\u3044\u308b\u305f\u3081\u3001\u63a2\u7d22\u7684\u30c7\u30fc\u30bf\u5206\u6790\u306b\u975e\u5e38\u306b\u9069\u3057\u3066\u3044\u307e\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong><strong>\u67d4\u8edf\u306a\u30ba\u30fc\u30e0\u30fb\u30d1\u30f3\u6a5f\u80fd<\/strong><\/strong>\n<ul class=\"wp-block-list\">\n<li>\u30b0\u30e9\u30d5\u4e0a\u3067\u306e\u30ba\u30fc\u30e0\u3084\u30d1\u30f3\u64cd\u4f5c\u304c\u76f4\u611f\u7684\u306b\u884c\u3048\u308b\u305f\u3081\u3001\u5927\u898f\u6a21\u306a\u30c7\u30fc\u30bf\u30bb\u30c3\u30c8\u3084\u5bc6\u5ea6\u306e\u9ad8\u3044\u30c7\u30fc\u30bf\u30dd\u30a4\u30f3\u30c8\u306e\u8996\u8a8d\u6027\u5411\u4e0a\u306b\u8ca2\u732e\u3057\u307e\u3059\u3002\u30e6\u30fc\u30b6\u30fc\u306f\u95a2\u5fc3\u306e\u3042\u308b\u90e8\u5206\u306b\u7126\u70b9\u3092\u7d5e\u308a\u3001\u8a73\u7d30\u306a\u691c\u8a0e\u304c\u53ef\u80fd\u3067\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<div class=\"wp-block-group\"><div class=\"wp-block-group__inner-container is-layout-constrained wp-block-group-is-layout-constrained\">\n<h3 class=\"wp-block-heading\">ECharts<\/h3>\n\n\n\n<figure class=\"wp-block-image size-full\"><a href=\"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/scatter-echats.gif\"><img loading=\"lazy\" decoding=\"async\" width=\"964\" height=\"474\" src=\"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/scatter-echats.gif\" alt=\"\" class=\"wp-image-8594\"\/><\/a><\/figure>\n\n\n\n<h4 class=\"wp-block-heading\"><strong>\u5c0e\u5165\u624b\u9806<\/strong><\/h4>\n\n\n\n<h5 class=\"wp-block-heading\"><strong>1.CDN\u30ea\u30f3\u30af\u306e\u8ffd\u52a0<\/strong> (HTML\u306e<code>&lt;head&gt;<\/code>\u5185\u306b\u8a18\u8ff0)<\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-a9fd3cb5ac861ab90bcde42027356f8b\"><code>\n    &lt;script src=\"https:\/\/cdn.jsdelivr.net\/npm\/echarts\/dist\/echarts.min.js\"&gt;&lt;\/script&gt;\n\n\n<code><span style=\"background-color: initial; font-family: inherit; font-size: inherit;\"><\/span><\/code><\/code><\/pre>\n\n\n\n<h5 class=\"wp-block-heading\"><strong>2.<\/strong>CSS\u306e\u8a2d\u5b9a<\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-2ec50d85fb5132c2be70131a827591d5\"><code>\n   &lt;style>\n  &lt;style>\n    #echarts-scatter {\n          width: 100%;\n          height: 400px;\n    }\n  &lt;\/style>\n  &lt;\/style>\n\n<code><span style=\"background-color: initial; font-family: inherit; font-size: inherit;\"><\/span><\/code><\/code><\/pre>\n\n\n\n<h5 class=\"wp-block-heading\"><strong>2.HTML\u3068JavaScript\u3092\u8ffd\u52a0<\/strong><\/h5>\n\n\n\n<pre class=\"wp-block-code has-vivid-green-cyan-color has-black-background-color has-text-color has-background has-link-color wp-elements-eef2a9fbd894cc9102ca7e9b32c44cd4\"><code>\n &lt;h2>ECharts \u3067\u306e\u6563\u5e03\u56f3&lt;\/h2>\n  &lt;div id=\"echarts-scatter\" >&lt;\/div>\n  &lt;script>\n    \/\/ \u5168\u30e9\u30a4\u30d6\u30e9\u30ea\u5171\u901a\u306e\u30b5\u30f3\u30d7\u30eb\u30c7\u30fc\u30bf\n    \/* *\u5272\u611b* *\/\n\n    \/\/ \u6563\u5e03\u56f3\u7528\u306b\u30c7\u30fc\u30bf\u3092\u6574\u5f62\uff08x\u8ef8: \u5e74\u9f62, y\u8ef8: \u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593\uff09\n    const seriesData = jsonData.data.map(item => &#91;item.age, item.siteDuration]);\n\n    \/\/ ECharts \u30a4\u30f3\u30b9\u30bf\u30f3\u30b9\u306e\u521d\u671f\u5316\n    const chartDom = document.getElementById('echarts-scatter');\n    const myChart = echarts.init(chartDom);\n\n    const option = {\n      title: {\n        text: jsonData.title,\n        left: 'center'\n      },\n      tooltip: {\n        formatter: params => `\u5e74\u9f62: ${params.value&#91;0]}&lt;br>\u6ede\u5728\u6642\u9593: ${params.value&#91;1]}\u5206`\n      },\n      toolbox: {\n        feature: {\n          saveAsImage: {},         \/\/ \u753b\u50cf\u3068\u3057\u3066\u4fdd\u5b58\n          dataView: {readOnly: false},  \/\/ \u30c7\u30fc\u30bf\u8868\u793a\u30fb\u7de8\u96c6\n          restore: {}              \/\/ \u521d\u671f\u72b6\u614b\u3078\u306e\u30ea\u30bb\u30c3\u30c8\n        }\n      },\n      xAxis: {\n        name: '\u5e74\u9f62',\n        type: 'value'\n      },\n      yAxis: {\n        name: '\u30b5\u30a4\u30c8\u6ede\u5728\u6642\u9593 (\u5206)',\n        type: 'value'\n      },\n      series: &#91;{\n        symbolSize: 10,\n        data: seriesData,\n        type: 'scatter'\n      }]\n    };\n\n    myChart.setOption(option);\n  &lt;\/script>\n<code>\n<\/code><\/code><\/pre>\n\n\n\n<h4 class=\"wp-block-heading\"> \u89e3\u8aac\u30fb\u30dd\u30a4\u30f3\u30c8<\/h4>\n\n\n\n<ul class=\"wp-block-list\">\n<li><\/li>\n<\/ul>\n\n\n\n<ol class=\"wp-block-list\">\n<li><strong><strong><strong>\u8c4a\u5bcc\u306a\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u6a5f\u80fd<\/strong><\/strong><\/strong>\n<ul class=\"wp-block-list\">\n<li>\u57fa\u672c\u7684\u306a\u30c4\u30fc\u30eb\u30c1\u30c3\u30d7\u8868\u793a\u306b\u52a0\u3048\u3001\u30c7\u30fc\u30bf\u306e\u30d5\u30a3\u30eb\u30bf\u30ea\u30f3\u30b0\u3001\u30ba\u30fc\u30e0\u30fb\u30d1\u30f3\u6a5f\u80fd\u3001\u3055\u3089\u306b\u306f\u30c7\u30fc\u30bf\u306e\u8868\u793a\u30fb\u7de8\u96c6\uff08dataView\uff09\u3084\u521d\u671f\u72b6\u614b\u3078\u306e\u30ea\u30bb\u30c3\u30c8\uff08restore\uff09\u306a\u3069\u3001\u30e6\u30fc\u30b6\u30fc\u304c\u30b0\u30e9\u30d5\u3068\u76f4\u63a5\u5bfe\u8a71\u3067\u304d\u308b\u591a\u5f69\u306a\u30a4\u30f3\u30bf\u30e9\u30af\u30c6\u30a3\u30d6\u6a5f\u80fd\u304c\u7d44\u307f\u8fbc\u307e\u308c\u3066\u3044\u307e\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n\n\n\n<li><strong><strong>\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u4ed8\u304d\u306e\u30c8\u30e9\u30f3\u30b8\u30b7\u30e7\u30f3<\/strong><\/strong>\n<ul class=\"wp-block-list\">\n<li>ECharts \u306f\u30a2\u30cb\u30e1\u30fc\u30b7\u30e7\u30f3\u52b9\u679c\u3092\u6a19\u6e96\u88c5\u5099\u3057\u3066\u304a\u308a\u3001\u30c7\u30fc\u30bf\u306e\u8ffd\u52a0\u3084\u66f4\u65b0\u6642\u306b\u8996\u899a\u7684\u306a\u30c8\u30e9\u30f3\u30b8\u30b7\u30e7\u30f3\u304c\u9069\u7528\u3055\u308c\u307e\u3059\u3002\u3053\u308c\u306b\u3088\u308a\u3001\u52d5\u7684\u306a\u30c7\u30fc\u30bf\u5909\u5316\u3092\u76f4\u611f\u7684\u306b\u628a\u63e1\u3067\u304d\u308b\u307b\u304b\u3001\u30d7\u30ec\u30bc\u30f3\u30c6\u30fc\u30b7\u30e7\u30f3\u7528\u9014\u306b\u3082\u9069\u3057\u3066\u3044\u307e\u3059\u3002<\/li>\n<\/ul>\n<\/li>\n<\/ol>\n<\/div><\/div>\n\n\n\n<h2 class=\"wp-block-heading\">\u307e\u3068\u3081<\/h2>\n\n\n\n<p>\u4eca\u56de\u306f\u3001\u6563\u5e03\u56f3\u306e\u7279\u5fb4\u3084\u6d3b\u7528\u30b7\u30fc\u30f3\u3092\u7d39\u4ecb\u3057\u3001Web\u30b5\u30a4\u30c8\u3067\u7c21\u5358\u306b\u63cf\u753b\u3067\u304d\u308b\u304a\u3059\u3059\u3081\u306eJavaScript\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u6bd4\u8f03\u3057\u307e\u3057\u305f\u3002<\/p>\n\n\n\n<p>\u6563\u5e03\u56f3\u306f\u3001\u30c7\u30fc\u30bf\u306e\u50be\u5411\u3084\u76f8\u95a2\u95a2\u4fc2\u3092\u8996\u899a\u7684\u306b\u628a\u63e1\u3059\u308b\u306e\u306b\u5f79\u7acb\u3064\u30b0\u30e9\u30d5\u3067\u3059\u3002\u4eca\u56de\u7d39\u4ecb\u3057\u305f\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u6d3b\u7528\u3057\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u30cb\u30fc\u30ba\u306b\u5408\u3063\u305f\u6700\u9069\u306a\u30b0\u30e9\u30d5\u3092\u9078\u3093\u3067\u304f\u3060\u3055\u3044\u306d\u3002<\/p>\n\n\n\n<p><\/p>\n<\/div>","protected":false},"excerpt":{"rendered":"<p>\u30c7\u30fc\u30bf\u3092\u8996\u899a\u7684\u306b\u4f1d\u3048\u308b\u305f\u3081\u306e\u30ec\u30fc\u30c0\u30fc\u30c1\u30e3\u30fc\u30c8\u3092JavaScript\u3067\u5b9f\u88c5\u3059\u308b\u65b9\u6cd5\u306b\u3064\u3044\u3066\u89e3\u8aac\u3057\u3066\u3044\u307e\u3059\u3002\u7279\u306b\u3001\u30ec\u30fc\u30c0\u30fc\u30c1\u30e3\u30fc\u30c8\u306e\u7279\u5fb4\u3001\u6d3b\u7528\u4f8b\u3001\u5229\u70b9\u30fb\u6b20\u70b9\u3001\u4eba\u6c17\u306eJavaScript\u30e9\u30a4\u30d6\u30e9\u30ea\u3092\u6bd4\u8f03\u3057\u3001\u5c0e\u5165\u65b9\u6cd5\u3084\u30ab\u30b9\u30bf\u30de\u30a4\u30ba\u306b\u3064\u3044\u3066\u3082\u7d30\u304b\u304f\u8aac\u660e\u3057\u3066\u3044\u307e\u3059\u3002\u9069\u5207\u306a\u30e9\u30a4\u30d6\u30e9\u30ea\u9078\u5b9a\u3092\u30b5\u30dd\u30fc\u30c8\u3057\u307e\u3059\u3002<\/p>\n","protected":false},"author":14,"featured_media":8596,"comment_status":"closed","ping_status":"closed","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":true,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"enabled":false},"version":2}},"categories":[13,15],"tags":[550,551,22,541,389],"class_list":["post-8521","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-frontend","category-system","tag-chart-js","tag-google-charts","tag-javascript","tag-541","tag-389"],"acf":[],"aioseo_notices":[],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"https:\/\/fastcoding.jp\/blog\/wp-content\/uploads\/2025\/03\/8521scatter.png","jetpack_sharing_enabled":true,"amp_enabled":true,"_links":{"self":[{"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/posts\/8521","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/users\/14"}],"replies":[{"embeddable":true,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/comments?post=8521"}],"version-history":[{"count":63,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/posts\/8521\/revisions"}],"predecessor-version":[{"id":8595,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/posts\/8521\/revisions\/8595"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/media\/8596"}],"wp:attachment":[{"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/media?parent=8521"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/categories?post=8521"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/fastcoding.jp\/blog\/wp-json\/wp\/v2\/tags?post=8521"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}