Visual Studio2017内のASP.NetCore1.1プロジェクトでAngular 4を利用したい(*。csprojファイルとして読み取る)
以前のASP.NETCore1.0およびVisualStudio 2015では、AngularJS(1.x.x)を依存関係としてproject.json
に追加するだけで、それ自体が組み込まれていました。
現在、ASP.NetCoreとVS2017では、project.json
ファイルがなくなり、私が見つけることができる唯一のドキュメントは、CLIを使用してCLIを使用して生成するAngular4プロジェクトの開始について言及しています新しいangularアプリ。新しいプロジェクトが本当に必要ないか、別のUIプロジェクトにサービスを提供するために作成したすべてをリファクタリングする必要があります。クライアント側のUIエクスペリエンスを追加して、アプリを拡張したいだけです。
助言がありますか?
この質問は多くの意見を得ており、情報はほとんど役に立たないので、このアップデートを提供します。
Visual Studio 2017(*.csproj
)
Asp.Net Core 2.0 + Angular(v2.0〜v4.0)::組み込みのテンプレートを使用してください!最良のオプションIMO。
Asp.Net Core 1.X + Angular(v2.0〜v4.0)
Visual Studio 2015(project.json
)
ツール:バージョン-preview2-まで-これ以上の更新はありません。すべての新しい.NETCore機能はVS2017に移行します。
Asp.Net Core 1.X + Angular(v2.0〜v4.0)
Asp.Net Core 1.X + AngularJS(〜1.5)
Asp.Net MVC 5 + AngularJS(〜1.5)
注:AngularをNPM、Bower、などのASP.Net/.NetCoreプロジェクトで機能させるには、他にも多くの方法があります。 NuGetなど。シンプルで実際に機能するものを強調してみました。また、上記のPluralsightブログ投稿によると、これらはMicrosoftの方向性と一致しています。
[あなたがこれを具体的に尋ねなかったことを知っていますが、私の意見に非常に関連する考えを共有したかっただけです]
私は数か月前にまったく同じ時点にいて、angularcliを使用することにしました。そして私はその決定をした神に感謝します。比類のないほど明確であり、実際には、.netコアWebAPIバックエンドと完全に分離されたangularクライアントのようになります。 iPhone/AndroidアプリをVSソリューションに配置しないのとまったく同じように、angularも配置する本当の理由はありません。
[〜#〜] update [〜#〜] RazorでMVCを使用するか、ORをSPAとしてAngularを使用し、Angularを使用する場合はAngularCLI。また、Angularを使用する場合は、asp.net(コア)WebApiをRESTバックエンドとして使用してデータをフィードします。
これがどのように混乱しているのかはわかりますが、deezgは正しいです。 2つの別々のプロジェクトが必要になります。 1つは.netコアバックエンドAPI(REST)で、もう1つはAngular 2スパです。完全に分離されます。
AngularJSを使用すると、jsファイルをかみそりのビューにドロップして1日と呼ぶことができます。ただし、Angular 2/4とReactを使用する場合は、各プロジェクトを独自のソリューションでホストするのが最適です。これは最初はばかげているように見えるかもしれませんが、APIを構築すると簡単になります。モバイルアプリ、デスクトップアプリなどでも利用できる機能を備えているため、将来性が保証されます。
.netコア用のdotnetspa services angular cli powershellコマンドがあることは知っていますが、それは本当に混乱のようなものであり、実際には無効なhtmlを出力しますおそらく SEOなどに悪影響を及ぼします。IMOは、別のプロジェクトでangular CLIを使用することをお勧めします。
本番環境では、.netコアAPIとangular 2プロジェクトを別々にホストします。
お役に立てば幸いです。
「ASP.NETコアプロジェクトにAngular 4を追加」」の意味は完全にはわかりませんが、これを行う1つの方法は次のとおりです。
私のブログでは、 このアプローチを示す詳細なチュートリアルがあります 。
私はAngular 4(SPA)および.NetコアWebAPIに取り組んでいます。リポジトリをチェックして理解を深めることができます。
認証、承認、ソーシャルログイン、MongoDBコネクタなどの多くの分野に対するソリューションを見つける必要がありました。
これが誰かがこれにつまずくための時間を節約することを願っています。
Angular 6とASP.NETCORE 2.1を使用していますが、これはAngular 4で機能する可能性があります。
次のコマンドを実行します。
ng生成コンポーネントcomponent-name-with-lowercase
これにより、.html、.spec.ts、.ts、.cssファイルが生成され、app.module.tsが更新されます。
次のコマンドを実行します。
ng generate service _component-name-with-lowercase_
これにより、デフォルトで\ appフォルダーに.tsと.spec.tsが生成されます。これらのファイルは、\ app\_servicesなどの別のフォルダーに移動できます