11

Swift で UITableView と UISearchBar を使用して新しいアプリを作成していますが、既に正常に動作しています。しかし、最終的なプロジェクトには完全にカスタマイズされた検索バーが必要なので、カスタマイズの可能性があるため、入力アウトレットとして UITextField に移動する必要がありました。

問題は、UITextField が UISearchBar のように動作するようにコーディングする方法を理解できないことです。UITextField 入力をフィルタリングし、文字列を UISearchBarDelegate メソッドで使用できるようにする方法がわかりません。

誰でもこれで私を助けることができますか?

編集:私はダニエルの助けに従って、このコードを思いつきましたが、「nil」を返し、機能していません。

class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate, UITextFieldDelegate {

@IBOutlet weak var txtSearchBar: UITextField!
var searchTxt = ""
let prods = ["água", "terra", "ar", "fogo"]
var searchResults:[String] = []

override func viewDidLoad() {
    super.viewDidLoad()
    // Do any additional setup after loading the view, typically from a nib.
    
    txtSearchBar.delegate = self
}


func textFieldDidEndEditing(textField: UITextField) {
    searchTxt = textField.text
    println(searchTxt)
    searchResults = prods.filter({(produtos:String) -> Bool in
        
        let nameMatch = produtos.rangeOfString(self.searchTxt, options: NSStringCompareOptions.CaseInsensitiveSearch)
        
        println(nameMatch)
        return nameMatch != nil})
}

私の入力は文字「ar」でしたが、配列のオブジェクトの1つが「ar」であるため、返されるべきではないときに「nil」が返されました。

4

4 に答える 4

12

uitextfield オブジェクトを作成します。

@IBOutlet var SearchTxt: UITextField!
var search:String=""

@IBOutlet var ListTable: UITableView!
var AllData:Array<Dictionary<String,String>> = []
var SearchData:Array<Dictionary<String,String>> = []

ビューの読み込み:

override func viewDidLoad()
{
    super.viewDidLoad()

    AllData = [["pic":"list0.jpg", "name":"Angel Mark", "msg":"Hi there, I would like read your...", "time":"just now", "unread":"12"],
               ["pic":"list1.jpg", "name":"John Doe", "msg":"I would prefer reading on night...", "time":"56 second ago", "unread":"2"],
               ["pic":"list2.jpg", "name":"Krishta Hide", "msg":"Okey Great..!", "time":"2m ago", "unread":"0"],
               ["pic":"list3.jpg", "name":"Keithy Pamela", "msg":"I am waiting there", "time":"5h ago", "unread":"0"]
               ]

    SearchData=AllData
}

テキストフィールドデリゲートメソッドで検索:

func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool
{
    if string.isEmpty
    {
        search = String(search.characters.dropLast())
    }
    else
    {
        search=textField.text!+string
    }

    print(search)
    let predicate=NSPredicate(format: "SELF.name CONTAINS[cd] %@", search)
    let arr=(AllData as NSArray).filtered(using: predicate)

    if arr.count > 0
    {
        SearchData.removeAll(keepingCapacity: true)
        SearchData=arr as! Array<Dictionary<String,String>>
    }
    else
    {
        SearchData=AllData
    }
    ListTable.reloadData()
    return true
}

tableview での検索データ表示:

func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int
{
    return SearchData.count
}

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell
{
    let cell = tableView.dequeueReusableCell(withIdentifier: "ListCell") as! ListCell

    var Data:Dictionary<String,String> = SearchData[indexPath.row]

    cell.Pic.image=UIImage(named: Data["pic"]!)
    cell.Name.text = Data["name"]
    cell.Msg.text = Data["msg"]
    cell.Time.text = Data["time"]

    cell.selectionStyle = .none
    return cell
}
于 2016-11-10T05:28:58.473 に答える
3

あなたの主な質問は、UISearchBar と同じように機能するクラスを実装する方法を尋ねているようです。それは大事業になるでしょう!

ただし、メモでは、検索ボタンがタップされた場合の対応方法を尋ねるだけです。

IBAction と 2 番目の配列をビュー コントローラーに追加します。2 番目の配列を「foundItems」のように呼び出します。IBAction を検索ボタンに接続します。アクションが呼び出されたら、テキスト フィールドからテキストを読み取り、そのテキストに基づいてアイテムをフィルタリングします。フィルターに適合するアイテムを foundItems 配列に配置し、テーブル ビューで reloadData() を呼び出します。

テーブル ビュー データ ソース メソッドで、foundItems が nil でないかどうかを確認します。そうでない場合は、メイン項目配列の代わりにそれらを表示します。

また、何らかのキャンセル ボタンが必要になります。そのボタンのアクションで、foundItems 配列を nil アウトし、テーブル ビューで reloadData() を呼び出します。

于 2014-10-19T01:56:28.270 に答える