- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用 Swift 4 构建一个货币转换器。我的主要问题仍然是我的应用程序在点击转换按钮时崩溃。我已经被这个问题困扰了 1 周了,我有点绝望。我没有在网上找到任何相关的解决方案,我仍然不明白我的错误在哪里,这真的很烦人。
我收到此错误消息:
Thread 1: signal SIGABRT
从这行代码:
类 AppDelegate:UIResponder,UIApplicationDelegate {
这是完整的消息:
2018-08-31 10:43:19.483566+0200 Baluchon[21101:1535106] -[Baluchon.CurrencyChangeViewController convert:]: unrecognized selector sent to instance 0x7fc51ef066802018-08-31 10:43:19.491934+0200 Baluchon[21101:1535106] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '-[Baluchon.CurrencyChangeViewController convert:]: unrecognized selector sent to instance 0x7fc51ef06680'*** First throw call stack:( 0 CoreFoundation 0x000000010cfa71e6 __exceptionPreprocess + 294 1 libobjc.A.dylib 0x0000000109560031 objc_exception_throw + 48 2 CoreFoundation 0x000000010d028784 -[NSObject(NSObject) doesNotRecognizeSelector:] + 132 3 UIKit 0x000000010a0226db -[UIResponder doesNotRecognizeSelector:] + 295 4 CoreFoundation 0x000000010cf29898 ___forwarding___ + 1432 5 CoreFoundation 0x000000010cf29278 _CF_forwarding_prep_0 + 120 6 UIKit 0x0000000109df53e8 -[UIApplication sendAction:to:from:forEvent:] + 83 7 UIKit 0x0000000109f707a4 -[UIControl sendAction:to:forEvent:] + 67 8 UIKit 0x0000000109f70ac1 -[UIControl _sendActionsForEvents:withEvent:] + 450 9 UIKit 0x0000000109f6fa09 -[UIControl touchesEnded:withEvent:] + 580 10 UIKit 0x0000000109e6a0bf -[UIWindow _sendTouchesForEvent:] + 2729 11 UIKit 0x0000000109e6b7c1 -[UIWindow sendEvent:] + 4086 12 UIKit 0x0000000109e0f310 -[UIApplication sendEvent:] + 352 13 UIKit 0x000000010a7506af __dispatchPreprocessedEventFromEventQueue + 2796 14 UIKit 0x000000010a7532c4 __handleEventQueueInternal + 5949 15 CoreFoundation 0x000000010cf49bb1 __CFRUNLOOP_IS_CALLING_OUT_TO_A_SOURCE0_PERFORM_FUNCTION__ + 17 16 CoreFoundation 0x000000010cf2e4af __CFRunLoopDoSources0 + 271 17 CoreFoundation 0x000000010cf2da6f __CFRunLoopRun + 1263 18 CoreFoundation 0x000000010cf2d30b CFRunLoopRunSpecific + 635 19 GraphicsServices 0x000000010f7daa73 GSEventRunModal + 62 20 UIKit 0x0000000109df4057 UIApplicationMain + 159 21 Baluchon 0x000000010890e0f7 main + 55 22 libdyld.dylib 0x000000010e0c3955 start + 1)libc++abi.dylib: terminating with uncaught exception of type NSException(lldb)
I'm following a MVC pattern so here is my model:
struct Currency: Decodable {
let rates: [String: Double]?
}
class CurrencyChangeService {
var currencies = [String]()
var rate = [Double]()
static var shared = CurrencyChangeService()
private init() {}
private static let currencyChangeUrl = URL(string: "http://data.fixer.io/api/latest?access_key=mykey")!
var task: URLSessionDataTask?
private var currencySession = URLSession(configuration: .default)
init(currencySession: URLSession) {
self.currencySession = currencySession
}
func getCurrencyChange(callback: @escaping (Bool, Currency?) -> Void) {
task?.cancel()
task = currencySession.dataTask(with: CurrencyChangeService.currencyChangeUrl) { data, response, error in
DispatchQueue.main.async {
guard let data = data, error == nil else {
callback(false, nil)
return
}
guard let response = response as? HTTPURLResponse, response.statusCode == 200 else {
callback(false, nil)
return
}
guard let responseJSON = try? JSONDecoder().decode(Currency.self, from: data) else {
callback(false, nil)
return
}
for (key, value) in responseJSON.rates! {
self.currencies.append(key)
self.rate.append(value)
}
callback(true, responseJSON)
}
}
task?.resume()
}
}
这是我的 Controller :
import UIKit
class CurrencyChangeViewController: UIViewController {
//MARK: - Outlets
@IBOutlet weak var myValueTextField: UITextField!
@IBOutlet weak var myCurrencyTextField: UITextField!
@IBOutlet weak var myConvertedValueLabel: UILabel!
@IBOutlet weak var convertButton: UIButton!
@IBOutlet weak var activityIndicator: UIActivityIndicatorView!
//MARK: - Properties
var selectedCurrency: Double = 0
//MARK: - View Life Cycle
override func viewDidLoad() {
super.viewDidLoad()
currencyChange()
createCurrencyPicker()
createNumberPad()
}
//MARK: - Action
@IBAction func convert() {
if myValueTextField.text != "" {
myConvertedValueLabel.text = String(Double(myValueTextField.text!)! * selectedCurrency)
myConvertedValueLabel.text = String(format: "%.2f")
}
}
@IBAction func dismissKeyboard(_ sender: UITapGestureRecognizer) {
myValueTextField.resignFirstResponder()
myCurrencyTextField.resignFirstResponder()
}
//MARK: - Methods
func currencyChange() {
CurrencyChangeService.shared.getCurrencyChange { (success, rate) in
self.toggleActivityIndicator(shown: true)
if success {
self.toggleActivityIndicator(shown: false)
} else {
self.showAlert(title: "Error", message: "Rates download failed!")
}
}
}
func toggleActivityIndicator(shown: Bool) {
activityIndicator.isHidden = !shown
convertButton.isHidden = shown
}
func createNumberPad() {
myValueTextField.keyboardType = UIKeyboardType.numberPad
}
func createCurrencyPicker() {
let currencyPicker = UIPickerView()
currencyPicker.delegate = self
myCurrencyTextField.inputView = currencyPicker
}
}
extension CurrencyChangeViewController: UIPickerViewDelegate, UIPickerViewDataSource {
func numberOfComponents(in pickerView: UIPickerView) -> Int {
return 1
}
func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
return CurrencyChangeService.shared.currencies.count
}
func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
CurrencyChangeService.shared.currencies.sort()
return CurrencyChangeService.shared.currencies[row]
}
func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) {
selectedCurrency = CurrencyChangeService.shared.rate[row]
myCurrencyTextField.text = CurrencyChangeService.shared.currencies[row]
}
}
最佳答案
在 IB 中,在最右边的按钮上,删除对 @IBAction
转换的引用,然后重新添加它。看起来编译器找不到 convert
。
关于带有 UIPickerView 和获取请求 Fixer API 的 Swift 4 货币转换器,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52107059/
我正在编写一个汽车租赁应用程序,用户必须指定取车和还车位置。 第一步,用户必须选择取货/返回办公室的区域/区域。选择区域后,他必须从该区域可用的办事处列表中进行选择。 为了选择办公室,我使用了 4 个
我正在尝试创建一个文本框,当选择该文本框时,UIPickerView 将打开并提供可供选择的选项。选择后,UIPickerView 将隐藏,所选项目将显示在文本框中。当我运行此程序时,数组中的第一个元
我有多个 UIPickerView 的问题,我在 UICollectionView 上有 8 个,当我滚动第一个 PickerView 和第五个 PickerView 时,它开始自行滚动并采用与第一个
我正在阅读一本 Swift OOP 书籍,我理解实例方法具有将在函数中使用的参数的想法。不清楚的是,在遵循 UIPickerViews 和 UITableViews 的在线教程时,有些方法将 UIPi
我有两个不同的 UIPickerView用户选择第一个 UIPickerView来自 didSelectRow第一个选择器,我得到第二个的输入 UIPickerView .我尝试为单个选择器设置标签,
函数 pickerView() 在 ViewLoad 上调用的代码 private func createPickerView(){ picker = UIPickerView(frame:
我创建了 UIPickerView 如下。现在我想让它 resignFirstResponder 如果用户在其他地方点击然后 UIPickerView 我怎么能实现呢。我已经按照以下方式创建了 UIP
我的 View Controller 中有两个 UIPickerview,pickerView1 和 pickerView2。 我在这里想要实现的是,当我从 pickerView1 中选择一个字符串时
我们正在使用 UIPickerView允许用户从选项列表中进行选择。我们正在添加 UIPickerView作为容器 UIView 的 subview 。然后我们将一个 UITapGestureReco
好吧,我不知道如何处理这个问题。 我有一个 UITextField,我根据 XML 文件的定义将其动态添加到 UITableView,在 XML 文件中,我可以将列表指定为其中一种数据类型,然后我所做
我现在有2个UIPickerView,以后想再添加3个,代码如下: -(void)viewDidLoad{ Pos_x = 5; Pos_y = 70; for (i= 0; i<2; i++) {
UIPickerView 的 selectRow:inComponent:animated:调用pickerView:didSelectRow:inComponent: ? 否则,我可以自己打电话吗?
我有两个按钮,打开一个 UIPickerView @IBOutlet weak var convertFromButton: UIButton! @IBOutlet weak var convertT
祝大家有美好的一天 我尝试在主题行中解释我的查询。据我了解,从代码中看到,所有 pickerview 都在 ViewDidLoad() 中初始化,这意味着它们都有自己的数据集。作为数据验证的一部分(在
我试图在 PickerView 中显示血型,但由于某些原因,选项仅显示为问号! 这是我的代码: class RegisterViewController: UIViewController,
我正在尝试将工具栏添加到 UIPicker . 我已经看到正确的方法是这样: UIToolbar* toolbarWeight= [[UIToolbar alloc] initWithFrame:CG
我将如何向 uipickerview 添加手势事件来更改选项卡?我必须创建一个自定义类,但是,我不知道如何处理 uipickerview。我当前在 uiviews 中存在手势来执行此操作,但我在使用
我想做的是: 显示了一个 UIPickerView。如果用户触摸选定的行,则该行将被锁定(它是多组件选择器),并且其他组件可以自由旋转。如果该行已被锁定并且用户触摸了锁定的行,则该行将被解锁并可以自由
我有两种看法。第一个:第一个 View Controller 第二:SecondViewController FirstView Controller 是我的 UINavigationControll
使用 UISegmentedControl,您可以在不选择任何内容的情况下启动它。如何使用 UIPickerView 做到这一点?看起来显示默认为索引 0。 谢谢 最佳答案 选择器轮必须停留在某些值上
我是一名优秀的程序员,十分优秀!