Type 'x' does not conform to protocol 'UIPickerViewDataSource'

    import UIKit

class FourthViewController: UIViewController,UIPickerViewDelegate,UIPickerViewDataSource {


    @IBOutlet weak var picker: UIPickerView!

      var pickerData: [String] = [String]()


    override func viewDidLoad() {
        super.viewDidLoad()

        // Do any additional setup after loading the view.

        self.picker.delegate = self
        self.picker.dataSource = self

        pickerData = ["Item 1", "Item 2", "Item 3", "Item 4", "Item 5", "Item 6"]    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }

    //MARK: - Delegates and data sources
    //MARK: Data Sources
    func numberOfComponentsInPickerView(pickerView: UIPickerView) -> Int {
        return 1
    }
    func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
        return pickerData.count
    }

    //MARK: Delegates
    func pickerView(pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
        return pickerData[row]
    }
    /*
    // MARK: - Navigation

    // In a storyboard-based application, you will often want to do a little preparation before navigation
    override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
        // Get the new view controller using segue.destinationViewController.
        // Pass the selected object to the new view controller.
    }
    */

}

Error: Type 'FourthViewController' does not match 'UIPickerViewDataSource' protocol

Just to test some features, but I don't understand the problem

+4
source share
5 answers

As you find, you need to implement numberOfComponents(in:).

Your numberOfComponentsInPickerView(pickerView: UIPickerView) -> Intneed to change to:

func numberOfComponents(in pickerView: UIPickerView) -> Int {
    return 1
}

Also you need to change your pickerView(pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String?:

func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
    return pickerData[row]
}

In Swift 3, many methods are renamed. Check out the last link and be careful with this . And you better notice the version of Xcode in your question.

+11
source

:

public func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int

:

//MARK: - Delegates and data sources
        //MARK: Data Sources
        public func numberOfComponents(in pickerView: UIPickerView) -> Int {
            return 1
        }

        public func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
            return pickerData.count
        }

        //MARK: Delegate
        func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
            return pickerData[row]
        }
+4

You must implement all the necessary methods UIPickerViewDataSourceand UIPickerViewDelegateif you confirm this protocol c swift. otherwise it will give an error at compile time.

+1
source

I got an error due to delegate method

func numberOfComponentsInPickerView(pickerView: UIPickerView) -> Int 
    {
    if pickerView == stylePickerView {
        return 1        }
    else if pickerView == fontPickerView {
        return 1        }
    return 0
    }

tried it and worked

@available(iOS 2.0, *)
public func numberOfComponents(in pickerView: UIPickerView) -> Int {
    if pickerView == stylePickerView {
        return 1        }
    else if pickerView == fontPickerView {
        return 1        }
    return 0 
}
0
source

You are missing this delegate:

func numberOfComponents(in pickerView: UIPickerView) -> Int {
    return 1
}
0
source

Source: https://habr.com/ru/post/1653612/


All Articles