加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ios – 如何使用swift3在TableViewCell中的CollectionViewCell中

发布时间:2020-12-15 01:46:37 所属栏目:百科 来源:网络整理
导读:我从TableViewCell获取了我的json链接数据,然后从服务器检索该数据并在collectView中显示相关的TableViewCell数据. 如何在swift3中显示这些数据?请帮帮我. 我从TableViewCell获得了url链接(mainThemeList.main_associated_url,main_name). func tableView(_
我从TableViewCell获取了我的json链接数据,然后从服务器检索该数据并在collectView中显示相关的TableViewCell数据.
如何在swift3中显示这些数据?请帮帮我.

我从TableViewCell获得了url链接(mainThemeList.main_associated_url,main_name).

func tableView(_ tableView: UITableView,cellForRowAt indexPath: IndexPath) -> UITableViewCell {



        let mainThemeList = mainHomeThemeTable[(indexPath as NSIndexPath).row]

        let cell = tableView.dequeueReusableCell(withIdentifier: "homecell") as! HomeCategoryRowCell



         DispatchQueue.main.async {
            cell.categoryTitle.text = mainThemeList.main_name
            cell.mainAssociatedURL.text = mainThemeList.main_associated_url


            self.prefs.set(mainThemeList.main_name,forKey: "main_name")
            cell.categoryTitle.font = UIFont.boldSystemFont(ofSize: 17.0)
            cell.collectionView.reloadData()

        }

        DispatchQueue.main.async {

            self.retrieveDataFromServer(associated_url: mainThemeList.main_associated_url,main_name: mainThemeList.main_name)
        }

        return cell
    }

然后数据来自Server的url链接数据.

private func retrieveDataFromServe(associated_url : String,main_name: String) {
        SwiftLoading().showLoading()
        if Reachability().isInternetAvailable() == true {

            self.rest.auth(auth: prefs.value(forKey: "access_token") as! String!)
            rest.get(url: StringResource().mainURL + associated_url,parma: [ "show_min": "true" ],finished: {(result : NSDictionary,status : Int) -> Void in


                self.assetsTable.removeAll()
                if(status == 200){
                    let data = result["data"] as! NSArray
                    if (data.count>0){
                        for item in 0...(data.count) - 1 {

                            let themes : AnyObject = data[item] as AnyObject
                            let created = themes["created"] as! String
                            let assets_id = themes["id"] as! Int
                            let name = themes["name"] as! String
                            var poster_img_url = themes["poster_image_url"] as! String
                            let provider_id = themes["provider_id"] as! Int

                            poster_img_url = StringResource().posterURL + poster_img_url

                            self.assetsTable.append(AssetsTableItem(main_name: main_name,created: created,assets_id: assets_id,name: name,poster_image_url: poster_img_url,provider_id: provider_id))

                        }
                    }

                    SwiftLoading().hideLoading()

                }else{

                    SwiftLoading().hideLoading()

                }
            })
        }
    }

从assetsTable中的服务器数据存储中检索数据.

然后在CollectionViewCell中显示assetsTable数据.

func collectionView(_ collectionView: UICollectionView,cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {



    let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "videoCell",for: indexPath) as! HomeVideoCell

            cell.movieTitle.text = list.name
            cell.imageView.image = list.image



    return cell

}

我的问题是collectionViewCell数据与以前的assetsTable数据重复,并且在CollectionView中没有显示正确的数据.

enter image description here

我的tableViewCell显示(Action,Drama)标签和My CollectionViewCell显示电影名称和电影图像.我从服务器检索CollectionViewCell的数据,但CollectionViewCell没有显示相关数据.

解决方法

在HomeVideoCell子类中,准备好在prepareforreuse中清理数据

override func prepareForReuse() {
    super.prepareForReuse()
    self.movieTitle.text = ""
    self.imageView.image = nil
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读