因为我是swift的新手我对我的代码有一个问题究竟是什么问题!我有表视图,我应该把一些数据从API中获取。我正在使用alamofire和moya。
我在我的vc中调用此func来请求网络:
class SmsPresenter
{
var view:SmsView?
func attachView(view: SmsView){
self.view = view
}
func gettingEveyThing( aptId : String){
ApiGenerator.request(targetApi: ApartemanService.getSmsInfo(aptId: aptId), responseModel: smsModelList.self, success: { (response) in
self.view?.GettingEverthingSuccess(response: response.body)
}) { (error) in
print(error)
self.view?.GettingEvethingFailed(errorMessage: "error")
}
}
这是我在这里存储它们的数据模型:
typealias smsModelList = [SmsModel]
struct SmsModel:Codable {
var unitNo:Int?
var unitPlaque:String?
var billText:String?
var contacts:[ContactsModel?]
}
struct ContactsModel:Codable
{
var id :Int?
var selected :Bool?
var phoneNumber : String?
var name : String?
}
当我得到200状态代码时这就是func:
func GettingEverthingSuccess(response: smsModelList?) {
print("getting evething success")
guard let response = response else {
return
}
self.data = response
self.tableview.reloadData()}
我的声明:
var Presenter = SmsPresenter()
var data : smsModelList?
var Pphone : [String] = []
var Nname : [String] = []
var Iid : [Int] = []
填充表:
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "SmsCell") as? SmsTableViewCell
if let contacts = data?[indexPath.row].contacts
{
for eachmain in contacts
{
Pphone.append((eachmain?.phoneNumber)!)
Nname.append((eachmain?.name)!)
Iid.append((eachmain?.id)!)
}
}
}
我的代码究竟出了什么问题:| !当我运行代码时,它将第一个数字放在第一行,然后再将第二个数字放入第一个ro,尽管它应该为第二个数字行放置第二个数字和其他数字。
Api响应:
[
{
"contacts": [
{
"id": 9827,
"selected": true,
"phoneNumber": "00987684044",
"name": "OWNER"
}
],
"unitNo": 1,
"unitPlaque": "Jack",
"billText": "TEXTTEXT"
},
{
"contacts": [
{
"id": 10145,
"selected": true,
"phoneNumber": "098887776655",
"name": "mmm"
}
],
"unitNo": 2,
"unitPlaque": "mm",
"billText": "TEXTTEXT"
}
]
照片:Photo
我的最终答案是所有答案的组合
由于力量展开data
值,你得到的第一次崩溃。
您可以使用nil返回数据计数
data.count ?? 0
在这个例子中,似乎你在tableView(_:cellForRowAt:)
中迭代值。这不是一个好主意,因为这个方法会被多次调用来显示表格。在cellForRow块内出列并配置单元格并立即返回单元格。
首先以您需要的格式填充数据。
func GettingEverthingSuccess(response: smsModelList?) {
print("getting evething success")
guard let response = response else { return }
let contacts = response.flatMap { $0.contacts }
for contact in contacts {
Pphone.append(contact.phoneNumber!)
Nname.append(contact.name!)
Iid.append(contact.id!)
}
self.tableview.reloadData()
}
func numberOfSections(in tableView: UITableView) -> Int {
return data.count ?? 0
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
guard let data = data else { return }
return data.contacts.count
}
func tableView( tableView : UITableView, titleForHeaderInSection section: Int)->String {
return data?[section].unitPlaque ?? ""
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "SmsCell") as? SmsTableViewCell
if let data = data, let contacts = data[indexPath.section].contacts, let contact = contacts[indexPath.row] {
cell.phoneNumber = contact.phoneNumber!
// ... more
}
}
您正在填充Table View错误。首先,您需要在表视图中添加多个部分:
func numberOfSections(in tableView: UITableView) -> Int {
return data.count
}
然后,您需要在部分中添加行数
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return Pphone.count
}
然后应该像这样填充表视图
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "SmsCell") as? SmsTableViewCell
cell.yourLabelInsideCell.text = Nname[indexPath.row]
cell.otherLabelInsideCell.text = Pphone[indexPath.row]
cell.idLabelInsideCell.text = Iid[indexPath.row]
// etc
}
此外,您还需要在收到请求时将响应映射到变量:
func GettingEverthingSuccess(response: smsModelList?) {
print("getting evething success")
guard let response = response else {
return
}
self.data = response
for contactData in data {
if let contacts = contactData.contacts {
for eachmain in contacts {
Pphone.append(eachmain.phoneNumber!)
Nname.append(eachmain.name!)
Iid.append(eachmain.id!)
}
}
}
self.tableview.reloadData()
}
不要忘记变量应该以小写字母开头......
你添加了numberOfRowsInSection,你传递的值是多少?根据您的代码,它需要像下面的代码
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return data.count
}
使用下面的代码(即我们必须检查数据数组是否有任何值)
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
if data != nil {
return data.count
}
}
首先填充数据返回numberOfRowsInSection。
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return data.count
}
另外正如你所说的你的应用程序在返回data.count时崩溃然后确保在表重新加载期间你的变量“data”应该是一个数组。