- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
class MyOrdersViewController:UITableViewController,GMSMapViewDelegate{
private var username = KeychainWrapper.standard.string(forKey: "username")
var googleStaticImages = [UIImage]()
var OrdersByCutomer = [Booking]()
var orderByCustomer: Booking! = Booking()
var driverPhotoUrlString: String!
var driverPhotoURL = [String]()
var refreshCtrl: UIRefreshControl!
该 View Controller 是嵌入在 UItabViewController 中的几个 View Controller 之一。当第一次选择此 viewController 的选项卡时,一切正常,数据源将从 getOrdersByCustomer() 进行更新,并且所有订单单元格都会显示。但是,当从另一个 View Controller (另一个选项卡)下订单并且我使用 self.tabBarController?.selectedIndex = 2 导航回到该 View Controller 时,我将获取从其他 View Controller 下的新订单的 JSON,但是此新订单的单元格未显示。
当从 viewWillAppear 调用以下方法时,数据源正在更新,但 self.tableView.reloadData() 似乎不起作用,并且新下订单的单元格不会显示。
func getOrdersByCustomer(){
if self.refreshCtrl.isRefreshing{
self.refreshCtrl.attributedTitle = NSAttributedString(string: "Refresh orders..")
}
ARSLineProgress.ars_showOnView(self.view)
Alamofire.request("http://www.*******************************************************ordersbyUser.php?", method: .get, parameters: ["username":username!], encoding: URLEncoding.default).responseString { response in
print(response.request ?? "") // original URL request
print(response.response ?? "") // URL response
print(response.data!) // server data
print(response.result) // result of response serialization
if let JSON = response.result.value {
print("Get Orders By User JSON: " , JSON)
var jsonObject: [AnyObject]!
do{
jsonObject = try JSONSerialization.jsonObject(with: response.data!, options:JSONSerialization.ReadingOptions.allowFragments) as? Array
print(jsonObject)
if jsonObject.isEmpty{
ARSLineProgress.hideWithCompletionBlock {
self.showAlertWithMessage(message: "No orders found.Use the Book Now tab to order!", ControllerTitle: "My Orders", ActionTitle: "OK")
if self.refreshCtrl.isRefreshing{
self.refreshCtrl.endRefreshing()
}
}
}
} catch let error as NSError {
print(error)
}
var jsonElement: [String:AnyObject]
for i in 0 ..< jsonObject.count
{
jsonElement = jsonObject[i] as! Dictionary
let staticUrl = jsonElement["staticurl"] as? String
let orderID = jsonElement["orderid"] as? String
let customerPrice = jsonElement["userprice"] as? String
let orderTime = jsonElement["order_time"] as? String
let orderStatus = jsonElement["stat"] as? String
let pickUpLatitude = jsonElement["plat"] as? String
let pickUpLongitude = jsonElement["plon"] as? String
let dropOffLatitude = jsonElement["dlat"] as? String
let dropOffLongitude = jsonElement["dlon"] as? String
let driverphotoURL = jsonElement["driver_photo"] as? String
print(jsonElement)
let booking = Booking()
booking.orderId = orderID!
booking.price = "₹" + customerPrice!
booking.pickUpTime = orderTime!
booking.status = orderStatus!
booking.pickUpLatitude = pickUpLatitude!
booking.pickUpLongitude = pickUpLongitude!
booking.dropOffLatitude = dropOffLatitude!
booking.dropOffLongitude = dropOffLongitude!
booking.staticUrl = staticUrl!
DispatchQueue.main.async{
self.OrdersByCutomer.append(booking)
if driverphotoURL != nil {
self.driverPhotoURL.append(driverphotoURL!)
self.refreshTable()
}
}
}
if self.refreshCtrl.isRefreshing{
self.refreshCtrl.endRefreshing()
self.refreshCtrl.attributedTitle = NSAttributedString(string: "Pull to refresh orders")
}
ARSLineProgress.hide()
}
}
}
func refreshTable(){
DispatchQueue.main.async {
self.tableView.reloadData()
}
}
override func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return OrdersByCutomer.count
}
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
print("CELL FOR ROW AT INDEX EXCECUTED")
self.orderByCustomer = self.OrdersByCutomer[(indexPath as NSIndexPath).row]
self.driverPhotoUrlString = self.driverPhotoURL[(indexPath as NSIndexPath).row]
let cell = tableView.dequeueReusableCell(withIdentifier: "MyOrdersCell", for: indexPath) as! MyOrdersCell
cell.contentView.layer.borderColor = UIColor.clear.cgColor
cell.contentView.layer.borderWidth = 10
let staticMapsURL = URL(string:orderByCustomer.staticUrl)
let p = Bundle.main.path(forResource: "39", ofType: "gif")!
let data = try! Data(contentsOf: URL(fileURLWithPath: p))
cell.googleStaticMapImageView.kf.indicatorType = .image(imageData: data)
cell.googleStaticMapImageView.kf.setImage(with: staticMapsURL)
// if driver photo is not available use default image
if driverPhotoUrlString.contains("600x300"){
cell.driverProfileImage.image = UIImage.init(named: "DriverImage.png")
cell.driverProfileImage.backgroundColor = UIColor.lightGray
}else{
let driverPhotoURL = URL(string: driverPhotoUrlString)
cell.driverProfileImage.kf.setImage(with: driverPhotoURL)
cell.driverProfileImage.kf.indicatorType = .activity
}
// make the driver profile picture cicular
cell.driverProfileImage.layer.borderWidth = 1
cell.driverProfileImage.layer.masksToBounds = false
cell.driverProfileImage.layer.borderColor = UIColor.black.cgColor
cell.driverProfileImage.layer.cornerRadius = cell.driverProfileImage.frame.height/2
cell.driverProfileImage.clipsToBounds = true
cell.orderIdLabel.text = orderByCustomer.orderId
cell.orderTimeLabel.text = orderByCustomer.pickUpTime
cell.userPriceLabel.text = orderByCustomer.price
cell.statusLabel.text = orderByCustomer.status
return cell
}
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(true)
self.animateTable()
DispatchQueue.main.async {
self.getOrdersByCustomer()
}
print("ViewWillAppear")
}
override func viewDidLoad() {
super.viewDidLoad()
tableView.delegate = self
tableView.dataSource = self
print("ViewDidLoad")
self.refreshCtrl = UIRefreshControl()
self.refreshCtrl.addTarget(self, action: #selector(self.getOrdersByCustomer), for: .valueChanged)
self.refreshCtrl.attributedTitle = NSAttributedString(string: "Pull to refresh orders")
self.refreshControl = self.refreshCtrl
}
另一个 View Controller 中的方法
func transactionCompleted(withResponse response : NSDictionary,errorDescription error:NSError) -> Void {
self.dismiss(animated: true){
if response.count != 0{
print(response)
}
self.view.isUserInteractionEnabled = false
DispatchQueue.main.async {
self.submitBookingRequest(){(_status,_success) in
if _status == "yes"{
self.effectView.removeFromSuperview()
self.view.isUserInteractionEnabled = true
let alertController = UIAlertController(title: "Delivery", message: "Delivery order was placed successfull!", preferredStyle: UIAlertControllerStyle.alert)
let closeAction = UIAlertAction(title: "Ok", style: UIAlertActionStyle.cancel) { (alertAction) -> Void in
let mainStoryboard: UIStoryboard = UIStoryboard(name: "Main", bundle: nil)
let bookNowViewController = mainStoryboard.instantiateViewController(withIdentifier: "ViewController2") as! BookNowViewController
self.tabBarController?.selectedIndex = 2
self.navigationController?.setViewControllers([bookNowViewController], animated: false)
}
alertController.addAction(closeAction)
self.present(alertController, animated: true, completion: nil)
}else{
self.effectView.removeFromSuperview()
self.showAlertWithMessage(message: "Problem placing the order!Please Contact Customer Care", ControllerTitle: "Order", ActionTitle: "Close")
}
}
}
}
}
}
最佳答案
该问题与 getOrdersByCustomer()
有关。每次出现 View 时都会调用该方法,并将新记录添加到 OrdersByCutomer
数组中。但是,您不会每次都清空数组,因此第一次您将看到最初的“10”条记录,然后下一次您将看到“21”条记录,新添加的记录位于末尾。
关于swift - UItableView 无法快速重新加载数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43266522/
我通过 spring ioc 编写了一些 Rest 应用程序。但我无法解决这个问题。这是我的异常(exception): org.springframework.beans.factory.BeanC
我对 TestNG、Spring 框架等完全陌生,我正在尝试使用注释 @Value通过 @Configuration 访问配置文件注释。 我在这里想要实现的目标是让控制台从配置文件中写出“hi”,通过
为此工作了几个小时。我完全被难住了。 这是 CS113 的实验室。 如果用户在程序(二进制计算器)结束时选择继续,我们需要使用 goto 语句来到达程序的顶部。 但是,我们还需要释放所有分配的内存。
我正在尝试使用 ffmpeg 库构建一个小的 C 程序。但是我什至无法使用 avformat_open_input() 打开音频文件设置检查错误代码的函数后,我得到以下输出: Error code:
使用 Spring Initializer 创建一个简单的 Spring boot。我只在可用选项下选择 DevTools。 创建项目后,无需对其进行任何更改,即可正常运行程序。 现在,当我尝试在项目
所以我只是在 Mac OS X 中通过 brew 安装了 qt。但是它无法链接它。当我尝试运行 brew link qt 或 brew link --overwrite qt 我得到以下信息: ton
我在提交和 pull 时遇到了问题:在提交的 IDE 中,我看到: warning not all local changes may be shown due to an error: unable
我跑 man gcc | grep "-L" 我明白了 Usage: grep [OPTION]... PATTERN [FILE]... Try `grep --help' for more inf
我有一段代码,旨在接收任何 URL 并将其从网络上撕下来。到目前为止,它运行良好,直到有人给了它这个 URL: http://www.aspensurgical.com/static/images/a
在过去的 5 个小时里,我一直在尝试在我的服务器上设置 WireGuard,但在完成所有设置后,我无法 ping IP 或解析域。 下面是服务器配置 [Interface] Address = 10.
我正在尝试在 GitLab 中 fork 我的一个私有(private)项目,但是当我按下 fork 按钮时,我会收到以下信息: No available namespaces to fork the
我这里遇到了一些问题。我是 node.js 和 Rest API 的新手,但我正在尝试自学。我制作了 REST API,使用 MongoDB 与我的数据库进行通信,我使用 Postman 来测试我的路
下面的代码在控制台中给出以下消息: Uncaught DOMException: Failed to execute 'appendChild' on 'Node': The new child el
我正在尝试调用一个新端点来显示数据,我意识到在上一组有效的数据中,它在数据周围用一对额外的“[]”括号进行控制台,我认为这就是问题是,而新端点不会以我使用数据的方式产生它! 这是 NgFor 失败的原
我正在尝试将我的 Symfony2 应用程序部署到我的 Azure Web 应用程序,但遇到了一些麻烦。 推送到远程时,我在终端中收到以下消息 remote: Updating branch 'mas
Minikube已启动并正在运行,没有任何错误,但是我无法 curl IP。我在这里遵循:https://docs.traefik.io/user-guide/kubernetes/,似乎没有提到关闭
每当我尝试docker组成任何项目时,都会出现以下错误。 我尝试过有和没有sudo 我在这台机器上只有这个问题。我可以在Mac和Amazon WorkSpace上运行相同的容器。 (myslabs)
我正在尝试 pip install stanza 并收到此消息: ERROR: No matching distribution found for torch>=1.3.0 (from stanza
DNS 解析看起来不错,但我无法 ping 我的服务。可能是什么原因? 来自集群中的另一个 Pod: $ ping backend PING backend.default.svc.cluster.l
我正在使用Hibernate 4 + Spring MVC 4当我开始 Apache Tomcat Server 8我收到此错误: Error creating bean with name 'wel
我是一名优秀的程序员,十分优秀!