{"id":36266,"date":"2018-07-09T10:10:39","date_gmt":"2018-07-09T01:10:39","guid":{"rendered":"https:\/\/www.ospn.jp\/press\/?p=36266"},"modified":"2019-03-05T13:18:47","modified_gmt":"2019-03-05T04:18:47","slug":"no53-useit-oss","status":"publish","type":"post","link":"https:\/\/www.ospn.jp\/press\/20180709no53-useit-oss.html","title":{"rendered":"\u300c\u30aa\u30fc\u30d7\u30f3\u30bd\u30fc\u30b9\u300d\u3092\u4f7f\u3063\u3066\u307f\u3088\u3046<br>\uff08\u7b2c48\u56de\uff1aBlazor\uff09"},"content":{"rendered":"<br \/>\n<h2 id=\"c-single-page-web-blazor\">C# \u3067 Single Page Web \u30a2\u30d7\u30ea\u304c\u4f5c\u308c\u308b<br \/>\n\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u300cBlazor\u300d<\/h2>\n<p>\u300cBlazor\u300d\u3068\u306f\u3001Microsoft \u304c\u4e3b\u5c0e\u3067\u958b\u767a\u3057\u3066\u3044\u308b\u30aa\u30fc\u30d7\u30f3\u30bd\u30fc\u30b9\u306e<br \/>\nSingle Page Web \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3067\u3059\u3002<\/p>\n<p>Angular \u3084 React\u3001Vue \u306e\u3088\u3046\u306b\u3001\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u5074 (\u30d6\u30e9\u30a6\u30b6\u5074) \u3067<br \/>\n\u52d5\u4f5c\u3059\u308b\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u30e9\u30a4\u30d6\u30e9\u30ea\u306a\u306e\u3067\u3059\u304c\u3001\u306a\u3093\u3068\u3001JavaScript \u3067\u306f\u306a\u304f<br \/>\nC# \u3067\u66f8\u3051\u308b\u306e\u304c\u7279\u5fb4\u3067\u3059\u3002<\/p>\n<p>\n        <a href=\"https:\/\/www.ospn.jp\/press\/20180709no53-useit-oss.html\/fig-01\" rel=\"attachment wp-att-36284\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/www.ospn.jp\/press\/wp-content\/uploads\/2018\/07\/fig-01.png\" alt=\"\" width=\"550\" height=\"266\" class=\"alignnone size-full wp-image-36284\" \/><\/a>\n    <\/p>\n<p>\u958b\u767a\u306f GitHub \u4e0a (\u4e0b\u8a18 URL) \u3067\u884c\u308f\u308c\u3066\u304a\u308a\u3001<br \/>\n\u30e9\u30a4\u30bb\u30f3\u30b9\u306f Apache v.2.0 \u30e9\u30a4\u30bb\u30f3\u30b9\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<ul>\n<li>\n            <a href=\"https:\/\/github.com\/aspnet\/Blazor\">https:\/\/github.com\/aspnet\/Blazor<\/a>\n        <\/li>\n<\/ul>\n<p>2018\u5e747\u6708\u73fe\u5728\u3082\u3001\u3053\u306e GitHub \u30ea\u30dd\u30b8\u30c8\u30ea\u4e0a\u3067\u306f Issue \u304c\u7acb\u3066\u3089\u308c\u3066<br \/>\n\u30c7\u30a3\u30b9\u30ab\u30c3\u30b7\u30e7\u30f3\u304c\u884c\u308f\u308c\u305f\u308a Pull Request \u304c\u98db\u3093\u3060\u308a\u3068\u3001<br \/>\n\u6d3b\u767a\u306b\u958b\u767a\u6d3b\u52d5\u304c\u884c\u308f\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>Pull request \u3092\u9001\u308b\u306a\u3069\u5b9f\u88c5\u3067\u8ca2\u732e\u3057\u305f\u3044\u5834\u5408\u306f\u3001\u4e0a\u8a18\u30ea\u30dd\u30b8\u30c8\u30ea\u306b<br \/>\n\u63b2\u8f09\u306e Contribution \u30ac\u30a4\u30c9\u3092\u53c2\u7167\u3059\u308b\u3068\u3088\u3044\u3067\u3057\u3087\u3046\u3002<\/p>\n<p><!--more--><\/p>\n<h2 id=\"c\">C# \u304c\u30d6\u30e9\u30a6\u30b6\u4e0a\u3067\u52d5\u304f\u4ed5\u7d44\u307f<\/h2>\n<p>Blazor \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306f C# \u8a00\u8a9e\u3067\u8a18\u8ff0\u3059\u308b\u306e\u3067\u3059\u304c\u3001<br \/>\n\u3055\u3066\u3001\u3069\u3046\u3057\u3066 C# \u8a00\u8a9e\u3067\u66f8\u3044\u305f\u30b3\u30fc\u30c9\u304c\u30d6\u30e9\u30a6\u30b6\u4e0a\u3067\u52d5\u4f5c\u3059\u308b\u306e\u3067\u3057\u3087\u3046\u304b?<\/p>\n<p>\u307e\u305a\u3001\u3053\u308c\u306f C# \u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u304b\u3089 JavaScript \u7b49\u3005\u3078\u306e\u30c8\u30e9\u30f3\u30b9\u30d1\u30a4\u30eb\u3067\u306f\u3042\u308a\u307e\u305b\u3093\u3002<\/p>\n<p>\u306a\u3093\u3068\u3001C# \u8a00\u8a9e\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u3092\u30d3\u30eb\u30c9\u3057\u3066\u51fa\u6765\u4e0a\u304c\u308b .dll \u30d5\u30a1\u30a4\u30eb<br \/>\n (.NET \u30a2\u30bb\u30f3\u30d6\u30ea\u30d5\u30a1\u30a4\u30eb) \u3092\u30d6\u30e9\u30a6\u30b6\u306b\u8aad\u307f\u8fbc\u3093\u3067\u3001\u305d\u306e .dll \u30d5\u30a1\u30a4\u30eb\u306b<br \/>\n\u53ce\u9332\u3055\u308c\u3066\u3044\u308b .NET \u4e2d\u9593\u8a00\u8a9e (IL) \u3092\u89e3\u91c8\u30fb\u5b9f\u884c\u3057\u3066\u3057\u307e\u3046\u306e\u3067\u3059\u3002<\/p>\n<p>\u306a\u305c\u305d\u306e\u3088\u3046\u306a\u4e8b\u304c\u53ef\u80fd\u306a\u306e\u304b\u3068\u3044\u3046\u3068\u3001Web \u30d6\u30e9\u30a6\u30b6\u306e WebAssembly \u306e\u4ed5\u7d44\u307f\u306e<br \/>\n\u4e0a\u306b\u3001.NET \u306e\u5b9f\u884c\u74b0\u5883 (.NET CLR) \u3092\u69cb\u7bc9\u3057\u3066\u3057\u307e\u3063\u305f\u306e\u3067\u3059\u3002<\/p>\n<p>\n        <a href=\"https:\/\/www.ospn.jp\/press\/20180709no53-useit-oss.html\/fig-02\" rel=\"attachment wp-att-36285\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/www.ospn.jp\/press\/wp-content\/uploads\/2018\/07\/fig-02.png\" alt=\"\" width=\"340\" height=\"324\" class=\"alignnone size-full wp-image-36285\" \/><\/a>\n    <\/p>\n<p>\u3053\u306e\u3088\u3046\u306a\u4ed5\u7d44\u307f\u306a\u306e\u3067\u3001.NET \u306e\u30a2\u30bb\u30f3\u30d6\u30ea\u30d5\u30a1\u30a4\u30eb (.dll) \u3092\u305d\u306e\u307e\u307e\u8aad\u307f\u8fbc\u3081\u3066<br \/>\n\u3057\u307e\u3046\u3082\u306e\u3067\u3059\u304b\u3089\u3001\u65e7\u6765\u304b\u3089\u3042\u308b\u30e9\u30a4\u30d6\u30e9\u30ea (NuGet \u30d1\u30c3\u30b1\u30fc\u30b8) \u3082 Blazor \u30a2\u30d7\u30ea\u5185<br \/>\n\u304b\u3089\u30d6\u30e9\u30a6\u30b6\u4e0a\u3067\u4f7f\u3048\u3066\u3057\u307e\u3063\u305f\u308a\u3057\u307e\u3059\u3002<\/p>\n<p>\u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u6280\u6cd5\u3082\u3001\u5c5e\u6027\u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u306f\u3082\u3061\u308d\u3093\u3001\u30ea\u30d5\u30ec\u30af\u30b7\u30e7\u30f3\u3059\u3089\u3082<br \/>\n\u4f7f\u3048\u307e\u3059\u3002<\/p>\n<p>\u307e\u305f\u3001\u540c\u3058\u7406\u7531\u304b\u3089\u3001\u5b9f\u306f C# \u8a00\u8a9e\u306b\u9650\u3089\u305a\u3001VB.net \u3084 F# \u306a\u3069\u306a\u3069\u3001\u3044\u305a\u308c\u306e\u8a00\u8a9e\u3067<br \/>\n\u3042\u308d\u3046\u3068\u6700\u7d42\u7684\u306b .NET \u30a2\u30bb\u30f3\u30d6\u30ea\u30d5\u30a1\u30a4\u30eb (.dll) \u3092\u30d3\u30eb\u30c9\u30fb\u51fa\u529b\u3067\u304d\u308c\u3070\u3001<br \/>\nBlazor \u30a2\u30d7\u30ea\u5185\u304b\u3089\u30d6\u30e9\u30a6\u30b6\u4e0a\u306b\u8aad\u307f\u8fbc\u3093\u3067\u5b9f\u884c\u3059\u308b\u3053\u3068\u3082\u53ef\u80fd\u3067\u3059\u3002<\/p>\n<h2 id=\"blazor-spa\">Blazor \u306f SPA \u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3067\u3042\u308b<\/h2>\n<p>Blazor \u304c\u9762\u767d\u3044\u306e\u306f\u3001\u5358\u306b\u300cC# \u304c\u30d6\u30e9\u30a6\u30b6\u4e0a\u3067\u5b9f\u884c\u3067\u304d\u308b\u300d\u3068\u3044\u3046\u3060\u3051\u3067\u306f<br \/>\n\u306a\u3044\u70b9\u3067\u3059\u3002<\/p>\n<p>C# \u3067 &quot;Single Page Web \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3 (\u4ee5\u4e0b SPA)&quot; \u3092\u958b\u767a\u3059\u308b\u306e\u306b\u5fc5\u8981\u306a<br \/>\n\u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u30e9\u30a4\u30d6\u30e9\u30ea\u8fbc\u307f\u306a\u306e\u3067\u3059\u3002<\/p>\n<p>Blazor \u306b\u306f \u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8 (HTML \u30c6\u30f3\u30d7\u30ec\u30fc\u30c8) \u3084 URL \u30eb\u30fc\u30c6\u30a3\u30f3\u30b0\u3001<br \/>\n\u30c7\u30fc\u30bf\u30d0\u30a4\u30f3\u30c7\u30a3\u30f3\u30b0\u3001\u4f9d\u5b58\u6027\u6ce8\u5165\u306a\u3069\u306a\u3069\u3001\u4eca\u6642\u306e SPA \u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u3092<br \/>\n\u624b\u672c\u3068\u3057\u305f\u5404\u7a2e\u6a5f\u80fd\u304c\u4f5c\u308a\u8fbc\u307e\u308c\u3066\u63d0\u4f9b\u3055\u308c\u3066\u304a\u308a\u3001\u3059\u3050\u306b C# \u306b\u3088\u308bSPA \u958b\u767a\u304c<br \/>\n\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>Blazor \u306b\u3088\u308b SPA \u30a2\u30d7\u30ea\u4f5c\u6210\u306e\u30c7\u30e2\u30f3\u30b9\u30c8\u30ec\u30fc\u30b7\u30e7\u30f3\u3068\u3057\u3066\u3001<br \/>\n\u4e0b\u8a18 URL \u3067 &quot;Flight Finder&quot; \u304c\u516c\u958b\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<ul>\n<li>Flight Finder Demo &#8211;<br \/>\n            <a href=\"https:\/\/j.mp\/blazor-flightfinder\">https:\/\/j.mp\/blazor-flightfinder<\/a>\n        <\/li>\n<\/ul>\n<p>\n        <a href=\"https:\/\/www.ospn.jp\/press\/20180709no53-useit-oss.html\/fig-03\" rel=\"attachment wp-att-36286\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/www.ospn.jp\/press\/wp-content\/uploads\/2018\/07\/fig-03.png\" alt=\"\" width=\"550\" height=\"340\" class=\"alignnone size-full wp-image-36286\" \/><\/a>\n    <\/p>\n<p>Flight Finder \u306e\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u306f\u4e0b\u8a18 URL \u306e GitHub \u30ea\u30dd\u30b8\u30c8\u30ea\u3067\u516c\u958b\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<ul>\n<li>Blazor Samples &#8211;<br \/>\n            <a href=\"https:\/\/j.mp\/blazor-samples\">https:\/\/j.mp\/blazor-samples<\/a>\n        <\/li>\n<\/ul>\n<h2 id=\"visual-studio-ide\">Visual Studio IDE \u306b\u3088\u308b\u958b\u767a\u652f\u63f4\u304c\u5f37\u529b<\/h2>\n<p>\u3055\u3089\u306b Blazor \u306f\u3001Visual Studio IDE 2017 \u7528\u306e\u30a2\u30c9\u30a4\u30f3\u3082\u540c\u6642\u63d0\u4f9b\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>Blazor \u30a2\u30d7\u30ea\u3092 Visual Studio IDE 2017 \u4e0a\u3067\u958b\u767a\u3059\u308b\u5834\u5408\u306f\u3001\u3053\u306e\u30a2\u30c9\u30a4\u30f3\u3092<br \/>\nVisual Studio IDE 2017 \u306b\u8ffd\u52a0\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u3066\u304a\u304f\u3068\u3001\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8<br \/>\n(HTML \u30c6\u30f3\u30d7\u30ec\u30fc\u30c8)\u306e\u7de8\u96c6\u6642\u306b\u3001\u30a4\u30f3\u30c6\u30ea\u30bb\u30f3\u30b9\u3092\u306f\u3058\u3081\u3068\u3057\u305f\u5404\u7a2eIDE\u652f\u63f4\u3092<br \/>\n\u53d7\u3051\u3089\u308c\u308b\u3088\u3046\u306b\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\n        <a href=\"https:\/\/www.ospn.jp\/press\/20180709no53-useit-oss.html\/fig-04\" rel=\"attachment wp-att-36287\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/www.ospn.jp\/press\/wp-content\/uploads\/2018\/07\/fig-04.png\" alt=\"\" width=\"550\" height=\"338\" class=\"alignnone size-full wp-image-36287\" \/><\/a>\n    <\/p>\n<h2 id=\"blazor-spa-1\">Blazor \u3067\u306e SPA \u958b\u767a\u306f\u3001\u958b\u767a\u8005\u306e\u8ca0\u62c5\u3092\u6e1b\u3089\u3059<\/h2>\n<p>C# \u3067 SPA \u958b\u767a\u3092\u3059\u308b\u3053\u3068\u306e\u9b45\u529b\u3068\u3057\u3066\u8a00\u3048\u308b\u3053\u3068\u306f\u3001<br \/>\n\u958b\u767a\u8005\u8ca0\u62c5\u304c\u524a\u6e1b\u3055\u308c\u308b\u3053\u3068\u3067\u3059\u3002<br \/>\n        <br \/> \u3044\u304f\u3064\u304b\u4f8b\u3092\u6319\u3052\u3066\u307f\u307e\u3057\u3087\u3046\u3002\n    <\/p>\n<h3 id=\"json\">\u4f8b. JSON \u304b\u3089\u306e\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306e\u5fa9\u5143<\/h3>\n<p>\u4e00\u4f8b\u3068\u3057\u3066\u3001\u30b5\u30fc\u30d0\u30fc\u5074\u304b\u3089 fetch \u3057\u305f JSON \u6587\u5b57\u5217\u3092\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u306b<br \/>\n\u5fa9\u5143\u3059\u308b\u5834\u5408\u3092\u8003\u3048\u3066\u307f\u307e\u3059\u3002<\/p>\n<p>\u6b8b\u5ff5\u306a\u304c\u3089 JSON \u306e\u4ed5\u69d8\u306b\u306f\u65e5\u6642\u578b (Date) \u306f\u542b\u307e\u308c\u3066\u304a\u3089\u305a\u3001<br \/>\n\u65e5\u6642\u578b\u306e\u5024\u306f\u6587\u5b57\u5217\u306b\u5909\u63db\u3055\u308c\u307e\u3059\u3002<br \/>\n        <br \/> \u305d\u306e\u305f\u3081\u3001JavaScript \u3067\u306e SPA \u958b\u767a\u306b\u304a\u3044\u3066\u306f\u3001\u65e5\u6642\u578b\u3092\u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u542b\u3080<br \/>\n\u30aa\u30d6\u30b8\u30a7\u30af\u30c8\u3092 JSON.parse() \u3060\u3051\u3067\u306f\u5fa9\u5143\u3067\u304d\u307e\u305b\u3093\u3002<br \/>\n        <br \/> \u3064\u307e\u308a\u3001\u65e5\u6642\u578b\u3068\u3057\u305f\u3044\u30d7\u30ed\u30d1\u30c6\u30a3\u306b\u6587\u5b57\u5217\u304c\u30bb\u30c3\u30c8\u3055\u308c\u3066\u3057\u307e\u3046\u306e\u3067\u3001<br \/>\n\u3055\u3089\u306a\u308b\u5f8c\u51e6\u7406\u304c\u5fc5\u8981\u3068\u306a\u308a\u307e\u3059\u3002\n    <\/p>\n<p>\u305d\u306e\u70b9\u3001Blazor \u306f C# \u3067\u3059\u304b\u3089\u3001\u5fa9\u5143\u5148\u306e\u578b\u60c5\u5831\u3092\u6301\u3063\u3066\u3044\u308b\u305f\u3081\u3001<br \/>\n\u65e5\u6642\u578b\u3067\u3042\u308d\u3046\u3068\u306a\u3093\u3067\u3042\u308d\u3046\u3068\u3001\u4f55\u3082\u8003\u3048\u305a\u3068\u3082\u3001\u304d\u3063\u3061\u308a\u76ee\u7684\u306e\u578b\u306b<br \/>\n\u5fa9\u5143\u3055\u308c\u307e\u3059\u3002<\/p>\n<h3 id=\"section\">\u4f8b. \u7ba1\u7406\u304c\u5bb9\u6613\u306a\u30d3\u30eb\u30c9\u30b7\u30b9\u30c6\u30e0<\/h3>\n<p>\u307e\u305f\u4ed6\u306e\u4f8b\u3068\u3057\u3066\u3001\u30d3\u30eb\u30c9\u30b7\u30b9\u30c6\u30e0\u306e\u7ba1\u7406\u306e\u5bb9\u6613\u3055\u3082\u6319\u3052\u3089\u308c\u307e\u3059\u3002<\/p>\n<p>Blazor \u3082 C# \u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30d5\u30a1\u30a4\u30eb\u306b\u57fa\u3065\u304f\u30d3\u30eb\u30c9\u5f62\u614b\u3067\u3059\u3002<br \/>\n        <br \/> \u30d1\u30c3\u30b1\u30fc\u30b8\u30b7\u30b9\u30c6\u30e0\u3082\u5f93\u6765\u304b\u3089\u306e C# \u30d7\u30ed\u30b0\u30e9\u30de\u306b\u306f\u304a\u306a\u3058\u307f\u306e NuGet \u3067\u3001<br \/>\n\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30d5\u30a1\u30a4\u30eb\u3068\u30d3\u30eb\u30c9\u30b7\u30b9\u30c6\u30e0\u306b\u900f\u904e\u7684\u306b\u7d71\u5408\u3055\u308c\u3066\u3044\u3059\u3002<\/p>\n<p>\u30d3\u30e5\u30fc\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8 (HTML \u30c6\u30f3\u30d7\u30ec\u30fc\u30c8) \u3092\u8ffd\u52a0\u3059\u308b\u5834\u5408\u3067\u3082\u3001<br \/>\ntouch \u30b3\u30de\u30f3\u30c9\u3067\u7a7a\u30d5\u30a1\u30a4\u30eb\u3092\u4f5c\u3063\u3066\u7de8\u96c6\u958b\u59cb\u3059\u308c\u3070\u305d\u308c\u3060\u3051\u3067 OK\u3002<br \/>\n        <br \/> \u5916\u90e8\u30e9\u30a4\u30d6\u30e9\u30ea (NuGet \u30d1\u30c3\u30b1\u30fc\u30b8) \u306e\u8ffd\u52a0\u3082\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u30d5\u30a1\u30a4\u30eb\u306b<br \/>\n\u30d1\u30c3\u30b1\u30fc\u30b8\u540d\u3092\u8ffd\u8a18\u3059\u308c\u3070 OK \u3067\u3059\u3002<\/p>\n<p>JavaScript \u306b\u3088\u308b SPA \u958b\u767a\u306b\u304a\u3051\u308b\u3001\u30d1\u30c3\u30b1\u30fc\u30b8\u30b7\u30b9\u30c6\u30e0\u3001\u30bf\u30b9\u30af\u30e9\u30f3\u30ca\u30fc\u3001<br \/>\n\u30d0\u30f3\u30c9\u30e9\u30fc\u3001\u3068\u3044\u3063\u305f\u5404\u7a2e\u30c4\u30fc\u30eb\u306e\u69cb\u6210\u30d5\u30a1\u30a4\u30eb\u306e\u8abf\u6574\u306f\u4e0d\u8981\u3067\u3059\u3002<\/p>\n<p>\u540d\u524d\u7a7a\u9593\u3067\u8b58\u5225\u3055\u308c\u3066\u3044\u308b\u306e\u3067\u3001\u4ed6\u306e\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u304b\u3089\u3053\u306e\u65b0\u898f\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8\u3092<br \/>\n\u53c2\u7167\u3059\u308b\u5834\u5408\u3067\u3082\u3001\u9010\u4e00 import \u3057\u306a\u304f\u3066\u3082\u3059\u3050\u306b\u4f7f\u3044\u59cb\u3081\u3089\u308c\u307e\u3059\u3002<\/p>\n<p>&#8230;\u3053\u306e\u3088\u3046\u306a\u8abf\u5b50\u3067\u3001C# \u8a00\u8a9e\u3068\u305d\u306e\u30d3\u30eb\u30c9\u30b7\u30b9\u30c6\u30e0\u306b\u3088\u308b Blazor SPA \u30a2\u30d7\u30ea\u958b\u767a\u306f\u3001<br \/>\n\u958b\u767a\u8005\u306b\u3068\u3063\u3066\u30b9\u30c8\u30ec\u30b9\u306e\u5c11\u306a\u3044\u3082\u306e\u3068\u306a\u3063\u3066\u3044\u307e\u3059\u3002<\/p>\n<h2 id=\"blazor-1\">Blazor \u306e\u59cb\u3081\u65b9<\/h2>\n<p>macOS\/Linux\/Windows \u3044\u305a\u308c\u3067\u3082\u3001.NET Core SDK 2.1 \u3055\u3048\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308c\u3070<br \/>\n\u6700\u4f4e\u9650\u306e\u74b0\u5883\u304c\u6574\u3044\u307e\u3059\u3002<\/p>\n<ul>\n<li>NET Core SDK 2.1 &#8211;<br \/>\n            <a href=\"https:\/\/j.mp\/netcore-sdk-2-1-300\">https:\/\/j.mp\/netcore-sdk-2-1-300<\/a>\n        <\/li>\n<\/ul>\n<p>Windows OS \u4e0a\u3067\u958b\u767a\u3059\u308b\u306e\u3067\u3042\u308c\u3070\u3001\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u30b5\u30a4\u30ba\u306f\u5c11\u3005\u304b\u3055\u3070\u308a\u307e\u3059\u3057\u3001<br \/>\n\u30d7\u30ed\u30d7\u30e9\u30a4\u30a8\u30bf\u30ea\u306a\u88fd\u54c1\u3067\u306f\u3042\u308a\u307e\u3059\u304c\u3001Visual Studio IDE 2017 \u3068\u3001\u305d\u306e Blazor \u7528<br \/>\n\u30a2\u30c9\u30a4\u30f3\u3092\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3059\u308b\u306e\u304c\u3001\u305d\u306e\u5feb\u9069\u306a\u958b\u767a\u652f\u63f4\u3092\u5f97\u3089\u308c\u308b\u306e\u3067\u304a\u52e7\u3081\u3067\u3059\u3002<\/p>\n<ul>\n<li>Visual Studio IDE &#8211;<br \/>\n            <a href=\"https:\/\/visualstudio.microsoft.com\/vs\/\">https:\/\/visualstudio.microsoft.com\/vs\/<\/a>\n        <\/li>\n<\/ul>\n<p>\u3082\u3061\u308d\u3093\u3001Visual Studio IDE 2017 \u304c\u306a\u304f\u3066\u3082\u3001\u6700\u4f4e\u9650\u30c6\u30ad\u30b9\u30c8\u30a8\u30c7\u30a3\u30bf\u304c\u3042\u308c\u3070<br \/>\n\u5927\u4e08\u592b\u3002<\/p>\n<p>.NET Core SDK \u3067\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3055\u308c\u308b &quot;dotent&quot; \u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u30a4\u30f3\u30bf\u30fc\u30d5\u30a7\u30fc\u30b9\u3092<br \/>\n\u30b7\u30a7\u30eb\u4e0a\u304b\u3089\u5b9f\u884c\u3059\u308b\u3053\u3068\u3067\u3001\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u306e\u65b0\u898f\u4f5c\u6210\u304b\u3089\u30d3\u30eb\u30c9\u3001\u5b9f\u884c\u3001<br \/>\n\u5358\u4f53\u30c6\u30b9\u30c8\u5b9f\u65bd\u3001\u767a\u884c\u307e\u3067\u3001\u3072\u3068\u3068\u304a\u308a\u958b\u767a\u4f5c\u696d\u3092\u884c\u3046\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>\u30d3\u30e5\u30fc\u30b3\u30f3\u30dd\u30fc\u30cd\u30f3\u30c8 (HTML \u30c6\u30f3\u30d7\u30ec\u30fc\u30c8) \u3092\u9664\u3051\u3070\u3001\u30e2\u30c7\u30eb\u3084\u30d3\u30b8\u30cd\u30b9\u30ed\u30b8\u30c3\u30af\u3001<br \/>\n\u30b5\u30fc\u30d3\u30b9\u306a\u3069\u306e\u30b3\u30fc\u30c9\u306f\u3001\u4f55\u306e\u5909\u54f2\u3082\u306a\u3044 C# \u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u3067\u3059\u3002<br \/>\n        <br \/> \u306a\u306e\u3067\u3001\u305d\u308c\u3089C# \u30b3\u30fc\u30c9\u306b\u3064\u3044\u3066\u306f\u3001Visual Studio Code \u306a\u3069\u3068\u3044\u3063\u305f<br \/>\n\u30aa\u30fc\u30d7\u30f3\u30bd\u30fc\u30b9\u306e\u9ad8\u6a5f\u80fd\u30a8\u30c7\u30a3\u30bf\u3092\u7528\u3044\u3066\u3001\u30b3\u30fc\u30c9\u88dc\u5b8c\u3084\u30ea\u30d5\u30a1\u30af\u30bf\u30ea\u30f3\u30b0\u652f\u63f4\u306a\u3069\u306e<br \/>\n\u958b\u767a\u652f\u63f4\u3092\u5f97\u306a\u304c\u3089\u958b\u767a\u3059\u308b\u3053\u3068\u304c\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>\u81ea\u7fd2\u65b9\u6cd5\u3068\u3057\u3066\u306f\u3001\u516c\u5f0f\u30b5\u30a4\u30c8\u306b\u30c1\u30e5\u30fc\u30c8\u30ea\u30a2\u30eb\u304c\u3042\u308b\u4ed6\u3001\u7b46\u8005\u304c\u4f5c\u6210\u3057\u305f\u3001<br \/>\n\u65e5\u672c\u8a9e\u306e\u81ea\u7fd2\u30ad\u30c3\u30c8\u3082\u3042\u308a\u307e\u3059\u3002\u3069\u3046\u305e\u3054\u6d3b\u7528\u304f\u3060\u3055\u3044\u3002<\/p>\n<ul>\n<li>&quot;Get started with Blazor&quot; &#8211;<br \/>\n            <a href=\"https:\/\/j.mp\/blazor-get-started\">https:\/\/j.mp\/blazor-get-started<\/a>\n        <\/li>\n<li>Blazor \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u81ea\u7fd2\u66f8 &#8211;<br \/>\n            <a href=\"https:\/\/j.mp\/selflearn-blazor-jp\">https:\/\/j.mp\/selflearn-blazor-jp<\/a>\n        <\/li>\n<\/ul>\n<h2 id=\"blazor-2\">Blazor \u306e\u77ed\u6240<\/h2>\n<p>\u3053\u306e\u3088\u3046\u306b\u305f\u304f\u3055\u3093\u306e\u9b45\u529b\u3092\u62b1\u3048\u308b Blazor \u306a\u306e\u3067\u3059\u304c\u3001\u3082\u3061\u308d\u3093\u77ed\u6240\u3082\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u4e00\u4f8b\u3092\u6319\u3052\u308b\u3068\u3001Blazor \u30a2\u30d7\u30ea\u306f\u3001.dll \u30d5\u30a1\u30a4\u30eb\u306e\u96c6\u5408\u4f53\u3068\u306a\u308b\u306e\u3067\u3059\u304c\u3001<br \/>\n\u305d\u306e .dll \u30d5\u30a1\u30a4\u30eb\u7fa4\u306e\u7dcf\u30b5\u30a4\u30ba\u304c\u307e\u3041\u307e\u3041\u306e\u5927\u304d\u3055\u306b\u306a\u308a\u307e\u3059<br \/>\n(\u5c06\u6765\u7684\u306b\u306f\u4e8b\u524d\u30b3\u30f3\u30d1\u30a4\u30eb\u6280\u8853\u306e\u767a\u9054\u306b\u3088\u3063\u3066\u3082\u3063\u3068\u30b9\u30ea\u30e0\u306b\u306a\u308b\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u304c)\u3002<br \/>\n\u5b9f\u4f8b\u3092\u6319\u3052\u308b\u3068\u3001\u5148\u306e Flight Finder \u30c7\u30e2\u3067\u3001\u7dcf\u8ee2\u9001\u30b5\u30a4\u30ba\u304c 1.8MB \u307b\u3069\u3002<br \/>\n        <br \/> \u3068\u306f\u3044\u3048 twitter.com \u3067\u7dcf\u8ee2\u9001\u30b5\u30a4\u30ba\u304c 4MB \u7a0b\u306a\u306e\u3067\u3001\u3053\u306e\u30b5\u30a4\u30ba\u611f\u3092\u3069\u3046\u8003\u3048\u308b\u304b<br \/>\n\u6b21\u7b2c\u306a\u3068\u3053\u308d\u3082\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u305d\u3057\u3066\u4f55\u3088\u308a\u3082\u6ce8\u610f\u70b9\u3068\u3057\u3066\u8a18\u3057\u3066\u304a\u304b\u306a\u3044\u3068\u306a\u3089\u306a\u3044\u306e\u306f\u3001Blazor \u306f2018\u5e747\u6708\u73fe\u5728\u3001<br \/>\n\u307e\u3060\u300c\u5b9f\u9a13\u7684\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u300d\u3068\u3057\u3066\u4f4d\u7f6e\u3065\u3051\u3089\u308c\u3066\u3044\u308b\u3053\u3068\u3067\u3059\u3002<\/p>\n<p>Blazor \u958b\u767a\u3092\u7387\u3044\u3066\u3044\u308b Daniel Rose \u6c0f\u3082 Twitter \u4e0a\u3067\u3001<br \/>\n\u300c\u307e\u3060\u30d7\u30ed\u30c0\u30af\u30b7\u30e7\u30f3\u30ec\u30d9\u30eb\u3067\u306f\u4f7f\u308f\u306a\u3044\u3067\u300d\u3068\u30c4\u30a4\u30fc\u30c8\u3057\u3066\u3044\u307e\u3059\u3002<\/p>\n<p>\n        <a href=\"https:\/\/www.ospn.jp\/press\/20180709no53-useit-oss.html\/fig-05\" rel=\"attachment wp-att-36288\"><img loading=\"lazy\" decoding=\"async\" src=\"https:\/\/www.ospn.jp\/press\/wp-content\/uploads\/2018\/07\/fig-05.png\" alt=\"\" width=\"550\" height=\"316\" class=\"alignnone size-full wp-image-36288\" \/><\/a>\n    <\/p>\n<ul>\n<li>\n            <a href=\"https:\/\/twitter.com\/danroth27\/status\/970174117109424128\">https:\/\/twitter.com\/danroth27\/status\/970174117109424128<\/a>\n        <\/li>\n<\/ul>\n<p>\u5b9f\u969b\u3001\u57fa\u790e\u90e8\u5206\u306f\u305d\u308c\u306a\u308a\u306b\u3057\u3063\u304b\u308a\u4f5c\u308a\u8fbc\u307e\u308c\u3066\u3044\u308b\u3082\u306e\u306e\u3001<br \/>\n\u672b\u7aef\u30ec\u30d9\u30eb\u3067\u306f\u307e\u3060\u307e\u3060\u6a5f\u80fd\u304c\u8db3\u308a\u306a\u3044\u9762\u3082\u57a3\u9593\u898b\u3048\u307e\u3059\u3002<\/p>\n<h2 id=\"section-1\">\u6700\u5f8c\u306b<\/h2>\n<p>SPA \u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u30e9\u30a4\u30d6\u30e9\u30ea\u300cBlazor\u300d\u306f\u3001\u958b\u767a\u8005\u306e\u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u4f53\u9a13\u3092<br \/>\n\u5411\u4e0a\u3055\u305b\u307e\u3059\u3002<\/p>\n<p>\u3082\u3063\u3068\u3082\u3001\u958b\u767a\u8005\u4f53\u9a13\u3092\u6539\u5584\u3057\u3066\u3082\u3001\u76f4\u63a5\u306b\u306f\u30a2\u30d7\u30ea\u306e\u51fa\u6765\u306e\u826f\u3057\u60aa\u3057\u306b\u306f<br \/>\n\u95a2\u4fc2\u306a\u3044\u3088\u3046\u306b\u3082\u601d\u3048\u307e\u3059\u3002<\/p>\n<p>\u3057\u304b\u3057\u3001Blazor \u306e\u63a1\u7528\u306b\u3088\u3063\u3066\u3001\u3088\u308a\u3088\u3044\u54c1\u8cea\u306e\u30b3\u30fc\u30c9\u3092\u3088\u308a\u77ed\u6642\u9593\u3067\u7d21\u304e\u3060\u3059\u3053\u3068\u304c\u3067\u304d\u308b\u3088\u3046\u306b\u306a\u308c\u3070\u3001\u305d\u308c\u306f\u305d\u308c\u3060\u3051\u65e9\u304f\u4fa1\u5024\u3092\u30e6\u30fc\u30b6\u30fc\u306b\u5c4a\u3051\u308b\u529b\u306b\u306a\u308b\u306e\u3067\u306f\u306a\u3044\u3060\u308d\u3046\u304b\u3001\u3068\u601d\u3046\u6b21\u7b2c\u3067\u3059\u3002<\/p>\n<p>\u4eca\u65e5\u6642\u70b9\u3067\u306f\u307e\u3060\u300c\u5b9f\u9a13\u7684\u30d7\u30ed\u30b8\u30a7\u30af\u30c8\u300d\u3068\u4f4d\u7f6e\u3065\u3051\u3089\u308c\u3066\u3044\u308b Blazor \u3067\u3059\u3002<\/p>\n<p>\u305d\u308c\u3067\u3082\u4eca\u65e5\u3053\u306e\u6642\u70b9\u304b\u3089\u8a66\u7528\u30fb\u8a55\u4fa1\u3092\u59cb\u3081\u308b\u3053\u3068\u3067\u3001\u3044\u3064\u306e\u65e5\u306b\u304b\u306e Blazor<br \/>\n\u306e\u516c\u5f0f\u30ea\u30ea\u30fc\u30b9\u306b\u8ca2\u732e\u3067\u304d\u308b\u3068\u601d\u3044\u307e\u3059\u3057\u3001\u3042\u308b\u3044\u306f\u307e\u305f\u3001JavaScript \u4ee5\u5916\u306e<br \/>\n\u51e6\u7406\u7cfb\u30fb\u30a8\u30b3\u30b7\u30b9\u30c6\u30e0\u3067 SPA \u958b\u767a\u304c\u3067\u304d\u308b\u3053\u3068\u3092\u8eab\u3092\u3082\u3063\u3066\u4f53\u9a13\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>Blazor \u306f JavaSript \u3078\u306e\u30c8\u30e9\u30f3\u30b9\u30d1\u30a4\u30eb\u3067\u3082\u306a\u304f\u3001Adobe Flash \u306e\u3088\u3046\u306a\u30d7\u30e9\u30b0\u30a4\u30f3<br \/>\n\u30b7\u30b9\u30c6\u30e0\u3067\u3082\u306a\u3044\u3001WebAssembly \u3068\u3044\u3046 Web \u6a19\u6e96\u306e\u4ed5\u7d44\u307f\u306e\u4e0a\u306b\u51e6\u7406\u7cfb\u30fb\u5b9f\u884c\u74b0\u5883\u3092<br \/>\n\u307e\u308b\u3054\u3068\u8f09\u305b\u3066\u3057\u307e\u3046\u65b9\u6cd5\u304c\u3001SPA\u958b\u767a\u53ca\u3073\u5b9f\u884c\u306e\u57fa\u76e4\u3068\u3057\u3066\u5b9f\u7528\u306b\u306a\u308b\u3053\u3068\u3092\u793a\u3057\u3066<br \/>\n\u898b\u305b\u305f\u3068\u3082\u601d\u3044\u307e\u3059\u3002<\/p>\n<p>Blazor \u306f .NET \u306e\u51e6\u7406\u7cfb\u3067\u3059\u304c\u3001\u4ed6\u306e\u8a00\u8a9e\u30fb\u51e6\u7406\u7cfb\u3067\u3082\u3001\u3053\u306e\u65b9\u5f0f\u3067 SPA \u304c\u66f8\u3051\u308b<br \/>\n\u3088\u3046\u306b\u306a\u308b\u3068\u3001\u5404\u8a00\u8a9e\u30fb\u51e6\u7406\u7cfb\u3092\u5f97\u610f\u3068\u3059\u308b\u30d7\u30ed\u30b0\u30e9\u30de\u3084\u30a8\u30b3\u30b7\u30b9\u30c6\u30e0\u306e\u3082\u3068\u3001<br \/>\n\u307e\u305f\u65b0\u3057\u3044 Web \u30d6\u30e9\u30a6\u30b6\u30d7\u30ed\u30b0\u30e9\u30df\u30f3\u30b0\u6280\u6cd5\u304c\u751f\u307e\u308c\u3066\u304f\u308b\u304b\u3082\u3057\u308c\u307e\u305b\u3093\u306d\u3002<\/p>\n<h2 id=\"section-2\">\u53c2\u8003\u30ea\u30f3\u30af<\/h2>\n<ul>\n<li>\u6628\u5e742017\u5e74\u306b\u521d\u3081\u3066\u516c\u958b\u3055\u308c\u305f Blazor \u30d7\u30ed\u30c8\u30bf\u30a4\u30d7\u306e NDC Oslo \u30bb\u30c3\u30b7\u30e7\u30f3\u52d5\u753b (YouTube) &#8211;<br \/>\n            <a href=\"https:\/\/j.mp\/ndc-oslo-blazor\">https:\/\/j.mp\/ndc-oslo-blazor<\/a>\n        <\/li>\n<\/ul>\n<p>\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d<br \/>\nMicrosoft MVP<br \/>\nVisual Studio and Development Technologies<br \/>\n\u5742\u672c \u7d14\u4e00 (@jsakamoto)<br \/>\n\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d\uff1d<\/p>\n<p><\/body><\/p>\n<p><\/html><\/p>\n","protected":false},"excerpt":{"rendered":"<p>C# \u3067 Single Page Web \u30a2\u30d7\u30ea\u304c\u4f5c\u308c\u308b \u30d5\u30ec\u30fc\u30e0\u30ef\u30fc\u30af\u300cBlazor\u300d \u300cBlazor\u300d\u3068\u306f\u3001Microsoft \u304c\u4e3b\u5c0e\u3067\u958b\u767a\u3057\u3066\u3044\u308b\u30aa\u30fc\u30d7\u30f3\u30bd\u30fc\u30b9\u306e Single Page Web \u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u30d5 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[9],"tags":[],"class_list":["post-36266","post","type-post","status-publish","format-standard","hentry","category-use-it-oss"],"_links":{"self":[{"href":"https:\/\/www.ospn.jp\/press\/wp-json\/wp\/v2\/posts\/36266","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.ospn.jp\/press\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.ospn.jp\/press\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.ospn.jp\/press\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/www.ospn.jp\/press\/wp-json\/wp\/v2\/comments?post=36266"}],"version-history":[{"count":42,"href":"https:\/\/www.ospn.jp\/press\/wp-json\/wp\/v2\/posts\/36266\/revisions"}],"predecessor-version":[{"id":38142,"href":"https:\/\/www.ospn.jp\/press\/wp-json\/wp\/v2\/posts\/36266\/revisions\/38142"}],"wp:attachment":[{"href":"https:\/\/www.ospn.jp\/press\/wp-json\/wp\/v2\/media?parent=36266"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.ospn.jp\/press\/wp-json\/wp\/v2\/categories?post=36266"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.ospn.jp\/press\/wp-json\/wp\/v2\/tags?post=36266"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}