enter image description here
我有两个 UITableView:一个是国家,另一个是硬币。当我选择一个国家时,我可以在里面看到那个国家的硬币数量。当我点击硬币数量时,勾选标记被选中。但是当点击一个国家硬币项目时,复选标记标记了所有 23 个国家。
我怎样才能切换到只检查被点击的国家?
//第一个TableView(国家)
import UIKit
class MainUITableViewController: UITableViewController {
var flagName = [
"Andorra",
"Austria",
"Belgium",
"Cyprus",
"Estonia",
"Finland",
"France",
"Germany",
"Greece",
"Ireland",
"Italy",
"Latvia",
"Lithuania",
"Luxembourg",
"Malta",
"Monaco",
"Netherlands",
"Portugal",
"San_Marino",
"Slovakia",
"Slovenia",
"Spain",
"Vatican_City"]
var flagImage = [
"Andorra",
"Austria",
"Belgium",
"Cyprus",
"Estonia",
"Finland",
"France",
"Germany",
"Greece",
"Ireland",
"Italy",
"Latvia",
"Lithuania",
"Luxembourg",
"Malta",
"Monaco",
"Netherlands",
"Portugal",
"San_Marino",
"Slovakia",
"Slovenia",
"Spain",
"Vatican_City"]
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
if segue.destinationViewController is SecondUITableViewController {
let second_vc = segue.destinationViewController as! SecondUITableViewController
second_vc.current_index = (self.tableView.indexPathForSelectedRow?.row)!
}
}
override func viewDidLoad() {
super.viewDidLoad()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return 1
}
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return flagName.count
}
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as! ComponentsUITableViewCell
cell.flagImageView?.image = UIImage(named: flagImage[indexPath.row])
cell.nameInCell?.text = flagName[indexPath.row]
return cell
}
}
//第二个TableView(硬币)
import UIKit
class SecondUITableViewController: UITableViewController {
var coinsNames = ["1 euro cent", "2 euro cent", "5 euro cent", "10 euro cent", "20 euro cent", "50 euro cent", "1 euro", "2 euro"]
var coinsImageA = ["Andorra_1", "Andorra_2", "Andorra_5", "Andorra_10", "Andorra_20", "Andorra_50", "Andorra_1e", "Andorra_2e"]
var coinsImageB = ["Austria_1", "Austria_2", "Austria_5", "Austria_10", "Austria_20", "Austria_50", "Austria_1e", "Austria_2e"]
var coinsImageC = ["Belgium_1", "Belgium_2", "Belgium_5", "Belgium_10", "Belgium_20", "Belgium_50", "Belgium_1e", "Belgium_2e"]
var coinsImageD = ["Cyprus_1", "Cyprus_2", "Cyprus_5", "Cyprus_10", "Cyprus_20", "Cyprus_50", "Cyprus_1e", "Cyprus_2e"]
var coinsImageE = ["Estonia_1", "Estonia_2", "Estonia_5", "Estonia_10", "Estonia_20", "Estonia_50", "Estonia_1e", "Estonia_2e"]
var coinsImageF = ["Finland_1", "Finland_2", "Finland_5", "Finland_10", "Finland_20", "Finland_50", "Finland_1e", "Finland_2e"]
var coinsImageG = ["France_1", "France_2", "France_5", "France_10", "France_20", "France_50", "France_1e", "France_2e"]
var coinsImageH = ["Germany_1", "Germany_2", "Germany_5", "Germany_10", "Germany_20", "Germany_50", "Germany_1e", "Germany_2e"]
var coinsImageI = ["Greece_1", "Greece_2", "Greece_5", "Greece_10", "Greece_20", "Greece_50", "Greece_1e", "Greece_2e"]
var coinsImageJ = ["Ireland_1", "Ireland_2", "Ireland_5", "Ireland_10", "Ireland_20", "Ireland_50", "Ireland_1e", "Ireland_2e"]
var coinsImageK = ["Italy_1", "Italy_2", "Italy_5", "Italy_10", "Italy_20", "Italy_50", "Italy_1e", "Italy_2e"]
var coinsImageL = ["Latvia_1", "Latvia_2", "Latvia_5", "Latvia_10", "Latvia_20", "Latvia_50", "Latvia_1e", "Latvia_2e"]
var coinsImageM = ["Lithuania_1", "Lithuania_2", "Lithuania_5", "Lithuania_10", "Lithuania_20", "Lithuania_50", "Lithuania_1e", "Lithuania_2e"]
var coinsImageN = ["Luxembourg_1", "Luxembourg_2", "Luxembourg_5", "Luxembourg_10", "Luxembourg_20", "Luxembourg_50", "Luxembourg_1e", "Luxembourg_2e"]
var coinsImageO = ["Malta_1", "Malta_2", "Malta_5", "Malta_10", "Malta_20", "Malta_50", "Malta_1e", "Malta_2e"]
var coinsImageP = ["Monaco_1", "Monaco_2", "Monaco_5", "Monaco_10", "Monaco_20", "Monaco_50", "Monaco_1e", "Monaco_2e"]
var coinsImageQ = ["Netherlands_1", "Netherlands_2", "Netherlands_5", "Netherlands_10", "Netherlands_20", "Netherlands_50", "Netherlands_1e", "Netherlands_2e"]
var coinsImageR = ["Portugal_1", "Portugal_2", "Portugal_5", "Portugal_10", "Portugal_20", "Portugal_50", "Portugal_1e", "Portugal_2e"]
var coinsImageS = ["San_Marino_1", "San_Marino_2", "San_Marino_5", "San_Marino_10", "San_Marino_20", "San_Marino_50", "San_Marino_1e", "San_Marino_2e"]
var coinsImageT = ["Slovakia_1", "Slovakia_2", "Slovakia_5", "Slovakia_10", "Slovakia_20", "Slovakia_50", "Slovakia_1e", "Slovakia_2e"]
var coinsImageU = ["Slovenia_1", "Slovenia_2", "Slovenia_5", "Slovenia_10", "Slovenia_20", "Slovenia_50", "Slovenia_1e", "Slovenia_2e"]
var coinsImageV = ["Spain_1", "Spain_2", "Spain_5", "Spain_10", "Spain_20", "Spain_50", "Spain_1e", "Spain_2e"]
var coinsImageW = ["Vatican_City_1", "Vatican_City_2", "Vatican_City_5", "Vatican_City_10", "Vatican_City_20", "Vatican_City_50", "Vatican_City_1e", "Vatican_City_2e"]
var current_index = 0
override func viewDidLoad() {
super.viewDidLoad()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
override func numberOfSectionsInTableView(tableView: UITableView) -> Int {
return 1
}
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return coinsNames.count
}
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell2 = tableView.dequeueReusableCellWithIdentifier("Cell2", forIndexPath: indexPath) as! Components2UITableViewCell
cell2.tintColor = UIColor.whiteColor()
switch current_index {
case 0:
cell2.coinsImageView?.image = UIImage(named: coinsImageA[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 1:
cell2.coinsImageView?.image = UIImage(named: coinsImageB[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 2:
cell2.coinsImageView?.image = UIImage(named: coinsImageC[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 3:
cell2.coinsImageView?.image = UIImage(named: coinsImageD[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 4:
cell2.coinsImageView?.image = UIImage(named: coinsImageE[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 5:
cell2.coinsImageView?.image = UIImage(named: coinsImageF[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 6:
cell2.coinsImageView?.image = UIImage(named: coinsImageG[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 7:
cell2.coinsImageView?.image = UIImage(named: coinsImageH[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 8:
cell2.coinsImageView?.image = UIImage(named: coinsImageI[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 9:
cell2.coinsImageView?.image = UIImage(named: coinsImageJ[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 10:
cell2.coinsImageView?.image = UIImage(named: coinsImageK[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 11:
cell2.coinsImageView?.image = UIImage(named: coinsImageL[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 12:
cell2.coinsImageView?.image = UIImage(named: coinsImageM[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 13:
cell2.coinsImageView?.image = UIImage(named: coinsImageN[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 14:
cell2.coinsImageView?.image = UIImage(named: coinsImageO[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 15:
cell2.coinsImageView?.image = UIImage(named: coinsImageP[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 16:
cell2.coinsImageView?.image = UIImage(named: coinsImageQ[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 17:
cell2.coinsImageView?.image = UIImage(named: coinsImageR[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 18:
cell2.coinsImageView?.image = UIImage(named: coinsImageS[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 19:
cell2.coinsImageView?.image = UIImage(named: coinsImageT[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 20:
cell2.coinsImageView?.image = UIImage(named: coinsImageU[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 21:
cell2.coinsImageView?.image = UIImage(named: coinsImageV[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
case 22:
cell2.coinsImageView?.image = UIImage(named: coinsImageW[indexPath.row])
cell2.cionsName?.text = coinsNames[indexPath.row]
default: cell2
}
cell2.accessoryType = NSUserDefaults.standardUserDefaults().boolForKey(coinsNames[indexPath.row]) == true ? .Checkmark : .None
return cell2
}
override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
// self.coinsNames[indexPath.row]
NSUserDefaults.standardUserDefaults().setBool(!NSUserDefaults.standardUserDefaults().boolForKey(coinsNames[indexPath.row]), forKey: coinsNames[indexPath.row])
NSUserDefaults.standardUserDefaults().synchronize()
self.tableView.reloadRowsAtIndexPaths([indexPath], withRowAnimation: .None)
}
}
最佳答案
我可以建议你做一个这样的元组:
typealias yourItem = (flagName: String, flagImage: String, selected: Bool)
然后将您的 tableView dataSource 更改为 [yourItem] 数组,例如
让 tableData: [yourItem] = [yourItem(), yourItem()....]
最后,在 cellForRowAtIndexPath 中,您应该像那样检查所选状态
let item = tableData[indexPath.row]
cell.accessoryView = item.selected ? .Checkmark : nil
关于ios - Checkmark 在所有 23 个国家/地区的同一地点均被接受。但是我怎样才能将它设置为一个地方,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38597501/
我有一个Ruby程序,它使用rubyzip压缩XML文件的目录树。gem。我的问题是文件开始变得很重,我想提高压缩级别,因为压缩时间不是问题。我在rubyzipdocumentation中找不到一种为创建的ZIP文件指定压缩级别的方法。有人知道如何更改此设置吗?是否有另一个允许指定压缩级别的Ruby库? 最佳答案 这是我通过查看rubyzip内部创建的代码。level=Zlib::BEST_COMPRESSIONZip::ZipOutputStream.open(zip_file)do|zip|Dir.glob("**/*")d
我在使用omniauth/openid时遇到了一些麻烦。在尝试进行身份验证时,我在日志中发现了这一点:OpenID::FetchingError:Errorfetchinghttps://www.google.com/accounts/o8/.well-known/host-meta?hd=profiles.google.com%2Fmy_username:undefinedmethod`io'fornil:NilClass重要的是undefinedmethodio'fornil:NilClass来自openid/fetchers.rb,在下面的代码片段中:moduleNetclass
使用带有Rails插件的vim,您可以创建一个迁移文件,然后一次性打开该文件吗?textmate也可以这样吗? 最佳答案 你可以使用rails.vim然后做类似的事情::Rgeneratemigratonadd_foo_to_bar插件将打开迁移生成的文件,这正是您想要的。我不能代表textmate。 关于ruby-使用VimRails,您可以创建一个新的迁移文件并一次性打开它吗?,我们在StackOverflow上找到一个类似的问题: https://sta
我需要从一个View访问多个模型。以前,我的links_controller仅用于提供以不同方式排序的链接资源。现在我想包括一个部分(我假设)显示按分数排序的顶级用户(@users=User.all.sort_by(&:score))我知道我可以将此代码插入每个链接操作并从View访问它,但这似乎不是“ruby方式”,我将需要在不久的将来访问更多模型。这可能会变得很脏,是否有针对这种情况的任何技术?注意事项:我认为我的应用程序正朝着单一格式和动态页面内容的方向发展,本质上是一个典型的网络应用程序。我知道before_filter但考虑到我希望应用程序进入的方向,这似乎很麻烦。最终从任何
我想要做的是有2个不同的Controller,client和test_client。客户端Controller已经构建,我想创建一个test_clientController,我可以使用它来玩弄客户端的UI并根据需要进行调整。我主要是想绕过我在客户端中内置的验证及其对加载数据的管理Controller的依赖。所以我希望test_clientController加载示例数据集,然后呈现客户端Controller的索引View,以便我可以调整客户端UI。就是这样。我在test_clients索引方法中试过这个:classTestClientdefindexrender:template=>
我正在查看instance_variable_set的文档并看到给出的示例代码是这样做的:obj.instance_variable_set(:@instnc_var,"valuefortheinstancevariable")然后允许您在类的任何实例方法中以@instnc_var的形式访问该变量。我想知道为什么在@instnc_var之前需要一个冒号:。冒号有什么作用? 最佳答案 我的第一直觉是告诉你不要使用instance_variable_set除非你真的知道你用它做什么。它本质上是一种元编程工具或绕过实例变量可见性的黑客攻击
如果您尝试在Ruby中的nil对象上调用方法,则会出现NoMethodError异常并显示消息:"undefinedmethod‘...’fornil:NilClass"然而,有一个tryRails中的方法,如果它被发送到一个nil对象,它只返回nil:require'rubygems'require'active_support/all'nil.try(:nonexisting_method)#noNoMethodErrorexceptionanymore那么try如何在内部工作以防止该异常? 最佳答案 像Ruby中的所有其他对象
关闭。这个问题需要detailsorclarity.它目前不接受答案。想改进这个问题吗?通过editingthispost添加细节并澄清问题.关闭8年前。Improvethisquestion为什么SecureRandom.uuid创建一个唯一的字符串?SecureRandom.uuid#=>"35cb4e30-54e1-49f9-b5ce-4134799eb2c0"SecureRandom.uuid方法创建的字符串从不重复?
我想设置一个默认日期,例如实际日期,我该如何设置?还有如何在组合框中设置默认值顺便问一下,date_field_tag和date_field之间有什么区别? 最佳答案 试试这个:将默认日期作为第二个参数传递。youcorrectlysetthedefaultvalueofcomboboxasshowninyourquestion. 关于ruby-on-rails-date_field_tag,如何设置默认日期?[rails上的ruby],我们在StackOverflow上找到一个类似的问
我有一个正在构建的应用程序,我需要一个模型来创建另一个模型的实例。我希望每辆车都有4个轮胎。汽车模型classCar轮胎模型classTire但是,在make_tires内部有一个错误,如果我为Tire尝试它,则没有用于创建或新建的activerecord方法。当我检查轮胎时,它没有这些方法。我该如何补救?错误是这样的:未定义的方法'create'forActiveRecord::AttributeMethods::Serialization::Tire::Module我测试了两个环境:测试和开发,它们都因相同的错误而失败。 最佳答案