Swift基础--使用TableViewController自定义列表
首先建立一个swift项目,把storyboard的内容删掉,添加一个 Navigation Controller,然后设置storyboard对应界面的class,在Navigation Controller界面设置View Controller的is initial View Controller,这里使用的自定义列表内容,所以要新建一个继承UITableViewCell的类,然后设置storyboard中Table View的Prototype Cells的class,对于点击item进入详情界面,使用TableView 中的prepareForSegue方法。
JieTableViewController.swift
- //
- // JieTableViewController.swift
- // JieTableView
- //
- // Created by jiezhang on 14-10-5.
- // Copyright (c) 2014年 jiezhang. All rights reserved.
- //
- import UIKit
- class JieTableViewController: UITableViewController {
- var listVideos : NSMutableArray!
- override func viewDidLoad() {
- super.viewDidLoad()
- var bundle = NSBundle.mainBundle()
- let plistPath : String! = bundle.pathForResource("videos", ofType: "plist")
- listVideos = NSMutableArray(contentsOfFile: plistPath)
- // Uncomment the following line to preserve selection between presentations
- // self.clearsSelectionOnViewWillAppear = false
- // Uncomment the following line to display an Edit button in the navigation bar for this view controller.
- //下面这段话是设置左边编辑,右边添加item
- self.navigationItem.leftBarButtonItem = self.editButtonItem()
- let addButton = UIBarButtonItem(barButtonSystemItem: UIBarButtonSystemItem.Add, target: self, action: "insertNewObject:")
- self.navigationItem.rightBarButtonItem = addButton
- }
- func insertNewObject(sender: AnyObject) {
- var item : NSDictionary = NSDictionary(objects:["http://c.hiphotos.baidu.com/video/pic/item/f703738da977391224eade15fb198618377ae2f2.jpg","新增数据", NSDate.date().description] , forKeys: ["video_img","video_title","video_subTitle"])
- listVideos.insertObject(item, atIndex: 0)
- let indexPath = NSIndexPath(forRow: 0, inSection: 0)
- self.tableView.insertRowsAtIndexPaths([indexPath], withRowAnimation: .Automatic)
- }
- override func didReceiveMemoryWarning() {
- super.didReceiveMemoryWarning()
- // Dispose of any resources that can be recreated.
- }
- // MARK: - Table view data source
- //返回节的个数
- override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
- // #warning Potentially incomplete method implementation.
- // Return the number of sections.
- return 1
- }
- //返回某个节中的行数
- override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
- // #warning Incomplete method implementation.
- // Return the number of rows in the section.
- return listVideos.count
- }
- //为表视图单元格提供数据,该方法是必须实现的方法
- override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
- let cellIdentifier : String = "videoItem"
- let cell = tableView.dequeueReusableCellWithIdentifier(cellIdentifier, forIndexPath: indexPath) as JieTableViewCell
- var row = indexPath.row
- var rowDict : NSDictionary = listVideos.objectAtIndex(row) as NSDictionary
- let url : String = rowDict.objectForKey("video_img") as String
- let dataImg : NSData = NSData(contentsOfURL: NSURL(string : url))
- cell.JieVideoImg.image = UIImage(data: dataImg)
- cell.JieVideoTitle.text = rowDict.objectForKey("video_title") as? String
- cell.JieVideoSubTitle.text = rowDict.objectForKey("video_subTitle") as? String
- return cell
- }
- override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
- }
- // 支持单元格编辑功能
- override func tableView(tableView: UITableView, canEditRowAtIndexPath indexPath: NSIndexPath) -> Bool {
- // Return NO if you do not want the specified item to be editable.
- return true
- }
- // Override to support editing the table view.
- override func tableView(tableView: UITableView, commitEditingStyle editingStyle: UITableViewCellEditingStyle, forRowAtIndexPath indexPath: NSIndexPath) {
- if editingStyle == .Delete {
- // Delete the row from the data source
- listVideos.removeObjectAtIndex(indexPath.row)
- tableView.deleteRowsAtIndexPaths([indexPath], withRowAnimation: .Fade)
- } else if editingStyle == .Insert {
- // Create a new instance of the appropriate class, insert it into the array, and add a new row to the table view
- }
- }
- // Override to support rearranging the table view.
- override func tableView(tableView: UITableView, moveRowAtIndexPath fromIndexPath: NSIndexPath, toIndexPath: NSIndexPath) {
- if fromIndexPath != toIndexPath{
- var object: AnyObject = listVideos.objectAtIndex(fromIndexPath.row)
- listVideos.removeObjectAtIndex(fromIndexPath.row)
- if toIndexPath.row > self.listVideos.count{
- self.listVideos.addObject(object)
- }else{
- self.listVideos.insertObject(object, atIndex: toIndexPath.row)
- }
- }
- }
- // Override to support conditional rearranging of the table view.
- //在编辑状态,可以拖动设置item位置
- override func tableView(tableView: UITableView, canMoveRowAtIndexPath indexPath: NSIndexPath) -> Bool {
- // Return NO if you do not want the item to be re-orderable.
- return true
- }
- // MARK: - Navigation
- //给新进入的界面进行传值
- override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject!) {
- if segue.identifier == "showDetail" {
- if let indexPath = self.tableView.indexPathForSelectedRow() {
- let object : NSDictionary = listVideos[indexPath.row] as NSDictionary
- (segue.destinationViewController as JieDetailViewController).detailItem = object
- }
- }
- }
- }
JieTableViewCell.swift
- //
- // JieTableViewCell.swift
- // JieTableView
- //
- // Created by jiezhang on 14-10-5.
- // Copyright (c) 2014年 jiezhang. All rights reserved.
- //
- import UIKit
- class JieTableViewCell: UITableViewCell {
- @IBOutlet weak var JieVideoImg: UIImageView!
- @IBOutlet weak var JieVideoTitle: UILabel!
- @IBOutlet weak var JieVideoSubTitle: UILabel!
- override func awakeFromNib() {
- super.awakeFromNib()
- // Initialization code
- }
- override func setSelected(selected: Bool, animated: Bool) {
- super.setSelected(selected, animated: animated)
- }
- }
JieDetailViewController.swift
- //
- // JieDetailViewController.swift
- // JieTableView
- //
- // Created by jiezhang on 14-10-5.
- // Copyright (c) 2014年 jiezhang. All rights reserved.
- //
- import UIKit
- class JieDetailViewController: UIViewController {
- @IBOutlet var big_video_img: UIImageView!
- //接受传进来的值
- var detailItem: NSDictionary?
- func configureView() {
- if let detail : NSDictionary = self.detailItem {
- self.title = detail.objectForKey("video_title") as? String
- let url : String = detail.objectForKey("video_img") as String
- let dataImg : NSData = NSData(contentsOfURL: NSURL(string : url))
- self.big_video_img.image = UIImage(data: dataImg)
- }
- }
- override func viewDidLoad() {
- super.viewDidLoad()
- configureView()
- }
- override func didReceiveMemoryWarning() {
- super.didReceiveMemoryWarning()
- // Dispose of any resources that can be recreated.
- }
- // MARK: - Navigation
- override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject!) {
- }
- }
源码地址:https://github.com/jwzhangjie/JieTableView
Swift基础--使用TableViewController自定义列表的更多相关文章
- Android零基础入门第39节:ListActivity和自定义列表项
原文:Android零基础入门第39节:ListActivity和自定义列表项 相信通过前两期的学习,以及会开发最简单的一些列表界面了吧,那么本期接着来学习更多方法技巧. 一.使用ListActivi ...
- 2.html基础标签:无序+有序+自定义列表
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- Bootstrap <基础二十八>列表组
列表组.列表组件用于以列表形式呈现复杂的和自定义的内容.创建一个基本的列表组的步骤如下: 向元素 <ul> 添加 class .list-group. 向 <li> 添加 cl ...
- WPF界面设计技巧(4)—自定义列表项样式
原文:WPF界面设计技巧(4)-自定义列表项样式 有前面修改按钮样式的基础,我们可以尝试来定制一个即好看又好用的 ListBox ,今天先来讲“好看”部分. 打开 Microsoft Visual S ...
- jqgrid自定义列表开发=》实现高级查询
标题已指出本文要说的三件事,首先是主角jqgrid,将应用在自定义列表中,重点介绍如何实现高级查询. 使用jqgrid实现自定义列表分为两大步骤,首先是要根据业务完成jqgrid的对象定义,即列表的描 ...
- swift基础:第六部分:类与对象
http://reactnative.cn/docs/0.24/getting-started.html#content(react Native 开发文档) 互联网这个时代,你松懈一天,就会有很多很 ...
- swift基础:第二部分:函数和闭包
今天本来想利用上午的时间本来打算将swift基础部分学习完的,不巧的是,后台来和我讨论用户评价的接口,讨论过后,商讨出一种可行的方案,十几分钟时间过去了,我拿到将接口介入到已经完成的页面中,完美,终于 ...
- Swift基础语法学习总结(转)
Swift基础语法学习总结 1.基础 1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift使用print和println打印,它的传参是一个泛型 ...
- SharePoint 2013开发入门探索(一)- 自定义列表
在SharePoint 2013中创建自定义列表的方式有很多,在网站内容页面添加应用程序就可以创建(站点内容-〉 您的应用程序),也可以通过SharePoint Designer 2013创建,而本文 ...
随机推荐
- [转]CSS目标伪类E:target
CSS3 target 伪类不得不说那些事儿(纯CSS实现tab切换) 是不是觉得target有点眼熟?! 今天要讲的不是HTML的<a>标签里面有个target属性. target伪类是 ...
- Android ----------获取各种路径(更新中。。。。。。)
##在手机中的路径 *获取应用的路径,形式:/data/data/包名 String appDataDir = getApplicationInfo().dataDir; *获取手机数据存储路径,即/ ...
- RouteHttpMap要添加的引用
System.Web.Routing.RouteCollection' does not contain a definition for 'MapHttpRoute' 此错的解决方式是添加 Syst ...
- ajax传递json数据,springmvc后台就收json数据
1.ajax数据的封装 var json = {"token":token};//封装json数据 $.ajax({ url:'', data:JSON.stringify(jso ...
- silverlight visifire控件图表制作——silverlight 后台方法ControlChart.xaml.cs
一.构造方法ControlChart 1.前台页面控件赋值 //时间下拉框赋值,下拉框赋选定值 for (int ii = DateTime.Today.Year; ii ...
- vc中调用Com组件的方法详解
vc中调用Com组件的方法详解 转载自:网络,来源未知,如有知晓者请告知我.需求:1.创建myCom.dll,该COM只有一个组件,两个接口: IGetRes--方法Hello(), IGet ...
- 【1】Laravel5.1 安装
1.安装composer http://www.phpcomposer.com/ 这个是中文网址里边有教程,但是由于被墙的缘故,可以通过下边这个链接下载Windows安装包 http://docs.p ...
- PHP内置Web Server探究(一)启动Cli_Server
自PHP5.4之后 PHP内置了一个Web 服务器(cli_server),类似于Python的内置server一样,方便我们开发阶段的调试 主要使用场景: 1,没有搭建nginx或apache等第三 ...
- UVA 12169 Disgruntled Judge
我该怎么说这道题呢...说简单其实也简单,就枚举模拟,开始卡了好久,今天看到这题没a又写了遍,看似会超时的代码交上去a了,果然实践是检验真理的唯一标准... #include <iostream ...
- un ange frappe a ma porte
Un signe, une larme 魂牵 泪扰 un mot, une arme 字断 情烧 nettoyer les étoiles à l'alcool de mon ame 灵魂之酒眷洗 星 ...