Swift 可选参数函数
Swift optional parameter functions
所以我有以下功能:
func remoteCall(_url:String, _params:[String: String]?=nil){
...
...
Alamofire.request(.POST, _url, parameters: _params) //requires _params to be of type [String String!]
...
}
如你所见,我能做到:
let url = "https://eamorr.com/remote.php"
remoteCall(url) //works great!
或者,我可以这样做:
let url = "https://eamorr.com/remote.php"
let params = [
"email": "eamorr@eamorr.com",
"pword": "secret"
]
remoteCall(url, _params:params) //works great!
然而,我做不到的是:
let url = "https://eamorr.com/remote.php"
let params = [
"email": email.text, //where "email" is a UITextField
"pword": pword.text //where "pword" is a UITextField
]
remoteCall(url, _params:params) //this doesn't work
我收到这个错误:
'String!' is not identical to 'String'
我需要能够适应所有三种情况(不传递任何内容、传递原始字符串和传递 UITextField 值)
不幸的是,如果我尝试将函数签名(注意关键字 "String" 后的 '!')更改为:
func remoteCall(_url:String, _params:[String: String!]?=nil){
...
...
}
UITextField 值有效,传递 nil 有效,但原始字符串情况在 运行 时失败。
fatal error: can't unsafeBitCast between types of different sizes
EXC_BAD_INSTRUCTION
我会经常使用这个函数,所以我不想用混乱的代码包装我的 "params" 变量。
我是 Swift 的新手,Objective-C 头脑,正在尝试重新学习所有内容...
我想我是否能以某种方式在函数内部将任何不正确的 [String: String]
整齐地转换为 [String: String!]
而不会干扰任何已经工作的 nil
或 [String: String!]
?
我认为这应该可行:
let url = "https://eamorr.com/remote.php"
let params: [String: String] = [ // Note explicitly declared type
"email": email.text, //where "email" is a UITextField
"pword": pword.text //where "pword" is a UITextField
]
remoteCall(url, _params:params)
你的问题是没有明确的类型声明 Swift 会为你推断一个。您创建的字典中的两个值都是 String!
类型,与 String
不同。因此错误。如果您明确告诉 Swift params
属于 [String: String]
类型,那应该可以正常工作,因为可以将 String!
值分配给 String
变量。
所以我有以下功能:
func remoteCall(_url:String, _params:[String: String]?=nil){
...
...
Alamofire.request(.POST, _url, parameters: _params) //requires _params to be of type [String String!]
...
}
如你所见,我能做到:
let url = "https://eamorr.com/remote.php"
remoteCall(url) //works great!
或者,我可以这样做:
let url = "https://eamorr.com/remote.php"
let params = [
"email": "eamorr@eamorr.com",
"pword": "secret"
]
remoteCall(url, _params:params) //works great!
然而,我做不到的是:
let url = "https://eamorr.com/remote.php"
let params = [
"email": email.text, //where "email" is a UITextField
"pword": pword.text //where "pword" is a UITextField
]
remoteCall(url, _params:params) //this doesn't work
我收到这个错误:
'String!' is not identical to 'String'
我需要能够适应所有三种情况(不传递任何内容、传递原始字符串和传递 UITextField 值)
不幸的是,如果我尝试将函数签名(注意关键字 "String" 后的 '!')更改为:
func remoteCall(_url:String, _params:[String: String!]?=nil){
...
...
}
UITextField 值有效,传递 nil 有效,但原始字符串情况在 运行 时失败。
fatal error: can't unsafeBitCast between types of different sizes
EXC_BAD_INSTRUCTION
我会经常使用这个函数,所以我不想用混乱的代码包装我的 "params" 变量。
我是 Swift 的新手,Objective-C 头脑,正在尝试重新学习所有内容...
我想我是否能以某种方式在函数内部将任何不正确的 [String: String]
整齐地转换为 [String: String!]
而不会干扰任何已经工作的 nil
或 [String: String!]
?
我认为这应该可行:
let url = "https://eamorr.com/remote.php"
let params: [String: String] = [ // Note explicitly declared type
"email": email.text, //where "email" is a UITextField
"pword": pword.text //where "pword" is a UITextField
]
remoteCall(url, _params:params)
你的问题是没有明确的类型声明 Swift 会为你推断一个。您创建的字典中的两个值都是 String!
类型,与 String
不同。因此错误。如果您明确告诉 Swift params
属于 [String: String]
类型,那应该可以正常工作,因为可以将 String!
值分配给 String
变量。