2014-12-12 74 views
0

表视图,我完全陌生的SWIFT和一般发展中国家。我目前正在建立一个RSS新闻馈送来磨练我的(非常有限的)技能。我基本上是从一个随机新闻频道解析RSS提要,然后将这些标题存储在一个简单的表格视图中。拉来刷新SWIFT

我想实现UIPullToRefresh使用SWIFT,并说实话我有点卡住了!我写了下面的代码。正如你所看到的,我已经将必要的代码添加到了我的viewDidLoad方法中。在这一点上刷新微调器工作正常,但我现在想知道我的“刷新功能”需要什么代码来实际刷新我的表格视图。

我知道这可能看起来微不足道的大多数的你们,但我是相当新的这一点,我一直在拉我的头发在过去的12小时,所以任何会在这一点上可能有所帮助。

感谢您的帮助!

import UIKit 

class BRTableViewController: UITableViewController, NSXMLParserDelegate { 

    var parser: NSXMLParser = NSXMLParser() 
    var blogPosts: [BlogPost] = [] 
    var postTitle: String = String() 
    var postLink: String = String() 
    var postDate: String = String() 

    var eName: String = String() 


    override func viewDidLoad() { 
     super.viewDidLoad() 
     let url:NSURL = NSURL(string: "http://rt.com/rss/")! 
     parser = NSXMLParser(contentsOfURL: url)! 
     parser.delegate = self 
     parser.parse() 

     // pull to refresh the table view 

     refreshControl!.attributedTitle = NSAttributedString(string: "Pull to refresh") 
     refreshControl!.addTarget(self, action: "refresh:", forControlEvents: UIControlEvents.ValueChanged) 
     tableView.addSubview(refreshControl!) 
    } 


    func refresh(sender:AnyObject){ 
     let url:NSURL = NSURL(string: "http://rt.com/rss/")! 
     parser = NSXMLParser(contentsOfURL: url)! 
     parser.delegate = self 
     parser.parse() 
    } 


     // MARK: - NSXMLParserDelegate methods 

    func parser(parser: NSXMLParser!, didStartElement elementName: String!, namespaceURI: String!, qualifiedName qName: String!, attributes attributeDict: [NSObject : AnyObject]!) { 
     eName = elementName 
     if elementName == "item" { 
      postTitle = String() 
      postLink = String() 
      postDate = String() 
     } 
    } 

    func parser(parser: NSXMLParser!, foundCharacters string: String!) { 
     let data = string.stringByTrimmingCharactersInSet(NSCharacterSet.whitespaceAndNewlineCharacterSet()) 
     if (!data.isEmpty) { 
      if eName == "title" { 
       postTitle += data 
      } else if eName == "link" { 
       postLink += data 
      } else if eName == "pubDate" { 
       postDate += data 
      } 
     } 
    } 

    func parser(parser: NSXMLParser!, didEndElement elementName: String!, namespaceURI: String!, qualifiedName qName: String!) { 
     if elementName == "item" { 
      let blogPost: BlogPost = BlogPost() 
      blogPost.postTitle = postTitle 
      blogPost.postLink = postLink 
      blogPost.postDate = postDate 
      blogPosts.append(blogPost) 
     } 
    } 

    override func parser(parser: NSXMLParser!, didEndElement elementName: String!, namespaceURI: String!, qualifiedName qName: String!) { 
     if elementName == "item" { 
      self.tableView.reloadData(); 
      self.refreshControl.endRefreshing(); 
     } 
    } 


    override func didReceiveMemoryWarning() { 
     super.didReceiveMemoryWarning() 
     // Dispose of any resources that can be recreated. 
    } 

    // MARK: - Table view data source 

    override func numberOfSectionsInTableView(tableView: UITableView) -> Int { 
     return 1 
    } 

    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 
     return blogPosts.count 
    } 


    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { 
     let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as UITableViewCell 

     let blogPost: BlogPost = blogPosts[indexPath.row] 
     cell.textLabel.text = blogPost.postTitle 
     cell.detailTextLabel?.text = blogPost.postDate.substringToIndex(advance(blogPost.postDate.startIndex, 25)) 


     return cell 
    } 

    override func tableView(tableView: UITableView, heightForRowAtIndexPath indexPath: NSIndexPath) -> CGFloat { 
     return 50.0 
    } 

    override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject!) { 
     if segue.identifier == "viewpost" { 
      let selectedRow = tableView.indexPathForSelectedRow()?.row 
      let blogPost: BlogPost = blogPosts[selectedRow!] 
      let viewController = segue.destinationViewController as PostViewController 
      viewController.postLink = blogPost.postLink 
     } 
    } 
} 

回答

0

我认为这会解决问题:

func refresh(sender:AnyObject){ 
    parser = NSXMLParser(contentsOfURL: url)! 
    parser.delegate = self 
    parser.parse() 

} 

这将重新解析XML和更新blogPosts变量。

viewDidLoad删除以下行:

refreshControl = UIRefreshControl() 

你也应该重写parserDidEndDocument功能,包括此:

func parserDidEndDocument(parser: NSXMLParser!){ 

    self.tableView.reloadData(); 
    self.refreshControl?.endRefreshing(); 
} 

这将刷新表视图,一旦解析器完成。

+0

你好,非常感谢您的快速反应!如上所述,我对编程非常陌生,而且我仍然在努力解决一些基本问题......所以,这里是我的问题:1)“将UIRefreshControl存储为类”的含义是什么2)会覆盖parserDidEndDocument?覆盖FUNC分析器(分析器:的NSXMLParser!didEndElement的ElementName:字符串!,的namespaceURI:字符串!,的qualifiedName QNAME:字符串){ 如果elementName == “项目”{ self.refresh() }} 非常感谢为你提供帮助。我真的很感激! – user3694305 2014-12-13 01:27:33

+0

1.我编辑了这个问题来解决这个问题。2.这是正确的,但是您应该将它编辑到问题中。 – 68cherries 2014-12-13 02:45:49

+0

我已经加入你的更新,但我不得不省略“VAR refreshControl:UIRefreshControl”当我得到了一个错误,显然UIRefreshControl已经是已经的UITableViewController声明refreshControl,所以我没有必要再声明这...这表示我仍然得到与“覆盖parserDidEndDocument”功能错误... – user3694305 2014-12-13 03:24:06