micomia株式会社の畑井です。
今回は投稿表示画面やユーザー一覧画面を作成する際に欠かせないListViewというWidgetについて解説していきます。
1.ListViewのスクロールについて

ListViewは画像のように利用します。
今回はColumnの下に入れています。
このような使い方をする場合はスクロールできないという問題が発生しがちですので下の画像のように設定してみてください。


Columnの下にListViewを入れる場合はまずはColumnをScrollableにしてください。

そしてListViewのPrimaryをOFFにしてください。
PrimaryをONにするとColumnもスクロールでPrimaryになっているため両方ともスクロールが優先されてしまいうまくスクロールができません。
2.ListViewにデータをセットする方法

ListViewにデータをセットする方法を説明していきます。
データベースはFirebaseのFirestoreを利用しています。

Query Collectionで今回はusersをセットします。
Filterで表示する内容を絞ったり、Orderingで並び替えたりすることができます。
「Confirm」を押してください。

このように表示されますが、「Confirm」を押してください。

このように薄く表示されていればListViewを使えています。

次に隣のこちらを利用していきます。

こちらは変数からListに表示する内容を入れることができるものです。
例えば検索した結果をドキュメントのListで受け取ってそれを表示するなど、ListViewに表示させる内容を変数から取得できる機能です。
3.その他メニュー

Axis・・・スクロールを縦でするか横でするか選べます。Verticalが縦スクロールで、Horizontalが横スクロールですが、Horizontalは多くの場合クラッシュしてしまうのでRowをスクロールできるように実装するのがおすすめです。
Item Spacing・・・ここの数字を入れると表示しているアイテムとアイテムの間にスペースを入れることができます。「Apply to Start & End」を押すと入力したスペースがアイテムの先頭と末尾にも入ります。
Shrink Wrap・・・アイテムの高さに合わせて動的にリストを生成するものです。
Primary・・・ONにすると優先スクロールとなります。
Reverse・・・並んでいるアイテムの順番を上下逆にします。
Reorderble・・・ONにすると並び替え可能な状態になります。
4.まとめ
今回はListViewについて解説しました。
ListView自体は簡単ですがスクロールできないという問題が発生することが多いため本記事を参考にスクロールできないなど基本的な不具合はなくせるようにしましょう。



.webp%3Falt%3Dmedia%26token%3Da7c14698-1b08-4fea-89c6-f77a9121f4c5&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D899eeefd-f4c9-44a6-9ec2-3ced0b223ffd&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Dca25fa6b-e233-43f7-90c3-e68e4c5b0bc5&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D7f18e5f1-cfda-4148-ab86-b3d2e6547262&w=3840&q=75)




.webp%3Falt%3Dmedia%26token%3D6ca2c2ef-9413-4453-b992-55b66b11ed54&w=3840&q=75)



.webp%3Falt%3Dmedia%26token%3D900f385d-12a2-449b-8d1e-83a57cef0088&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D0e802fb0-2dda-44a7-bf80-5d39019635ba&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D3fb3dc66-ecca-402e-8fb8-fbec9407f7f5&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Ddb21d760-e1ed-4ec2-af28-3462041e31b5&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Dcce7bd72-f11e-4292-86bf-e6ccf3e7bf32&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D457ff920-e0df-4ff5-95eb-e29f74b73823&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3Dc21fcc77-7404-458d-9eb5-85b8d84ae1bc&w=3840&q=75)
.webp%3Falt%3Dmedia%26token%3D92052f12-5280-49df-877a-b514582e95db&w=3840&q=75)