質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

XAML

XAML(Extensible Application Markup Language)はWPF、Silverlight、Windows PhoneそしてWindows Store appsでユーザーインターフェースを定義するために使われるXML言語です。

Q&A

解決済

1回答

2175閲覧

コードビハインドがない場合、~xaml.csは削除してもよいのか

soi013

総合スコア149

C#

C#はマルチパラダイムプログラミング言語の1つで、命令形・宣言型・関数型・ジェネリック型・コンポーネント指向・オブジェクティブ指向のプログラミング開発すべてに対応しています。

Visual Studio

Microsoft Visual StudioはMicrosoftによる統合開発環境(IDE)です。多種多様なプログラミング言語に対応しています。

XAML

XAML(Extensible Application Markup Language)はWPF、Silverlight、Windows PhoneそしてWindows Store appsでユーザーインターフェースを定義するために使われるXML言語です。

1グッド

0クリップ

投稿2020/03/07 03:11

編集2020/03/07 11:36

前提・実現したいこと

VisualStuidoを使用してWPFアプリケーションでWindowやUserControlを新規作成した場合、~.xaml~.xaml.csのファイルがペアで生成されます。
ただしMVVMでアプリケーションを作成している場合、~.xaml.csには何も変更しないことが多いです。

この条件では~.xaml.csを削除しても動作することは確認できましたが、
削除してしまっても問題はないのでしょうか?
パフォーマンス・コード管理など、他の部分で問題になる可能性はありますでしょうか?

※ 追記 消しても動くのはMainWindow.xaml.csだけで、その他のUserControlやWindowは中身が表示されなくなります。
ただしビルドや実行時エラーが起きるわけではありません。

試したこと

~.xaml.csを削除後に動作を確認
その後、再び同名のファイルを追加して、コードビハインドを記述して動作を確認

補足情報(FW/ツールのバージョンなど)

  • VisualStuido 2019
  • .NET Framework 4.8
hihijiji👍を押しています

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hihijiji

2020/03/07 03:23

InitializeComponent();が無いと中身が配置されないと思うけど?
soi013

2020/03/07 05:58

私もそう思っていたのですが、不思議と動いて、Xamlに配置したコントロールも表示されるのです。 objフォルダには`~.g.i.cs`と`~g.cs`が生成されていた、そこにはInitializeComponentが含まれています。
guest

回答1

0

ベストアンサー

objフォルダには~.g.i.cs~g.csが生成されていた、そこにはInitializeComponentが含まれています。

そこにあるのはInitializeComponentメソッドの実装のほうですよね。
どこかではInitializeComponentを呼ばない限り Component の Initialize はされないはずです。
DIとかテンプレートとか拡張機能にInitializeComponentを呼ぶ機能が含まれているのではないでしょうか?
コードビハインドはInitializeComponentを呼ぶためにあるようなものですから、InitializeComponentを確実に呼ぶ何かがあるなら不要と言えば不要です。

でもあえて消す意義があるのかは疑問です。
消す手間がゼロだとしても、消している理由を解りやすく説明する手段を盛り込む手間はかなり大きくなりそうです。
またコードビハインドの存在自体を利用する拡張機能があったとしたら解りにくい不具合が出そうです。

投稿2020/03/07 08:06

編集2020/03/07 08:15
hihijiji

総合スコア4152

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

soi013

2020/03/07 09:22

回答ありがとうございます。 > DIとかテンプレートとか拡張機能にInitializeComponentを呼ぶ機能が含まれているのではないでしょうか? DIは使っておらず、拡張機能はProductivity Power Toolsぐらい、VisualStuido標準のWPFテンプレートを使っているので特に思い当たるものは無いです。 > でもあえて消す意義があるのかは疑問です。 コードビハインドが無いことが分かりやすいかな、というぐらいですかね > またコードビハインドの存在自体を利用する拡張機能があったとしたら解りにくい不具合が出そうです。 確かにそれはありそうですね。
hihijiji

2020/03/07 09:48

コードビハインドを消した状態でInitializeComponentが呼ばれているか確認してほしいです。 ~.g.i.csのInitializeComponentメソッドはブレークポイントが置けます。 被参照をたどるか"InitializeComponent();"で検索すれば呼び出し元も解ります。
soi013

2020/03/07 11:32

コードビハインドを消した`MainWindow.xaml.g.i.cs`にブレークポイントを設置しましたが、以下のメッセージが表示され止まりませんでした。 "ブレークポイントは現在の設定ではヒットしません。このドキュメントのシンボルが読み込まれていません" なお、このメッセージはコードビハインドを消してないUserControlの`~g.i.cs`でも同じなので、デバッガーの仕様かもしれません。
soi013

2020/03/07 11:33

それと、実験していて気づいたのですが、コードビハインドを消しても動くのはMainWindowだけのようです。UserControlや別のWindowは表示されませんでした。質問の方に追記しておきます
soi013

2020/03/08 15:02

おお!ありがとうございます。 Stackoverflowを参考に、コードビハインドを消したUserControlに以下の変更を加えたら、表示されるようになりました! ``` <UserControl x:Class="CodeBihindDeleteTest.NoCodeUserControl" ...省略... > <x:Code> <![CDATA[ public NoCodeUserControl() { InitializeComponent(); }]]> </x:Code> ```
hihijiji

2020/03/09 00:27

soi013 さん 謎はとけました。 ありがとうございます。 TN8001 さんも有り難うございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問