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

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

新規登録して質問してみよう
ただいま回答率
85.48%
UWP

UWPは、Universal Windows Platformの略。様々なデバイス向けに提供されているアプリケーションを共通のフレームワーク上で動作可能にする仕組みで、Windows10で導入されました。

C#

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

XAML

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

Q&A

解決済

2回答

759閲覧

【UWP】XAMLにおいて、データを保持する方法について。

heroherohero

総合スコア38

UWP

UWPは、Universal Windows Platformの略。様々なデバイス向けに提供されているアプリケーションを共通のフレームワーク上で動作可能にする仕組みで、Windows10で導入されました。

C#

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

XAML

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

0グッド

0クリップ

投稿2019/07/21 01:12

お世話になっております。
UWPで、アプリ開発を行っており、分からないことがあったたため、質問させていただきます。

ローカルに蓄積しているデータを取得し、その取得したデータ数に応じて、ボタンを生成し、押下したボタンに応じて、(画面遷移の際に)渡すパラメータを変更するということを行いたいと考えております。

そうした際に、下記2つの実現方法があるのではないかと思っておりますが、色々と調べてみたのですが、分からなかったため、自分のこの考え方が合っているのかどうかも、含めてご意見いただけますと幸いです。

  1. HTMLのdata属性と同じような、プロパティが存在し、そこに値をセットし、その値を取得する。
  2. HTMLのhiddenタグと同じようなものが存在し、そこに値をセットし、その値を取得する。

下記に、該当分のXAMLのコードを記載いたします。

なお、ボタンは、通常のボタンではなく、CommandBarのAppBarButtonになります。
該当箇所:「<AppBarButton Content="{Binding DisplayName}" Click="{x:Bind ViewModel.NavigateTo}" />

以上、どうぞ、よろしくお願いいたします。

C#

1 <CommandBar DefaultLabelPosition="Right" Margin="-24,0,-24,0" VerticalAlignment="Top"> 2 <CommandBar.Content> 3 <StackPanel Orientation="Horizontal"> 4 <AppBarButton Icon="Home" Label="" /> 5 <ItemsControl ItemsSource="{x:Bind ViewModel._CurrentPathFoldersList}"> 6 <ItemsControl.ItemsPanel> 7 <ItemsPanelTemplate> 8 <StackPanel Orientation="Horizontal" /> 9 </ItemsPanelTemplate> 10 </ItemsControl.ItemsPanel> 11 <ItemsControl.ItemTemplate> 12 <DataTemplate> 13 <AppBarButton Content="{Binding DisplayName}" Click="{x:Bind ViewModel.NavigateTo}" /> 14 </DataTemplate> 15 </ItemsControl.ItemTemplate> 16 </ItemsControl> 17 </StackPanel> 18 </CommandBar.Content> 19 <AppBarButton Icon="NewFolder" Label="新規作成" Click="{x:Bind ViewModel.ShowNewFolderContentDialog}" /> 20 <AppBarButton Icon="Upload" Label="アップロード" Click="{x:Bind ViewModel.UploadFile}"/> 21 <CommandBar.SecondaryCommands> 22 <AppBarButton Icon="Message" Label="メッセージ"/> 23 </CommandBar.SecondaryCommands> 24 </CommandBar>

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

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

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

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

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

guest

回答2

0

ベストアンサー

AppBarButton.CommandAppBarButton.CommandParameterの組み合わせで「操作の種類+操作に対する変数」を表現できるかと思います。

Commandには生成するボタンに対して共通のCommand(今回の場合はNavigateToCommandといった感じでしょうか)を与えて、CommandParameterにそれぞれのIdであるとか、何か識別できるようなデータを与えることでCommandの動作を変化させることができる、というイメージです。

Commandの実装にはPrismのDelegateCommand<T>が便利です。

さらに発展的な実装が必要になった場合にはReactivePropertyのReactiveCommandが便利です。こちらは後学のために頭の片隅にでも置いておいて貰えたらいいかと思います。

投稿2019/07/21 08:28

tor4kichi

総合スコア763

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

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

heroherohero

2019/07/21 12:17

コメント、ありがとうございます! そうです!自分がやりたかったのは、まさに、tor4kichiさんがおっしゃってくださったものになります。 (前の質問にも答えていただき、ありがとうございました!) いただいたご意見を参考に、解決に取り組んでみたいと思います! 取り急ぎ、御礼申し上げます。
heroherohero

2019/07/21 13:58

無事に解決できました。 ボタン押下した後の、CommandParameterの受け取り方が分からなかったのですが、下記URLを参考に解決することができました。 ありがとうございました! 【参考URL】 https://qiita.com/aiya000/items/1cf31699bf8122e76bd7
guest

0

データを保持するのはViewModel側の仕事だからXAMLでどうこうしようとするのはおかしいんじゃないですかね。(MVVMで作ってる前提ですけど)

投稿2019/07/21 02:40

gentaro

総合スコア8949

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

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

heroherohero

2019/07/21 07:15

コメント、ありがとうございます。 gentaroさんのおっしゃる通り、ViewModel側にデータは持っているので、わざわざ、View側にデータを渡さなくとも、なんとかなりそうです。。。 いただいた意見をもとに、取り組んでみたいと思います。 よろしくお願いいたします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問