簡體   English   中英

如何在Swift 3.1.1中使用getter setter方法搜索欄?

[英]how to use getter setter method for search bar in swift 3.1.1?

我已經在我的應用程序中實現了搜索欄。 我有一些酒店的JSON數據。 (名稱,圖片,地址,手機號碼,電子郵件)。 我在搜索結果中得到了名字,但我想獲得特定酒店的全部數據。 因此,請幫助我實現搜索功能。 我想使用getter setter方法。 請幫忙。 提前致謝!!

let str = self.catArr [indexPath.row]
    let url1 = "myapi"
    let url2 = url1+str

    let allowedCharacterSet = (CharacterSet(charactersIn: " ").inverted)
    if let url = url2.addingPercentEncoding(withAllowedCharacters: allowedCharacterSet)
    {
        Alamofire.request(url).responseJSON { (responseData) -> Void in

            if (responseData.result.value) == nil
            {
                print("Error!!")
            }

            //if (responseData.result.value) != nil
            else
            {
                let response = JSON(responseData.result.value!)

                if let resData = response["data"].arrayObject
                {
                    self.arrResponse1 = resData as! [[String: AnyObject]]

                    for item in self.arrResponse1
                    {
                        let name = item["name"] as! String
                        self.arrName.append(name)

                        let add = item["address"] as! String
                        self.arrAddress.append(add)

                        let web = item["website"] as! String
                        self.arrWebsite.append(web)

                        let email = item["email"] as! String
                        self.arrEmail.append(email)

                        let mob = item["mobile"] as! String
                        self.arrMobile.append(mob)

                        let city = item["city"] as! String
                        self.arrCity.append(city)

                        let state = item["state"] as! String
                        self.arrState.append(state)

                        let dist = item["district"] as! String
                        self.arrDistrict.append(dist)

                        let area = item["area"] as! String
                        self.arrArea.append(area)

                        let img = item["image"] as! String
                        self.arrImage.append(img)

                        let rating = item["rating"] as! String
                        self.arrRating.append(rating)

                        let id = item["id"] as! String
                        self.arrId.append(id)
                    }
                }
            }
        }
    }

func searchBar(_ searchBar: UISearchBar, textDidChange searchText: String)
{
    filteredName = self.nameArr.filter({ (String) -> Bool in
        let tmp: NSString = String as NSString
        let range = tmp.range(of: searchText, options: NSString.CompareOptions.caseInsensitive)
        return range.location != NSNotFound
    })

    if(filteredName.count == 0)
    {
        searchActive = false;
    }

    else
    {
        searchActive = true;
        print("Search Array = \(filteredName)")
    }

    self.infoTableView.reloadData()
}

//在表格視圖中顯示if(searchActive){cell.lblName.text = self.filteredName [indexPath.row]}

    else
    {
        let urlImage = str1+self.imageArr [indexPath.row]+".jpg"

        cell.imgView.sd_setImage(with: URL(string: urlImage), placeholderImage: UIImage(named: ""))
        cell.lblName.text = self.nameArr [indexPath.row]
        cell.lblAddress.text = self.addressArr [indexPath.row]
        cell.lblCity.text = self.cityArr [indexPath.row]
        cell.lblPhone.text = self.mobileArr [indexPath.row]
        cell.lblEmail.text = self.emailArr [indexPath.row]
        cell.lblStar.text = self.ratingArr [indexPath.row]

        cell.phoneString = self.mobileArr [indexPath.row]
        cell.emailString = self.emailArr [indexPath.row]
    }

不需要使用多個數組來存儲每個值,您需要的是自定義class/struct對象的數組,然后使用它輕松使用filter

struct Item { //Make some suitable name 
    let id: String
    let name: String
    let address: String
    let website: String
    let email: String
    let mobile: String
    let city: String
    let state: String
    let district: String
    let area: String
    let image: String
    let rating: String

    init(dictionary: [String:Any]) {
        self.id = dictionary["id"] as? String ?? "Default Id"
        self.name = dictionary["name"] as? String ?? "Default name"
        self.address = dictionary["address"] as? String ?? "Default address"
        self.website = dictionary["website"] as? String ?? "Default website"
        self.email = dictionary["email"] as? String ?? "Default email"
        self.mobile = dictionary["mobile"] as? String ?? "Default mobile"
        self.city = dictionary["city"] as? String ?? "Default city"
        self.state = dictionary["state"] as? String ?? "Default state"
        self.district = dictionary["district"] as? String ?? "Default district"
        self.area = dictionary["area"] as? String ?? "Default area"
        self.image = dictionary["image"] as? String ?? "Default image"
        self.rating = dictionary["rating"] as? String ?? "Default rating"
    }
}

現在,您只需要兩個[Item]類型的數組,一個用於普通數據,一個用於filter數據,因此聲明兩個這樣的數組。

var items = [Item]()
var filterItems = [Item]()

以這種方式在您的Alamofire請求中初始化此items數組。

let response = JSON(responseData.result.value!)

if let resData = response["data"].arrayObject as? [[String: Any]] {
    self.items = resData.map(Item.init)
}

現在像這樣在tableView方法中使用這兩個數組。

func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    if searchActive {
         return filterItems.count
    }
    return items.count
}

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as! YourCustomCell
    let item = searchActive ? filterItems[indexPath.row] : items[indexPath.row]
    cell.lblName.text = item.name
    cell.lblAddress.text = item.address
    //...Set others detail same way
    return cell
}

現在,使用textDidChange這種方式過濾您的items數組。

func searchBar(_ searchBar: UISearchBar, textDidChange searchText: String)
{
    filterItems = self.items.filter({ 
         $0.name.localizedCaseInsensitiveContains(searchText) 
    })

    if(filterItems.count == 0) {
        searchActive = false
    }            
    else {
        searchActive = true
        print("Search Array = \(filterItems)")
    }        
    self.infoTableView.reloadData()
}

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM