Menggunakan snapkit/autolayout dengan UIScrollView

Saya memiliki aplikasi yang akan memiliki

  • scrollView
    • contentView
      • chart
      • tombol
      • hal-hal lain

Saya mencoba membatasinya seperti yang ditunjukkan di bawah ini, tetapi saya kehilangan batasan dan saya tidak dapat menemukan apa yang saya perlukan.

    self.view.addSubview(self.scrollView)
    self.scrollView.snp.makeConstraints { (make) in
        make.edges.equalTo(self.view)
    }
    let contentView = UIView()

    self.scrollView.addSubview(contentView)
    contentView.snp.makeConstraints { (make) in
        make.top.bottom.equalTo(self.scrollView)
        make.left.right.equalTo(self.view)
    }
    contentView.addSubview(self.chart)
    self.chart.snp.makeConstraints { (make) in
        // http://snapkit.io/docs/
        make.edges.equalTo(contentView).inset(UIEdgeInsets(top: 30, left: 0, bottom: 50, right: 0))
    }

dimana scrollView = UIScrollView()


person Peter S    schedule 17.10.2018    source sumber


Jawaban (2)


Anda perlu menambahkan batasan lebar/tinggi atau perataan untuk contentView. Coba ini:

contentView.snp.makeConstraints { (make) in
    make.top.bottom.equalTo(self.scrollView)
    make.left.right.equalTo(self.view)
    make.width.equalTo(self.scrollView)
    make.height.equalTo(self.scrollView)
    // or:
    // make.centerX.equalTo(self.scrollView)
    // make.centerY.equalTo(self.scrollView)
}
person Ilya Kharabet    schedule 17.10.2018
comment
terima kasih. Bagaimana cara mengatur tinggi konten scrollView berdasarkan contentView? - person Peter S; 17.10.2018
comment
Tinggi konten akan dihitung secara otomatis - person Ilya Kharabet; 17.10.2018

Jawaban singkat @Ilya Kharabet:

contentView.snp.makeConstraints { (make) in
    make.left.right.equalTo(self.view)
    make.width.height.top.bottom.equalTo(self.scrollView)
}

PS:

biasanya kami menggunakan make.leading.trailing, bukan make.left.right, untuk Dukungan RTL.

person dengST30    schedule 17.12.2019