- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个带有两个屏幕( View Controller 和表格 View )的应用程序,每次用户更新数据上使用的过滤器时,我都会尝试在表格 View 中重新加载数据。例如,我的数组保存火车时刻表数据,我根据方向过滤这些数据。用户更新方向,然后 TableView 应重新加载并更新方向过滤器。
我尝试过使用 DispatchQueue.main.async { self.tableView.reloadData() }
我有一个由按钮操作调用的函数来更新方向
@IBAction func ChangeDirection(_ sender: Any) {
changeDirection()
}
func changeDirection()
{
if direction == "Southbound" {
direction = "Northbound"
}
else {
direction = "Southbound"
}
DispatchQueue.main.async { self.tableView.reloadData() }
}
我使用带有 ui 选择器的 View Controller ,以便用户可以选择他们想要的火车时刻表的车站,ui 选择器访问一个单例类,该类保存每个车站的火车计划数据(我想知道这是否可能是问题)也许这需要从 TableView 访问。
if segue.identifier == "Stations"
{
let vc = segue.destination as? TableViewController
let xmlParserSchedule = XMLParserSchedule()
xmlParserSchedule.runScheudledParser(userStation:StationsDecoder.shared.uiStationsSorted[station])
vc?.stationData=xmlParserSchedule.sortedArrival
}
我希望 tableview 根据用户选择的新方向重新加载,但是 tableview 已关闭,我们返回到 View Controller ui 选择器屏幕。当我在调用 reloaddata() 时调试代码时,我注意到内存似乎无限泄漏。
我正在添加来自 View Controller 和 TableView 的完整代码,以防万一这有帮助:
View Controller : 导入 UIKit
@available(iOS 9.0, *)
class ViewController: UIViewController, UIPickerViewDelegate, UIPickerViewDataSource {
//stores picker selection for array index in station data
var station = 0
//UI Picker Outlet
@IBOutlet weak var UIStationPicker: UIPickerView!
override func viewDidLoad() {
super.viewDidLoad()
//self.UIStationPicker.setValue(UIColor.white, forKey: "textColor")
self.UIStationPicker.delegate = self
self.UIStationPicker.dataSource = self
self.UIStationPicker.reloadAllComponents()
//check if station file is already loaded by accessing the singletons/create plist throw method
do {
try? CreatePlist.shared.createPlist()
//throw needed here to reach the catch block
throw CreatePlist.ErrorsToThrow.fileAlreadyExists
}catch {
print("file already exists")
print("time to get decoding")
//decode the station plist using singleton class method
StationsDecoder.shared.decoder()
//get stations in array of dictionaries using singlton class method
StationsDecoder.shared.getStations()
self.UIStationPicker.reloadAllComponents()
}
}
//uiPicker delegate methods
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Number of columns of data
}
func numberOfComponents(in pickerView: UIPickerView) ->Int {
return 1
}
// The number of rows of data
func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int)-> Int {
return StationsDecoder.shared.uiStationsSorted.count
}
// The data to return for the row and component (column) that's being passed in
func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int)-> String? {
return StationsDecoder.shared.uiStationsSorted[row]
}
func pickerView(_ pickerView: UIPickerView, attributedTitleForRow row: Int, forComponent component: Int) -> NSAttributedString? {
let titleData = StationsDecoder.shared.uiStationsSorted[row]
let myTitle = NSAttributedString(string: titleData, attributes: [NSAttributedString.Key.font:UIFont(name: "Georgia", size: 28.0)!,NSAttributedString.Key.foregroundColor:UIColor.white])
return myTitle
}
// Capture the picker view selection
func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
station = row
performSegue(withIdentifier: "Stations", sender: Any?.self)
}
override func prepare(for segue: UIStoryboardSegue, sender: Any?){
if segue.identifier == "Stations"
{
let vc = segue.destination as? TableViewController
let xmlParserSchedule = XMLParserSchedule()
xmlParserSchedule.runScheudledParser(userStation:StationsDecoder.shared.uiStationsSorted[station])
vc?.stationData=xmlParserSchedule.sortedArrival
}
}
}
表格 View
import UIKit
var direction:String = "Southbound"
class TableViewController: UITableViewController{
//this code here is interesting, it dismisses the presented view with orignally presented view ie tableview is replaced with initial view controller. this avoids calling dataload method again in view controller which can duplicate your data
@IBAction func GoBack(_ sender: Any) {
dismiss(animated: true, completion: nil)
}
@IBAction func ChangeDirection(_ sender: Any) {
changeDirection()
}
func changeDirection()
{
if direction == "Southbound" {
direction = "Northbound"
}
else {
direction = "Southbound"
}
DispatchQueue.main.async { self.tableView.reloadData() }
}
override func viewDidLoad() {
super.viewDidLoad()
tableView.delegate = self
tableView.dataSource = self
}
//array of tuples to hold station data
var stationData: [(stationfullname:String,origin: String,destination:String,lastLocation: String, dueIn: Int, late: Int, due: Int, expArrival: String, direction: String) ] = []
//array literal, for tuples
//var data = [String:(stationfullname:String,origin: String,destination:String,lastLocation: String, dueIn: Int, late: Int, due: Int, expArrival: String, direction: String)].self
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
// MARK: - Table view data source
override func numberOfSections(in tableView: UITableView) -> Int {
// As long as `total` is the last case in our TableSection enum,
// this method will always be dynamically correct no mater how many table sections we add or remove.
return 1
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
// #warning Incomplete implementation, return the number of rows
return stationData.filter{($0.direction == direction)}.count
}
override func tableView(_ tableView: UITableView, titleForHeaderInSection section: Int) -> String? {
return direction
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "StationLevel", for: indexPath)
cell.textLabel?.text = stationData.filter{($0.direction == direction)}[indexPath.row].destination
cell.detailTextLabel?.text = "\(String(stationData.filter{($0.direction == direction)}[indexPath.row].due)) mins"
return cell
}
}
最佳答案
哦,Lordie,原来我有一个额外的发送事件用于发送回 View Controller 的按钮,有 4 个小时我永远不会回来。不管帕尔文如何,感谢您的帮助。
关于ios - reloaddata() 函数关闭 tableview,并返回到上一个屏幕,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58453638/
我正在对 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
我是一名优秀的程序员,十分优秀!