【Swift UI】ScrollViewのスクロールを止める方法!

この記事からわかること

  • Swift UIScrollViewスクロールさせない方法
  • scrollDisabled使い方
  • iOS15以前の指定方法
  • Listをスクロールさせない方法

index

[open]

\ アプリをリリースしました /

みんなの誕生日

友達や家族の誕生日をメモ!通知も届く-みんなの誕生日-

posted withアプリーチ

環境

ScrollViewのスクロールを動作しないようにする

公式リファレンス:scrollDisabled

Swift UIのScrollViewのスクロールを動作しないように停止させておくにはscrollDisabledモディファイアを使用します。引数には停止させたい場合はtrueを、スクロールさせたい場合はfalseを指定します。

ScrollView {
  //
}.scrollDisabled(true)

このモディファイアはiOS16以降からしか使用できません。

iOS15以前

iOS15以前で実装したい場合はScrollViewの引数に空の配列を渡すことでスクロールできないように設定することが可能です。


ScrollView([]) {
  //
}

ScrollViewの第一引数にはAxis.Set型でスクロールを許可する方向を渡します。デフォルト値がverticalなのであえて空の配列を渡すことでスクロールの許可をなくすことができます。

init(
    _ axes: Axis.Set = .vertical,
    @ViewBuilder  content: () -> Content
)

Listにも使用できる

scrollDisabledListにも利用することが可能です。

List {
    ForEach((1...50), id: \.self) { num in
        Text("\(num)")
    }
}.scrollDisabled(true)

まだまだ勉強中ですので間違っている点や至らぬ点がありましたら教えていただけると助かります。

ご覧いただきありがとうございました。

searchbox

スポンサー

ProFile

ame

趣味:読書,プログラミング学習,サイト制作,ブログ

IT嫌いを克服するためにITパスを取得しようと勉強してからサイト制作が趣味に変わりました笑
今はCMSを使わずこのサイトを完全自作でサイト運営中〜

New Article

index