Как отобразить данные одного tableview в двух сегментах в swift

#swift #segment

#swift #сегмент

Вопрос:

Я использую XLPagerTabStrip для сегмента

я хочу показать данные одного tableview в двух сегментах с сортировкой, для этого я использую приведенный ниже код

Код SegmentViewController: если я добавлю child_2.isSorted = false ошибку

Значение типа ‘UIViewController’ не имеет элемента ‘isSorted’

 import UIKit
import XLPagerTabStrip

class SegmentViewController: ButtonBarPagerTabStripViewController {

@IBOutlet weak var testSeg: ButtonBarView!

override func viewDidLoad() {
    super.viewDidLoad()
    // change selected bar color
    // Sets the background colour of the pager strip and the pager strip item
        settings.style.buttonBarBackgroundColor = .white
        settings.style.buttonBarItemBackgroundColor = .yellow

        // Sets the pager strip item font and font color
        settings.style.buttonBarItemFont = UIFont(name: "Helvetica", size: 15.0)!
        settings.style.buttonBarItemTitleColor = .gray

        changeCurrentIndexProgressive = { [weak self] (oldCell: ButtonBarViewCell?, newCell: ButtonBarViewCell?, progressPercentage: CGFloat, changeCurrentIndex: Bool, animated: Bool) -> Void in
              guard changeCurrentIndex == true else { return }
              oldCell?.label.textColor = .gray
              newCell?.label.textColor = .blue
        }
    // Do any additional setup after loading the view.
    
    }
override func viewDidLayoutSubviews() {
        super.viewDidLayoutSubviews()
        self.buttonBarView.frame = testSeg.frame
    }
override func viewControllers(for pagerTabStripController: PagerTabStripViewController) -> [UIViewController] {
let child_1 = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "SegTableViewController")
let child_2 = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "SegTableViewController")
    child_2.isSorted = false

return [child_1, child_2]
    
    
}        
}
 

Код SegTableViewController: здесь в обоих сегментах показаны только sortedArray те, которые мне нужны в первом сегменте sortedArray и втором сегменте namesArray .. как это сделать .. может кто-нибудь, пожалуйста, посоветуйте мне

  import UIKit
import XLPagerTabStrip
class SegTableViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, IndicatorInfoProvider {

var sortedArray = [String]()
var isSorted = true

func indicatorInfo(for pagerTabStripController: PagerTabStripViewController) -> IndicatorInfo {
    
    if isSorted{
        return IndicatorInfo(title: "Sorted")

    }else{
    return IndicatorInfo(title: "Normal")
    }

}
@IBOutlet weak var tableView: UITableView!

var namesArray = ["afsdf","ddsfsdf", "hjhgjh", "trytryr", "nvbmvnb", "yuertyri", "bmvmncb", "jgfhk", "ytuioi", "sdfgsfdsh", "mkhjgijik", "gfuyru"]

override func viewDidLoad() {
    super.viewDidLoad()

    // Do any additional setup after loading the view.
     sortedArray = namesArray.sorted { $0.localizedCaseInsensitiveCompare($1) == ComparisonResult.orderedDescending }
    self.tableView.register(UITableViewCell.self, forCellReuseIdentifier: "cell")

}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    if isSorted {
       return sortedArray.count
    }
    else{
    return namesArray.count
}
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    
    let cell = tableView.dequeueReusableCell(withIdentifier: "cell") as! UITableViewCell
    
    if isSorted{
    cell.textLabel?.text = sortedArray[indexPath.row]

    }
    else{
        cell.textLabel?.text = namesArray[indexPath.row]
    }
    return cell
}
}
 

Ответ №1:

Вам нужно использовать свой контроллер представления следующим образом

 override func viewControllers(for pagerTabStripController: PagerTabStripViewController) -> [UIViewController] {
    let child_1 = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "SegTableViewController")
    let child_2 = UIStoryboard(name: "Main", bundle: nil).instantiateViewController(withIdentifier: "SegTableViewController")
    (child_2 as? SegTableViewController).isSorted = false
    return [child_1, child_2]
}
 

Кроме того, нет необходимости в массиве для отображения данных. Используйте только один массив namesArray , подобный этому

 override func viewDidLoad() {
    super.viewDidLoad()
    
    // Do any additional setup after loading the view.
    if isSorted {
        namesArray = namesArray.sorted { $0.localizedCaseInsensitiveCompare($1) == ComparisonResult.orderedDescending }
    }
    self.tableView.register(UITableViewCell.self, forCellReuseIdentifier: "cell")
    
}