キャンバスアプリのギャラリーのItemsプロパティ(データソース)にWith関数を使ったときの動作が気になったので調査
今回確認したいこと
事前準備としてアプリのデータ行の制限を5にして、
data:image/s3,"s3://crabby-images/0ef30/0ef301e8d0aa53758093708c858493f09eba9267" alt=""
data:image/s3,"s3://crabby-images/0ef30/0ef301e8d0aa53758093708c858493f09eba9267" alt=""
このアプリ内のギャラリーで、アイテムがたくさんあるSPOリストを扱うときの話。
data:image/s3,"s3://crabby-images/ea48e/ea48e705d55b953ed4af2deb5ad57e148b4316eb" alt=""
data:image/s3,"s3://crabby-images/ea48e/ea48e705d55b953ed4af2deb5ad57e148b4316eb" alt=""
この場合、アプリ内のギャラリーに委任にひっかからない式を書くと、ギャラリーの遅延読み込み機能のおかげでSPOリストのアイテムを全件表示することが可能だが、
data:image/s3,"s3://crabby-images/5d0f4/5d0f4bdad53243553b48e2c0a9b225b902b56792" alt=""
data:image/s3,"s3://crabby-images/5d0f4/5d0f4bdad53243553b48e2c0a9b225b902b56792" alt=""
委任に引っかかる式を書くとギャラリーの遅延読み込み機能が動かず、データ行の制限分のアイテムしか表示されない。
data:image/s3,"s3://crabby-images/0fb2e/0fb2e9b242dd2270a5ce61883041cae1ea350b1d" alt=""
data:image/s3,"s3://crabby-images/0fb2e/0fb2e9b242dd2270a5ce61883041cae1ea350b1d" alt=""
今回はこのギャラリーの、ItemsプロパティにWith関数を使用したときのギャラリーの動作を確認する。
※委任とデータ行の制限に関する詳しい解説はこちら
data:image/s3,"s3://crabby-images/5b142/5b142818726f9198cc5128ccf1efd8170def50fb" alt=""
data:image/s3,"s3://crabby-images/5b142/5b142818726f9198cc5128ccf1efd8170def50fb" alt=""
Power Apps 委任とデータ行の制限(500件~2000件)の関係を徹底解説|委任とデータ行の制限は分けて考える
これまで委任とデータ行の制限(既定は500件)が絡まると、いまいち理解がこんがらがってしまっていたけど、改めて図にしてみるとわかりやすかったのでメモ。前提前提として今回はこんなリストがあって、このリストを、わかりやすいようにデータ行の制限を...
パターン1 : Filterの結果をWithの変数に入れる場合
まずはWith関数で宣言する変数にFilterの結果を代入してギャラリーで表示する場合。
これはもちろん変数に代入する時点で「委任はできるけどデータ行の制限にひっかかる」ため、画像のような表示になる。
data:image/s3,"s3://crabby-images/58951/5895156099ea1f4f77596c46e8eba1c938c1a3f6" alt=""
data:image/s3,"s3://crabby-images/58951/5895156099ea1f4f77596c46e8eba1c938c1a3f6" alt=""
ここまではわかりやすい。
パターン2:Filterの条件式に使う値をWithの変数に入れる場合
続いてWith関数で宣言する変数にFilter式で使用する値を代入する場合。
この場合も下の画像のように、「委任はできているけどデータ行の制限にひっかかる」ような動作になる。
data:image/s3,"s3://crabby-images/78485/78485af0fae0a80d0e6e327eba3ba5c2f9ec9468" alt=""
data:image/s3,"s3://crabby-images/78485/78485af0fae0a80d0e6e327eba3ba5c2f9ec9468" alt=""
パターン3:With関数でFilter式で一切使用しない変数を代入する場合
最後はWith関数でFilter式に一切関係しない変数を代入した場合。
この場合も画像のように「データ行の制限」分のアイテムしか表示されない。
data:image/s3,"s3://crabby-images/fb277/fb277416e090e8f23dc566a3adad0d68f29519e9" alt=""
data:image/s3,"s3://crabby-images/fb277/fb277416e090e8f23dc566a3adad0d68f29519e9" alt=""
ということでこれまでの結果を見ると、ギャラリーのItemsプロパティにWith関数を使用すると、ギャラリーの遅延読み込み機能が動かず、データ行の制限数分のアイテムしか表示できない、動作になることがわかる。
警告がでないためややこしいけど、ギャラリーに対してWith関数を使うのは控えたほうがよさげ。
おまけ:UpdateContextやFormulasで宣言した変数を使えば、遅延読み込み機能は動作する
UpdateContextで変数を宣言して、
data:image/s3,"s3://crabby-images/d2f98/d2f98015de1b26793e6921e2d8b7341f3c5ba239" alt=""
data:image/s3,"s3://crabby-images/d2f98/d2f98015de1b26793e6921e2d8b7341f3c5ba239" alt=""
この変数をギャラリーのItemsプロパティの委任可能な式で使用すれば問題なくすべてのアイテムが表示される。
data:image/s3,"s3://crabby-images/17ceb/17ceb65cee96b80b8574e71440fcde49469f890e" alt=""
data:image/s3,"s3://crabby-images/17ceb/17ceb65cee96b80b8574e71440fcde49469f890e" alt=""
Formulasで宣言した値も
data:image/s3,"s3://crabby-images/8d1e3/8d1e31c66b9112fd0912e84d925120c40d5e3fea" alt=""
data:image/s3,"s3://crabby-images/8d1e3/8d1e31c66b9112fd0912e84d925120c40d5e3fea" alt=""
問題なく動作。
data:image/s3,"s3://crabby-images/b1a90/b1a9088bd1d995d65d7fbb98d5ae6e1add7d70b5" alt=""
data:image/s3,"s3://crabby-images/b1a90/b1a9088bd1d995d65d7fbb98d5ae6e1add7d70b5" alt=""