私は生の値から列挙型を取得しようとしています:
enum TestEnum: String {
case Name
case Gender
case Birth
var rawValue: String {
switch self {
case .Name: return "Name"
case .Gender: return "Gender"
case .Birth: return "Birth Day"
}
}
}
let name = TestEnum(rawValue: "Name") //Name
let gender = TestEnum(rawValue: "Gender") //Gender
ただし、rawValue
はスペースを含む文字列では機能しないようです。
let birth = TestEnum(rawValue: "Birth Day") //nil
それを取得する方法はありますか?
複雑すぎて、未加工の値を直接ケースに割り当てるだけです
enum TestEnum: String {
case Name = "Name"
case Gender = "Gender"
case Birth = "Birth Day"
}
let name = TestEnum(rawValue: "Name")! //Name
let gender = TestEnum(rawValue: "Gender")! //Gender
let birth = TestEnum(rawValue: "Birth Day")! //Birth
ケース名が生の値と一致する場合は、それを省略することもできます
enum TestEnum: String {
case Name, Gender, Birth = "Birth Day"
}
Swift 3+では、すべての列挙型のケースはlowercased
完全な実例:
enum TestEnum: String {
case name = "A Name"
case otherName
case test = "Test"
}
let first: TestEnum? = TestEnum(rawValue: "A Name")
let second: TestEnum? = TestEnum(rawValue: "OtherName")
let third: TestEnum? = TestEnum(rawValue: "Test")
print("\(first), \(second), \(third)")
これらはすべて機能しますが、生の値を使用して初期化する場合はオプションです。これが問題になる場合は、none
ケースを追加して列挙を作成できない場合はそれを返すために、列挙の初期化子またはコンストラクターを作成してこれを処理できます。このようなもの:
static func create(rawValue:String) -> TestEnum {
if let testVal = TestEnum(rawValue: rawValue) {
return testVal
}
else{
return .none
}
}
define enum このようにできます-
enum TestEnum: String {
case Name, Gender, Birth
}
または
enum TestEnum: String {
case Name
case Gender
case Birth
}
initメソッドを提供できます。このメソッドはdefaultsのいずれかのメンバー値に。
enum TestEnum: String {
case Name, Gender, Birth
init() {
self = .Gender
}
}
上記の例では、TestEnum.Nameには「Name」という暗黙の生の値が含まれています。
RawValueプロパティを使用して、列挙ケースの生の値にアクセスします。
let testEnum = TestEnum.Name.rawValue
// testEnum is "Name"
let testEnum1 = TestEnum()
// testEnum1 is "Gender"
Swift 4.2およびCaseIterableプロトコルでは、それほど難しくありません!
以下に実装方法の例を示します。
import UIKit
private enum DataType: String, CaseIterable {
case someDataOne = "an_awesome_string_one"
case someDataTwo = "an_awesome_string_two"
case someDataThree = "an_awesome_string_three"
case someDataFour = "an_awesome_string_four"
func localizedString() -> String {
// Internal operation
// I have a String extension which returns its localized version
return self.rawValue.localized
}
static func fromLocalizedString(localizedString: String) -> DataType? {
for type in DataType.allCases {
if type.localizedString() == localizedString {
return type
}
}
return nil
}
}
// USAGE EXAMPLE
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
if let dataType = DataType.fromLocalizedString(localizedString: self.title) {
loadUserData(type: dataType)
}
}
RawValueに基づいてDataTypeを返すように簡単に変更できます。私はそれが役立つことを願っています!
以下は、Swift 4.1のより使用可能なコードの例です。
import UIKit
enum FormData {
case userName
case password
static let array = [userName, password]
var placeHolder: String {
switch self {
case .userName:
return AppString.name.localized // will return "Name" string
case .password:
return AppString.password.localized // will return "Password" string
}
}
}
enum AppString: String {
case name = "Name"
case password = "Password"
var localized: String {
return NSLocalizedString(self.rawValue, comment: "")
}
}
これはSwift 4.2の迅速かつクリーンなソリューションだと思います(プレイグラウンドにc&pできます)
import UIKit
public enum SomeEnum: String, CaseIterable {
case Sun,moon,venus,pluto
}
let str = "venus"
let newEnum = SomeEnum.allCases.filter{$0.rawValue == str}.first
// newEnum is optional
if let result = newEnum {
print(result.rawValue)
}
Enumを使用してrawvalueを表示します
import UIKit
enum car: String {
case bmw = "BMW"
case jaquar = "JAQUAR"
case rd = "RD"
case benz = "BENZ"
}
class ViewController: UIViewController {
@IBOutlet weak var label: UILabel!
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
label.text = car.bmw.rawValue
}
}