UICollectionView 委托方法的问题

Posted

技术标签:

【中文标题】UICollectionView 委托方法的问题【英文标题】:Problem with UICollectionView delegate methods 【发布时间】:2018-11-30 16:56:30 【问题描述】:

我正在尝试使用UICollectionView,它显示在视图上,但没有调用委托方法。这是我正在尝试做的事情:

在 Storyboard 上,我有一个 UITableViewController,其中有一个 TableView 和一个 UIView,如下所示:

我在UITableViewController 班级上为UIView 创建了一个出口:

class FeedTableViewController: UITableViewController 

    @IBOutlet weak var bannerView: UIView!


viewDidLoad() 函数上,我正在实例化UIViewController 类,它将成为我的UICollectionView 的委托和数据源:

override func viewDidLoad() 
    let bannerViewController = BannerViewController()
    bannerView.addSubview(bannerViewController.view)

    bannerViewController.view.translatesAutoresizingMaskIntoConstraints = false
    bannerViewController.view.leadingAnchor.constraint(equalTo: bannerView.leadingAnchor).isActive = true
    bannerViewController.view.trailingAnchor.constraint(equalTo: bannerView.trailingAnchor).isActive = true
    bannerViewController.view.topAnchor.constraint(equalTo: bannerView.topAnchor).isActive = true
    bannerViewController.view.bottomAnchor.constraint(equalTo: bannerView.bottomAnchor).isActive = true

这是BannerViewController类的完整代码:

class BannerViewController: UIViewController 

    override func viewDidLoad() 
        super.viewDidLoad()

        let frame = CGRect(x: 0, y: 0, width: view.frame.size.width, height: 125)
        let collectionView = UICollectionView(frame: frame, collectionViewLayout: UICollectionViewFlowLayout())
        collectionView.register(UICollectionViewCell.self, forCellWithReuseIdentifier: "collectionCell")
        collectionView.delegate = self
        collectionView.dataSource = self
        collectionView.backgroundColor = .cyan

        view.addSubview(collectionView)
    



extension BannerViewController: UICollectionViewDataSource 

    // MARK: UICollectionViewDataSource

    func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int 
        return 3
    

    func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell 
        let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "collectionCell", for: indexPath)
        cell.backgroundColor = .red
        return cell
    



extension BannerViewController: UICollectionViewDelegateFlowLayout 

    // MARK: UICollectionViewDelegateFlowLayout

    func collectionView(_ collectionView: UICollectionView, layout collectionViewLayout: UICollectionViewLayout, sizeForItemAt indexPath: IndexPath) -> CGSize 
        return CGSize(width: collectionView.bounds.size.width, height: collectionView.bounds.size.height)
    


UICollectionView 正在被实例化并出现在视图中,正如我们在此处的青色框上看到的那样:

但是没有调用委托方法numberOfItemsInSectioncellForItemAt。而且我已经将BannerViewController注册为UICollectionView的数据源和委托,所以我不知道为什么它不起作用。

【问题讨论】:

【参考方案1】:

你需要持有一个强引用(使其成为实例变量)

var bannerViewController:BannerViewController!

也正确添加

bannerViewController = BannerViewController()
addChildViewController(bannerViewController)
view.addSubview(bannerViewController.view)
bannerViewController.view.translatesAutoresizingMaskIntoConstraints =false
NSLayoutConstraint.activate([
    bannerViewController.view.leadingAnchor.constraint(equalTo: bannerView.leadingAnchor),
    bannerViewController.view.trailingAnchor.constraint(equalTo: bannerView.trailingAnchor),
    bannerViewController.view.topAnchor.constraint(equalTo: bannerView.topAnchor),
    bannerViewController.view.bottomAnchor.constraint(equalTo: bannerView.bottomAnchor)
])
bannerViewController.didMove(toParentViewController: self)

别忘了

extension BannerViewController: UICollectionViewDelegate 

【讨论】:

强烈引用bannerViewController 已解决问题,谢谢!

以上是关于UICollectionView 委托方法的问题的主要内容,如果未能解决你的问题,请参考以下文章

为啥 UICollectionView 的委托方法不起作用?

在实例化单元格之前调用 UICollectionView 委托方法?

UICollectionView 委托方法没有被正确调用

UICollectionView 未显示 & 未调用委托/数据源方法

UICollectionView:如何在委托方法中设置特定项目后获取项目大小

UICollectionView如何从委托中重新加载数据