所有数据都显示在一行中
All the datas are presenting in one row
因为我是 swift 的新手,所以我对我的代码有疑问,到底是什么问题!我有 table 视图,我应该放置一些我从 API 获得的数据。我正在使用 alamofire 和 moya。
我在 vc 中调用这个函数来请求网络:
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 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] = []
填充table:
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"
}
]
crashLog
PPhoto
照片:
Photo
我的最终答案是所有答案的组合
您添加了 numberOfRowsInSection 了吗?您传递给它的值是多少?根据您的代码,它需要像下面的代码
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return data.count
}
您正在填充 Table 视图错误。
首先,您需要在 Table 视图中添加部分数:
func numberOfSections(in tableView: UITableView) -> Int {
return data.count
}
然后您需要在
部分添加行数
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return Pphone.count
}
然后 table 视图应该像这样填充
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()
}
并且不要忘记变量应该以小写字母开头...
使用下面的代码(即我们必须检查数据数组是否有任何值)
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
if data != nil {
return data.count
}
}
首先要填充您的数据 return numberOfRowsInSection。
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return data.count
}
此外,正如您所说,您的应用程序在 returning data.count 时崩溃,然后确保在 table 期间重新加载您的变量 "data" 应该是一个数组。
第一次崩溃是因为强制展开 data
值。
您可以 return 使用 nil
进行数据计数
data.count ?? 0
在这个例子中,您似乎在 tableView(_:cellForRowAt:)
中迭代值。这不是个好主意,因为此方法将被调用很多次以显示 table。出列并配置 cellForRow 块内的单元格并立即 return cell.
首先以您需要的格式填充数据。
func GettingEverthingSuccess(response: smsModelList?) {
print("getting evething success")
guard let response = response else { return }
let contacts = response.flatMap { [=11=].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
}
}
因为我是 swift 的新手,所以我对我的代码有疑问,到底是什么问题!我有 table 视图,我应该放置一些我从 API 获得的数据。我正在使用 alamofire 和 moya。
我在 vc 中调用这个函数来请求网络:
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 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] = []
填充table:
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"
}
]
crashLog PPhoto
照片: Photo
我的最终答案是所有答案的组合
您添加了 numberOfRowsInSection 了吗?您传递给它的值是多少?根据您的代码,它需要像下面的代码
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return data.count
}
您正在填充 Table 视图错误。 首先,您需要在 Table 视图中添加部分数:
func numberOfSections(in tableView: UITableView) -> Int {
return data.count
}
然后您需要在
部分添加行数func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return Pphone.count
}
然后 table 视图应该像这样填充
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()
}
并且不要忘记变量应该以小写字母开头...
使用下面的代码(即我们必须检查数据数组是否有任何值)
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
if data != nil {
return data.count
}
}
首先要填充您的数据 return numberOfRowsInSection。
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return data.count
}
此外,正如您所说,您的应用程序在 returning data.count 时崩溃,然后确保在 table 期间重新加载您的变量 "data" 应该是一个数组。
第一次崩溃是因为强制展开 data
值。
您可以 return 使用 nil
进行数据计数data.count ?? 0
在这个例子中,您似乎在 tableView(_:cellForRowAt:)
中迭代值。这不是个好主意,因为此方法将被调用很多次以显示 table。出列并配置 cellForRow 块内的单元格并立即 return cell.
首先以您需要的格式填充数据。
func GettingEverthingSuccess(response: smsModelList?) {
print("getting evething success")
guard let response = response else { return }
let contacts = response.flatMap { [=11=].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
}
}