【发布时间】:2018-08-19 21:06:09
【问题描述】:
我正在创建一个搜索屏幕,您可以在其中选择四个不同的选项。如果选择人员,则人员数组会加载到表格视图单元格中,如果他选择图像,则图像帖子会加载到表格视图中。
我怎样才能实现上面发布的设计?我已经创建了四个不同的单元格和 nib 文件,并且根据在段控制中选择的选项,我必须将这些 nib 文件加载到表格单元格中。
更新 ::::
我在这里更新我已合并到一个文件中的所有代码。
import UIKit
import Alamofire
class SearchViewController: UIViewController , UITableViewDataSource , UITableViewDelegate , UISearchBarDelegate{
var imagepost : ImageSeachPostData!
var imageposts = [ImageSeachPostData]()
var videopost : VideoSeachPostData!
var videoposts = [VideoSeachPostData]()
var statuspost : StatusSearchPostData!
var statusposts = [StatusSearchPostData]()
var penpalpost : PenpalSearchPostData!
var penpalposts = [PenpalSearchPostData]()
var tablearray : NSArray = []
typealias DownloadComplete = () -> ()
@IBOutlet weak var searchTable: UITableView!
@IBOutlet weak var searchBar: UISearchBar!
@IBOutlet weak var searchTypeSegmentControl: UISegmentedControl!
override func viewDidLoad() {
super.viewDidLoad()
searchTable.dataSource = self
searchTable.delegate = self
searchBar.delegate = self
searchPassed()
}
@IBAction func onChangeSegment(_ sender: UISegmentedControl)
{
self.searchTable.reloadData()
}
func searchBarSearchButtonClicked(_ searchBar: UISearchBar) {
view.endEditing(true)
}
func searchBar(_ searchBar: UISearchBar, textDidChange searchText: String) {
if searchBar.text == nil || searchBar.text == "" {
searchTable.reloadData()
view.endEditing(true)
} else {
searchPassed()
searchTable.reloadData()
}
}
func searchPassed()
{
let searchText = "Postpositives"
print(searchText)
var request = URLRequest(url: URL(string: "https://www.example.com/search")!)
request.httpMethod = "GET"
let postString = "q=\(searchText)"
request.httpBody = postString.data(using: .utf8)
let task = URLSession.shared.dataTask(with: request) { data, response, error in
guard let data = data, error == nil else { // check for fundamental networking error
print("error=\(String(describing: error))")
print("cant run")
return
}
if let httpStatus = response as? HTTPURLResponse, httpStatus.statusCode != 200 { // check for http errors
print("statusCode should be 200, but is \(httpStatus.statusCode)")
print("response = \(String(describing: response))")
print("\(searchText)")
}
else {
let responseString = String(data: data, encoding: .utf8)
print("responseString = \(String(describing: responseString))")
// func downloadPostData(completed: @escaping DownloadComplete) {
Alamofire.request("https://www.example.com/api/search?q=\(searchText)").responseJSON { response in
let result = response.result
if let dict = result.value as? Dictionary<String,AnyObject> {
if let successcode = dict["STATUS_CODE"] as? Int {
if successcode == 1 {
if let postsArray = dict["posts"] as? [Dictionary<String,AnyObject>]
{
for obj in postsArray
{
let mediatype = dict["media_type"] as! String?
if mediatype == "image"
{
let imagepost = ImageSeachPostData(postDict: obj)
self.imageposts.append(imagepost)
}
else if mediatype == "video"
{
let videopost = VideoSeachPostData(postDict: obj)
self.videoposts.append(videopost)
}
else if mediatype == "null"
{
let statuspost = StatusSearchPostData(postDict: obj)
self.statusposts.append(statuspost)
}
let penpalpost = PenpalSearchPostData(postDict: obj)
self.penpalposts.append(penpalpost)
}
self.searchTable.reloadData()
}
}
}
}
}
}
}
}
task.resume()
}
func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
let selectedIndex = self.searchTypeSegmentControl.selectedSegmentIndex
switch selectedIndex
{
case 0:
return penpalposts.count
case 1:
return statusposts.count
case 2:
return imageposts.count
case 3:
return videoposts.count
default:
return 0
}
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let selectedIndex = self.searchTypeSegmentControl.selectedSegmentIndex
switch selectedIndex
{
case 0:
return tableView.dequeueReusableCell(withIdentifier: "penpalSearchReuse", for: indexPath)
case 1:
return tableView.dequeueReusableCell(withIdentifier: "statusSearchReuse", for: indexPath)
case 2:
return tableView.dequeueReusableCell(withIdentifier: "imageSearchReuse", for: indexPath)
case 3:
return tableView.dequeueReusableCell(withIdentifier: "videoSearchReuse", for: indexPath)
default:
return UITableViewCell()
}
}
func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {
return 420
}
}
【问题讨论】:
-
到目前为止你尝试过什么?你可以使用 UISearchController 实现你想要的。查找 searchBar 的 scopedButtonTitles 属性
-
上传所有代码并不会突然变得不那么宽泛,只会让阅读时间更长!
标签: ios swift search uisegmentedcontrol