2 x xx xxx xxxx x_xx_xxx_xxxx 于 2016.04.06 17:00 提问

swift tableview 刷新

小弟在编写复选列表(用tableview 的每一个 cell 装每一个选项)时遇到刷新问题,点击刷新后,被选中的文件若上传成功,则在列表中不再显示,但是上传成功后刷新列表,原本存在的被选中的cell(用image标识)中的image下移到另一个cell中了。求大神帮我解决这个问题!!!!

或者求大神提供一个“复选列表”带自动刷新的可行方法!求大神帮忙小弟度过这个紧急时刻!

5个回答

x_xx_xxx_xxxx
x_xx_xxx_xxxx   2016.04.12 11:52
已采纳

好吧,最后我解决了这个问题,方案如下:
1.设置一个全局变量flag,当做刷新的标志位,
2.确定总共上传x个文件,把标志位置成x,每上传成功一次,标志位自减1;
3因为 tableview?.reloadData() 时,有多少个cell,便会调用多少次 tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell ,所以 每加载一个cell时都可判断一下 if(flag >=0){把cell的“button图片” —> “未选中button图片”,flag--;}else{flag = -1}

4.其余时候下的刷新(比如说下拉刷新)flag < 0, 并不会更新每个cell中button的图片。

5.如果我解释的不清楚,或者有什么更好的方式,请联系我!

部分代码如下:(有很多函数都是自己写的,看起来比较乱,请见谅 )

/*上传*/
func uploadClicked(){
    prepareForUpload()
    uploadAudioAndImage(uploadAudioID, ID : ID , insuranceID: insuranceID, idataIcard: idataIcard, userCode: userCode)
    uploadVideo(uploadVideoID,  ID : ID , insuranceID: insuranceID, idataIcard: idataIcard, userCode: userCode)
    timer = NSTimer.scheduledTimerWithTimeInterval(1,
        target:self,selector:Selector("tickDown"),
        userInfo:nil,repeats:true)
    upload.enabled = false
    upload.setTitle("正在上传", forState: UIControlState.Normal)

    coverView = UIView(frame: CGRectMake(0, 130, self.view.frame.size.width, self.view.frame.size.height))
    coverView!.backgroundColor = UIColor(red: 0, green: 0, blue: 0, alpha: 0.1)
    self.view!.addSubview(coverView!)
}

/*轮询是否上传完成*/
func tickDown(){
    let defaults = NSUserDefaults.standardUserDefaults()
    let temp = defaults.integerForKey("temp_done")
    if(temp == 0){
        upload.enabled = true
        upload.setTitle("上传资料", forState: UIControlState.Normal)
        coverView?.removeFromSuperview()
        rfClick()
        timer.invalidate()
    }
}

        /*上传完成后,刷新页面*/
func rfClick(){
    audioID = searchAudioID(insuranceID)
    videoID = searchVideoID(insuranceID)
    //maintableview?.reloadData()
    dispatch_async(dispatch_get_main_queue(), {
        self.flag = self.audioID.count + self.videoID.count
        self.maintableview?.reloadData()
        })
}

//flag 为全局变量,常态时置成 -1(上传完成,flag置成 -1)
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell:(UITableViewCell) = UITableViewCell(style:.Default,reuseIdentifier:"Identifier") as UITableViewCell
if(indexPath.section==0){
let cell:audioCheckboxTableViewCell = maintableview!.dequeueReusableCellWithIdentifier("audioCheckboxTableViewCell", forIndexPath: indexPath) as! audioCheckboxTableViewCell
cell.audioName.text = (audioID[indexPath.row]["audio_id"]as? String)!
cell.tag = 0
if flag > 0
{
flag--
cell.butSelect.setImage(UIImage(named: "fx_02"), forState: UIControlState.Normal)
}else{flag = -1}
cell.textLabel!.font = UIFont.systemFontOfSize(14)
cell.selectionStyle = UITableViewCellSelectionStyle.None
return cell
}
if(indexPath.section==1){
let cell:videoCheckboxTableViewCell = maintableview!.dequeueReusableCellWithIdentifier("videoCheckboxTableViewCell", forIndexPath: indexPath) as! videoCheckboxTableViewCell
cell.videoName.text = (videoID[indexPath.row]["VIDEO_ID"]as? String)!
cell.tag = 1
if flag > 0
{
flag--
cell.butSelect.setImage(UIImage(named: "fx_02"), forState: UIControlState.Normal)
}else{flag = -1}
//cell向右箭头
cell.accessoryType = UITableViewCellAccessoryType.None
cell.textLabel!.font = UIFont.systemFontOfSize(14)
cell.selectionStyle = UITableViewCellSelectionStyle.None
return cell
}
//cell向右选择箭头
cell.accessoryType = UITableViewCellAccessoryType.None
cell.textLabel!.font = UIFont.systemFontOfSize(14)
cell.selectionStyle = UITableViewCellSelectionStyle.None
return cell
}

x_xx_xxx_xxxx
x_xx_xxx_xxxx 解释一下,temp 同样是一个标志位,确定我所选的所有文件是否上传完成的标志位。
一年多之前 回复
devmiao
devmiao   Ds   Rxr 2016.04.06 17:10

tableview的局部刷新逻辑,通常是为了实现某一些或者一组效果,依赖于三个函数,reload,delete,insert。tableview的很多很炫的动画效果都是以此来实现,但是这几个函数,对cell高度可变的table的局部刷新作用,个人觉得是影响体验的,每一个cell第一次配置好之后,第二次再reload一遍,也是一个窝火的事情。但是,but,哈哈,你懂的,如果你想对特定的cell做一些效果,他们真的是,太好用咯。 --- likendsl

这次来说说像reeder那样上下拖动切换的效果是如何做的。
如何触发这里就不多说了,靠contentofset也可以,按钮也可以。
这里主要介绍一下这种效果的3种做法,各有好处。
第一种:如图一。提前预加载好3个view,比如往下翻的时候,就将view C 移到view B,view B移到view A, view A重新加载。这样做的好处就是展示的效果比较好,可控性高。代码见http://www.minroad.com/?p=286

图1
第二种方法:利用tableview来做。在tableview的一层中套入一个view,同样预加载view A B C ,每一次都只要把要显示view加入到tableview中的view上,并利用reload cell来刷新一下。这种做的好处就是简单,对代码水平要求不高,但是与第一次效果相比略显粗糙,可扩展性不强。
比如要将下拖的时候,将cell2中的view B删除,加入view C,然后调用
NSIndexPath *path = [NSIndexPath indexPathForRow:1 inSection:0]; //指向cell2的path
[self.tableview reloadRowsAtIndexPaths:[NSArray arrayWithObject:path] withRowAnimation:
UITableViewRowAnimationBottom];//刷新

图2
第三种方法:同样是tableview,但是这次不需要预加载,优点就是对于tableview相当实用,处理也比较简单。缺点同方法二,见图3.
比如要将cell1 cell2 cell3向前滚动,用cell4,cell5,cell6代替。可以执行以下代码
[self.tableview beginUpdates];
NSIndexPath *path1 = [NSIndexPath indexPathForRow:0 inSection:0];
NSIndexPath *path2 = [NSIndexPath indexPathForRow:1 inSection:0];
NSIndexPath *path3 = [NSIndexPath indexPathForRow:2 inSection:0];
//更新tableview delegate中的数据,cell数量等于删除之后的数量相同,否则会出错
[self.tableview deleteRowsAtIndexPaths:[NSArray arrayWithObjects:path1,path2,path3,nil] withRowAnimation:UITableViewRowAnimationTop];
//更新tableview delegate datasource,cell的数量是添加之后的,同时数据是新的
[self.tableview insertRowsAtIndexPaths:[NSArray arrayWithObjects:path1,path2,path3,nil] withRowAnimation:UITableViewRowAnimationTop];
[self.tableview endUpdates];
这样相当于把原来该是cell4,cell5,cell6中的数据从下向上到cell1,cell2,cell3的位置。

x_xx_xxx_xxxx
x_xx_xxx_xxxx 你好,我看了几遍这个东西,可是并没有理解您的意思,可以说的再具体一些吗?谢谢啦!
一年多之前 回复
CSDNXIAOD
CSDNXIAOD   2016.04.06 17:11

tableView的刷新
Swift - TableView
swift入门之TableView
----------------------biu~biu~biu~~~在下问答机器人小D,这是我依靠自己的聪明才智给出的答案,如果不正确,你来咬我啊!

x_xx_xxx_xxxx
x_xx_xxx_xxxx 我真的可以咬你吗?谢谢机器人小D了!
一年多之前 回复
x_xx_xxx_xxxx
x_xx_xxx_xxxx   2016.04.12 11:53

好吧,最后我解决了这个问题,方案如下:
1.设置一个全局变量flag,当做刷新的标志位,
2.确定总共上传x个文件,把标志位置成x,每上传成功一次,标志位自减1;
3因为 tableview?.reloadData() 时,有多少个cell,便会调用多少次 tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell ,所以 每加载一个cell时都可判断一下 if(flag >=0){把cell的“button图片” —> “未选中button图片”,flag--;}else{flag = -1}

4.其余时候下的刷新(比如说下拉刷新)flag < 0, 并不会更新每个cell中button的图片。

5.如果我解释的不清楚,或者有什么更好的方式,请联系我!

部分代码如下:(有很多函数都是自己写的,看起来比较乱,请见谅 )

/*上传*/
func uploadClicked(){
    prepareForUpload()
    uploadAudioAndImage(uploadAudioID, ID : ID , insuranceID: insuranceID, idataIcard: idataIcard, userCode: userCode)
    uploadVideo(uploadVideoID,  ID : ID , insuranceID: insuranceID, idataIcard: idataIcard, userCode: userCode)
    timer = NSTimer.scheduledTimerWithTimeInterval(1,
        target:self,selector:Selector("tickDown"),
        userInfo:nil,repeats:true)
    upload.enabled = false
    upload.setTitle("正在上传", forState: UIControlState.Normal)

    coverView = UIView(frame: CGRectMake(0, 130, self.view.frame.size.width, self.view.frame.size.height))
    coverView!.backgroundColor = UIColor(red: 0, green: 0, blue: 0, alpha: 0.1)
    self.view!.addSubview(coverView!)
}

/*轮询是否上传完成*/
func tickDown(){
    let defaults = NSUserDefaults.standardUserDefaults()
    let temp = defaults.integerForKey("temp_done")
    if(temp == 0){
        upload.enabled = true
        upload.setTitle("上传资料", forState: UIControlState.Normal)
        coverView?.removeFromSuperview()
        rfClick()
        timer.invalidate()
    }
}

        /*上传完成后,刷新页面*/
func rfClick(){
    audioID = searchAudioID(insuranceID)
    videoID = searchVideoID(insuranceID)
    //maintableview?.reloadData()
    dispatch_async(dispatch_get_main_queue(), {
        self.flag = self.audioID.count + self.videoID.count
        self.maintableview?.reloadData()
        })
}

//flag 为全局变量,常态时置成 -1(上传完成,flag置成 -1)
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell:(UITableViewCell) = UITableViewCell(style:.Default,reuseIdentifier:"Identifier") as UITableViewCell
if(indexPath.section==0){
let cell:audioCheckboxTableViewCell = maintableview!.dequeueReusableCellWithIdentifier("audioCheckboxTableViewCell", forIndexPath: indexPath) as! audioCheckboxTableViewCell
cell.audioName.text = (audioID[indexPath.row]["audio_id"]as? String)!
cell.tag = 0
if flag > 0
{
flag--
cell.butSelect.setImage(UIImage(named: "fx_02"), forState: UIControlState.Normal)
}else{flag = -1}
cell.textLabel!.font = UIFont.systemFontOfSize(14)
cell.selectionStyle = UITableViewCellSelectionStyle.None
return cell
}
if(indexPath.section==1){
let cell:videoCheckboxTableViewCell = maintableview!.dequeueReusableCellWithIdentifier("videoCheckboxTableViewCell", forIndexPath: indexPath) as! videoCheckboxTableViewCell
cell.videoName.text = (videoID[indexPath.row]["VIDEO_ID"]as? String)!
cell.tag = 1
if flag > 0
{
flag--
cell.butSelect.setImage(UIImage(named: "fx_02"), forState: UIControlState.Normal)
}else{flag = -1}
//cell向右箭头
cell.accessoryType = UITableViewCellAccessoryType.None
cell.textLabel!.font = UIFont.systemFontOfSize(14)
cell.selectionStyle = UITableViewCellSelectionStyle.None
return cell
}
//cell向右选择箭头
cell.accessoryType = UITableViewCellAccessoryType.None
cell.textLabel!.font = UIFont.systemFontOfSize(14)
cell.selectionStyle = UITableViewCellSelectionStyle.None
return cell
}

oyljerry
oyljerry   Ds   Rxr 2016.04.06 17:10

你用一个数组来维护数据,每一个数组元素都是cell对应的数据,显示cell的时候,根据数组来处理,需要刷新的时候就是reloadData重新加载

oyljerry
oyljerry 回复x_xx_xxx_xxxx: 主要是你可以看看你的数组是否发生了变化。cell对应的数据是否搞错了
一年多之前 回复
x_xx_xxx_xxxx
x_xx_xxx_xxxx 你好,我就是在用多个数组来维护cell的数据啊,我这里分两个section,每个cell中有一个button,点击的时候,会改变cell中button的图片,可是,上传成功对应的cell,确实不再显示了,可是其中button的图片直接留给下一个cell的button的image了。所以,我已很难搞定
一年多之前 回复
x_xx_xxx_xxxx
x_xx_xxx_xxxx 你好,我就是在用多个数组来维护cell的数据啊,我这里分两个section,每个cell中有一个button,点击的时候,会改变cell中button的图片,可是,上传成功对应的cell,确实不再显示了,可是其中button的图片直接留给下一个cell的button的image了。所以,我已很难搞定
一年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
准确详细的回答,更有利于被提问者采纳,从而获得C币。复制、灌水、广告等回答会被删除,是时候展现真正的技术了!