TableViewにカスタムセルを出力したいのですがうまくいきません。
func tableView{}のなかにあるprint("purchaseItemArray(purchaseItemArray)")が出力されていなかったので、そもそもfunc tabeleView{ } がうまく機能していないのではと踏んでいます。
どのように対処すべきでしょうか?
// // ContainerBuyViewController.swift // SoundKnowledge // // Created by 綱島将人 on 2018/02/20. // Copyright © 2018年 ONER. All rights reserved. // import UIKit import NCMB class ContainerBuyViewController: UIViewController,UITableViewDelegate,UITableViewDataSource { @IBOutlet weak var tableView: UITableView! //tableviewに出力するセルデータを保存するarray var itemArray : NSArray = NSArray() //購入したデータを特定するために使用するobjectIdを保存するarray var purchaseObjectId: NSArray = NSArray() var purchaseItemArray: NSArray = NSArray() let Fav = "Fav.png" let NotFav = "NotFav.png" let currentUser = NCMBUser.current() override func viewDidLoad() { super.viewDidLoad() loadItemData() print("purchseItemData:(purchaseItemArray)") DispatchQueue.main.async{self.tableView.dataSource = self self.tableView.delegate = self // Do any additional setup after loading the view. self.tableView.reloadData() }} override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() // Dispose of any resources that can be recreated. } func loadItemData(){ let query = NCMBQuery(className: "user") query?.whereKey("userName", equalTo: currentUser!.userName) query?.findObjectsInBackground({ (objects, error) in if error != nil{ print("ユーザー購入アイテム情報の取得に失敗しました") }else{ let object = objects![0] as! NCMBObject self.purchaseObjectId = object.object(forKey: "account_purchase") as! NSArray print("成功はしているんだよね") print("purchaseObjectId:(self.purchaseObjectId)") let query2: NCMBQuery = NCMBQuery(className: "itemClass") query2.whereKey("objectId",equalTo:self.purchaseObjectId[0]) query2.findObjectsInBackground({(object, error) in self.purchaseItemArray = object! as NSArray print("purchaseItemArray:(self.purchaseItemArray)") print(self.purchaseItemArray.count) } )} }) } func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return purchaseItemArray.count } func numberOfSections(in tableView: UITableView) -> Int { return 1 } func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let cell = tableView.dequeueReusableCell(withIdentifier:"BuyCell", for: indexPath) as! ContainerBuyTableViewCell let targetItemData: AnyObject = self.purchaseItemArray[indexPath.row] as AnyObject print("purchaseItemArray2:(purchaseItemArray)") cell.CellTitle?.text! = (targetItemData.object(forKey: "item_title")as? String)! cell.CellSpeaker?.text! = (targetItemData.object(forKey: "item_price")as? String)! //cell.SpeakerImage = targetItemData.object(forKey: "thumbnail") as! UIImageView //favの動きをどのようにするか? cell.setCell() return cell } @IBAction func FavButton(_ sender: Any){ let button = sender as! UIButton let cell = button.superview?.superview as! ContainerBuyTableViewCell if (cell.count % 2 == 0){ cell.FavImage.image = UIImage(named: NotFav) cell.count += 1 }else{ cell.FavImage.image = UIImage(named: Fav) cell.count += 1 } } }
ご回答いただけますと幸いです。
purchaseItemArrayが空なのでは?
コメントありがとうございます。purchaseItemArrayにはデータ入っておりました。 [purchaseItemArray2]の文字自体も出力されていないので、そもそもtableViewが起動していないのではと思いました。
numberOfSections(in:) , tableView(_: numberOfRowsInSection:)にもログ出力を。これらの方が先に呼ばれます。
return purchaseItemArray.countの上に、print("purchaseItemArray.count:",purchaseItemArray.count)。データが認識されてるなら個数がカウントされる。
ありがとうございます!アドバイス参考にして解決できそうです。
あなたの回答
tips
プレビュー