- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用 Xcode 8.0 和 swift 2.3。
我有一个scrollView,我想用segment来控制页面
scrollView中有两个tableView
但是函数中出现错误:
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
Contstant 'cell' used before being initialized
这是错误
这是初始化“cell”,对吧?
let cell:UITableViewCell?
上面是我的代码
class DetailViewController: UIViewController, UITableViewDataSource, UITableViewDelegate, UIScrollViewDelegate {
@IBOutlet weak var scroll: UIScrollView!
@IBOutlet weak var segmentControl2: UISegmentedControl!
@IBOutlet var recipesImageView: UIImageView!
@IBOutlet var tableView:UITableView!
@IBOutlet var tableView1:UITableView!
var recipes:Recipe!
var noodles:Recipe!
var snacks:Recipe!
var category: Int = Int()
@IBAction func segmented(sender: AnyObject) {
switch sender.selectedSegmentIndex {
case 0:
scroll.setContentOffset(CGPoint(x:0, y:0), animated: true)
case 1:
scroll.setContentOffset(CGPoint(x:375, y:0), animated: true)
case 2:
scroll.setContentOffset(CGPoint(x:750, y:0), animated: true)
case 3:
scroll.setContentOffset(CGPoint(x:1125, y:0), animated: true)
default:
print()
}
}
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
switch self.category {
case 0:
self.recipesImageView.image = UIImage(named: recipes.image)
title = self.recipes.name
case 1:
self.recipesImageView.image = UIImage(named: noodles.image)
title = self.noodles.name
case 2:
self.recipesImageView.image = UIImage(named: snacks.image)
title = self.snacks.name
case 3:
self.recipesImageView.image = UIImage(named: noodles.image)
title = self.noodles.name
case 4:
self.recipesImageView.image = UIImage(named: noodles.image)
title = self.noodles.name
default:
self.recipesImageView.image = UIImage(named: recipes.image)
title = self.recipes.name
}
self.tableView.backgroundColor = UIColor(red: 240.0/255.0, green: 240.0/255.0, blue: 240.0/255.0, alpha: 0.5)
//刪除多餘的隔線
self.tableView.tableFooterView = UIView(frame: CGRectZero)
self.tableView.separatorColor = UIColor(red: 240.0/255.0, green: 240.0/255.0, blue: 240.0/255.0, alpha: 1)
//title = self.recipes.name
tableView.estimatedRowHeight = 36.0;
tableView.rowHeight = UITableViewAutomaticDimension;
tableView.dataSource = self
tableView.delegate = self
tableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: "Cell")
tableView1.dataSource = self
tableView1.delegate = self
tableView1.registerClass(UITableViewCell.self, forCellReuseIdentifier: "Cell1")
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
var cellNum:Int?
if tableView == self.tableView {
cellNum = 4
//return cellNum
}
if tableView == self.tableView1 {
cellNum = 1
}
return cellNum!
}
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell:UITableViewCell?
if tableView == self.tableView {
let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as! DetailTableViewCell
//cell.backgroundColor = UIColor.clearColor()
if self.category == 0 {
switch indexPath.row {
case 0:
cell.fieldLabel.text = "名稱"
cell.valueLabel.text = recipes.name
cell.amountLabel.text = ""
case 1:
cell.fieldLabel.text = "類型"
cell.valueLabel.text = recipes.type
cell.amountLabel.text = ""
case 2:
cell.fieldLabel.text = "收藏"
cell.valueLabel.text = (recipes.isFavor) ? "Yes" : "No"
cell.amountLabel.text = ""
case 3:
cell.fieldLabel.text = "食材"
cell.valueLabel.text = recipes.material
cell.amountLabel.text = recipes.amount
default:
cell.fieldLabel.text = ""
cell.valueLabel.text = ""
cell.amountLabel.text = ""
}
}
if self.category == 1 {
switch indexPath.row {
case 0:
cell.fieldLabel.text = "名稱"
cell.valueLabel.text = noodles.name
cell.amountLabel.text = ""
case 1:
cell.fieldLabel.text = "類型"
cell.valueLabel.text = noodles.type
cell.amountLabel.text = ""
case 2:
cell.fieldLabel.text = "收藏"
cell.valueLabel.text = (noodles.isFavor) ? "Yes" : "No"
cell.amountLabel.text = ""
case 3:
cell.fieldLabel.text = "食材"
cell.valueLabel.text = noodles.material
cell.amountLabel.text = noodles.amount
default:
cell.fieldLabel.text = ""
cell.valueLabel.text = ""
cell.amountLabel.text = ""
}
}
if self.category == 2 {
switch indexPath.row {
case 0:
cell.fieldLabel.text = "名稱"
cell.valueLabel.text = snacks.name
cell.amountLabel.text = ""
case 1:
cell.fieldLabel.text = "類型"
cell.valueLabel.text = snacks.type
cell.amountLabel.text = ""
case 2:
cell.fieldLabel.text = "收藏"
cell.valueLabel.text = (snacks.isFavor) ? "Yes" : "No"
cell.amountLabel.text = ""
case 3:
cell.fieldLabel.text = "食材"
cell.valueLabel.text = snacks.material
cell.amountLabel.text = snacks.amount
default:
cell.fieldLabel.text = ""
cell.valueLabel.text = ""
cell.amountLabel.text = ""
}
}
if self.category == 3 {
switch indexPath.row {
case 0:
cell.fieldLabel.text = "名稱"
cell.valueLabel.text = noodles.name
cell.amountLabel.text = ""
case 1:
cell.fieldLabel.text = "類型"
cell.valueLabel.text = noodles.type
cell.amountLabel.text = ""
case 2:
cell.fieldLabel.text = "收藏"
cell.valueLabel.text = (noodles.isFavor) ? "Yes" : "No"
cell.amountLabel.text = ""
case 3:
cell.fieldLabel.text = "食材"
cell.valueLabel.text = noodles.material
cell.amountLabel.text = noodles.amount
default:
cell.fieldLabel.text = ""
cell.valueLabel.text = ""
cell.amountLabel.text = ""
}
}
if self.category == 4 {
switch indexPath.row {
case 0:
cell.fieldLabel.text = "名稱"
cell.valueLabel.text = noodles.name
cell.amountLabel.text = ""
case 1:
cell.fieldLabel.text = "類型"
cell.valueLabel.text = noodles.type
cell.amountLabel.text = ""
case 2:
cell.fieldLabel.text = "收藏"
cell.valueLabel.text = (noodles.isFavor) ? "Yes" : "No"
cell.amountLabel.text = ""
case 3:
cell.fieldLabel.text = "食材"
cell.valueLabel.text = noodles.material
cell.amountLabel.text = noodles.amount
default:
cell.fieldLabel.text = ""
cell.valueLabel.text = ""
cell.amountLabel.text = ""
}
}
//return cell
}
if tableView == self.tableView1 {
let cell = tableView1.dequeueReusableCellWithIdentifier("Cell1", forIndexPath: indexPath) as! DetailTableViewCell
if self.category == 0 {
switch indexPath.row {
case 0:
cell.materialLabel!.text = recipes.material
default:
cell.materialLabel!.text = recipes.material
}
}
if self.category == 1 {
switch indexPath.row {
case 0:
cell.materialLabel!.text = noodles.material
default:
cell.materialLabel!.text = noodles.material
}
}
if self.category == 2 {
switch indexPath.row {
case 0:
cell.materialLabel!.text = snacks.material
default:
cell.materialLabel!.text = snacks.material
}
}
if self.category == 3 {
switch indexPath.row {
case 0:
cell.materialLabel!.text = noodles.material
default:
cell.materialLabel!.text = noodles.material
}
}
if self.category == 4 {
switch indexPath.row {
case 0:
cell.materialLabel!.text = noodles.material
default:
cell.materialLabel!.text = noodles.material
}
}
}
return cell //<----This line will error ***********************
}
//避免被前面一頁的隱藏導覽列所影響
override func viewWillAppear(animated: Bool) {
super.viewWillAppear(animated)
self.navigationController?.hidesBarsOnSwipe = false
self.navigationController?.setNavigationBarHidden(false, animated: true)
}
/*
// MARK: - Navigation
// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
// Get the new view controller using segue.destinationViewController.
// Pass the selected object to the new view controller.
}
*/
}
最佳答案
我相信这些改变应该有所帮助:
将 let cell:UITableViewCell?
更改为 let cell:UITableViewCell
。该函数不希望您返回可选值。
将 let cell = tableView.dequeue...
更改为 cell = tableView.dequeue...
。您不应声明 cell
两次。
将 cellForRowAtIndexPath
中的结构更新为:
if tableView == self.tableView {
细胞=...
...
} 别的 {
细胞=...
...
}
返回单元格
因此编译器会发现您总是在返回单元格之前将其设置为某些内容。
关于Swift: ScrollView 中的两个tableView,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40099307/
我正在对 tableView 是否呈现单元格进行单元测试。 我发现 tableView.cellForRow(at:) 返回 nil,而 tableView.dataSource?tableView(
我有 Tableview 用于显示客户下的食品订单。其中包含水平 UIStackview。在 UIStackView UIStackview 中很少有一/两行标签和一个用于显示订单项的UITableV
我有 Viewcontroller,我在其中设置了 ScrollView 。在 scrollview 中,我有一个 tableview,它位于 Container 中,就在容器下方,当我将 table
我想在滚动时让我的第一个单元格始终位于 tableview 的顶部。 任何帮助都是可观的。提前致谢... 最佳答案 这是为 UITableView 创建标题 View 的方法 - (UIView *)
在我的应用程序中,我点击一行,它会在其下方展开另一行。我想生成一种随机颜色,当我单击一行时,行背景会变成该颜色,而它下面的展开行会变成相同的颜色。如何让行生成相同的随机颜色? 我创建了一个函数来生成随
我正在为这个问题苦苦挣扎,所以我需要你的帮助。基本上我已经编写了一个复杂的 TableView Controller (使用 NSFetchedResults 协议(protocol)等)并且已经在我
我正在使用 JavaFx 2.2。我遇到了一个问题,我无法在 TableView 列中放置不同的组件。例如我有两列 1) 回答 2) 答案类型 如果 AnswerType 包含“Multiple Ch
试图弄清楚如何在 javafx 2 中禁用表列的重新排序? 最佳答案 这是解决方案: tblView.getColumns().addListener(new ListChangeListener()
我一直在寻找有关将数据刷新到 tableview 的信息。我试图直接修改模型,但我遇到了一个错误。我修改了模型,但表格没有刷新,只有当我移动一列时,表格才会显示修改后的值。 为了给你展示一个例子(13
给定一个TableView,我需要检测单元格上的双击。 tableView.setOnMouseClicked(new EventHandler() { @Override publi
我成功创建了一个 TableView,其中将特定列分配给了数据模型类。该程序可以将 csv 文件解析为其中并在表中正确显示所有内容。在此阶段,滚动不是问题。 然后我想选择特定行并将它们发送到另一个表。
我尝试了所有方法来用数据填充 TableView。下一个代码在表中插入一个新行,但数据没有出现在表中。我试图为此找到解释,但没有成功。 请帮忙。我不知道怎么了。 在 controller.java 中
我尝试了所有方法来用数据填充 TableView。下一个代码在表中插入一个新行,但数据没有出现在表中。我试图为此找到解释,但没有成功。 请帮忙。我不知道怎么了。 在 controller.java 中
我有一个通过 Tableview 显示玩家的应用程序。用户可以“添加”一个新玩家并输入他的姓名、高度、体重、图片等...保存后将被添加到 Tableview 中。他们还可以点击每个玩家,然后将他们带到
对于大学,我必须编写一个小应用程序,其想法是创建一个小公式集合。这个概念是有一个类别列表,选择类别后您会收到一个公式列表。选择所需的公式后,您将看到公式计算器的 View 。 我正在努力获得第一个UI
如果我只加载一个 TableView ,我的 View 中必须有两个 TableView ,它工作正常。但是当我尝试使用下面的方法加载两个表格 View 时,它给出了以下异常。 未捕获异常“NSRan
我是 JavaFx 的新手,我正在尝试创建一个 TableView ,而 fxml 是使用场景生成器创建的。如果我运行该程序,该表不会获取值。我发现这个问题在某种程度上符合我的要求( javaFX 2
是否可以对 tableView 进行反向排序?我搜索了很多解决方案,但没有任何效果。 效果就像whatsapp聊天。 一个普通的tableView是: ---------- label 1 -----
我有一个有趣的问题。我有两个 TableView ,一个在另一个里面。我有一个结构,我想用它来将数据添加到我的 TableView 中。该结构有 2 个字符串项和另一个具有 3 个字符串项的结构的数组
我正在使用的方法 func tableView(tableView: UITableView, editActionsForRowAtIndexPath indexPath: NSIndexPath
我是一名优秀的程序员,十分优秀!