UISearchBar извлекает данные из Json - PullRequest
0 голосов
/ 30 октября 2018

Я использую API. Я публикую некоторые данные и храню ответ в виде таблицы. Я поставил панель поиска для поиска данных из таблицы. Я хочу, когда я пишу 3 слова в строке поиска, после этого мой API вызовет и данные отобразятся в виде таблицы. Я использую uitextfield для панели поиска.

var array = [String]()
var tabledata = [String]()
var tableFilterData = [String]()
var isSearch :Bool!

let cellReuseIdentifier = "cell"

@IBOutlet weak var searchTextfield: UITextField!

@IBOutlet weak var tableview: UITableView!

@IBOutlet weak var heightConstraint: NSLayoutConstraint!

@IBAction func textfieldchanged(_ sender: Any) {

      tableview.isHidden = true
}

override func viewDidLoad() {
    super.viewDidLoad()

    isSearch = false
    self.apicalling()

    searchTextfield.addTarget(self, action: #selector(textFieldActive), for: UIControlEvents.touchDown)

}
  public func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool{

    var searchText  = textField.text! + string

    if string  == "" {
        searchText = (searchText as String).substring(to: searchText.index(before: searchText.endIndex))
    }
    if searchText == "" {
        isSearch = false
        tableview.reloadData()
    }
    else{
        getSearchArrayContains(searchText)
    }

    return true
}
 func getSearchArrayContains(_ text : String) {
    var predicate : NSPredicate = NSPredicate(format: "SELF CONTAINS[c] %@", text)
     tableFilterData = (tabledata as NSArray).filtered(using: predicate) as! [String]
    isSearch = true
    tableview.reloadData()

}
 override func viewDidLayoutSubviews()
{  
    heightConstraint.constant = tableview.contentSize.height
}

override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?)
{
    guard let touch:UITouch = touches.first else
    {
        return;
    }
    if touch.view != tableview
    {
        searchTextfield.endEditing(true)
        tableview.isHidden = true
    }
}

@objc func textFieldActive() {

     tableview.isHidden = !tableview.isHidden
}
 func textFieldShouldReturn(_ textField: UITextField) -> Bool {
    textField.resignFirstResponder()

    return true
}

моя часть просмотра таблицы это

 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    if isSearch! {
        return tableFilterData.count
    }
    else{
        return tabledata.count
    }
}

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell:UITableViewCell = tableView.dequeueReusableCell(withIdentifier: "cell") as UITableViewCell!
    // Set text from the data model

    if isSearch! {
        cell.textLabel?.text = tableFilterData[indexPath.row]
        cell.textLabel?.font = searchTextfield.font
    }
    else{
        cell.textLabel?.text = tabledata[indexPath.row]
        cell.textLabel?.font = searchTextfield.font
    }
    return cell
}

В моем API-вызове мой параметр это

  let param = ["var_name": "sha","API":"user_search","auth_token":authToken!]

но я хочу, чтобы данные поиска передавались в "var_name". моя поисковая панель работает нормально, но я хочу, чтобы я написал 3 слова в поисковой строке после того, как вызовет этот API, и эти три данные будут переданы в API в качестве параметров в "var_name".

...