質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

91.14%

  • Swift

    5524questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Realm

    150questions

    RealmとはSQLiteやCore Dataに代わるモバイルデータベースです。iOSとAndroidの両方でサポートされています。

swift realm xcode

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 91

raa

score 9

現在、UserDefaultsを使ってテキストに入力した文字をラベルに反映させ、保存するという単純なものを作りましたが。これをRealmを使って同じようにさせたいのですが、本日使い始めたのでどのようにRealmを使えばいいのかわかりません。

1:Realmを使用するためにクラス作成
2:データを保存
3:データの呼び出し
これだけでいけるとは思うのですが、まだそこまで理解ができていません。できればどこをどのように変更すればいいのか教えていただけると助かります。

import UIKit
import RealmSwift

class SubViewController: UIViewController, UITextFieldDelegate {

    @IBOutlet weak var textField: UITextField!
    @IBOutlet weak var label: UILabel!

    var testText:String = "default"
    // UserDefaults のインスタンス
    let userDefaults = UserDefaults.standard

    override func viewDidLoad() {
        super.viewDidLoad()
        // textFiel の情報を受け取るための delegate を設定
        textField.delegate = self
        // デフォルト値
        userDefaults.register(defaults: ["DataStore": "default"])

        label.text = readData()
    }

    func textFieldShouldReturn(_ textField: UITextField) -> Bool{

        testText = textField.text!

        label.text = testText
        // キーボードを閉じる
        textField.resignFirstResponder()

        saveData(str: testText)

        return true
    }

    func saveData(str: String){
        // Keyを指定して保存
        userDefaults.set(str, forKey: "DataStore")
        userDefaults.synchronize()
    }

    func readData() -> String {
        // Keyを指定して読み込み
        let str: String = userDefaults.object(forKey: "DataStore") as! String

        return str
    }
}


イメージ説明
本当に簡単ですが、テキストに入力するとデータを保存、ラベルに反映されページを遷移してもラベルにはすでに入力された文字が表示される。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • t_obara

    2017/12/06 18:56

    この質問内容だけだと、realmのドキュメントを読むべしとか、やって欲しいことを丸投げしてるとご指摘を受けるのではないでしょうか。まずは1からでも良いのでご自身でどのように実現するのか・実現しようとしたのか試行過程などをご提示された上で、不明点をお聞きになられてはいかがでしょうか。

    キャンセル

回答 1

checkベストアンサー

0

もう解決しているかもしれませんが
ざっとコードだけ

import UIKit
import RealmSwift

class strData:Object{
    @objc dynamic var str = ""
}

class SubViewController: UIViewController, UITextFieldDelegate {
    let db = try! Realm()

    @IBOutlet weak var textField: UITextField!
    @IBOutlet weak var label: UILabel!

    var testText:String = "default"
    // UserDefaults のインスタンス
    //let userDefaults = UserDefaults.standard ->削除

    override func viewDidLoad() {
        super.viewDidLoad()
        // textFiel の情報を受け取るための delegate を設定
        textField.delegate = self
        // デフォルト値
        //userDefaults.register(defaults: ["DataStore": "default"]) ->削除

        label.text = readData()
    }

    func textFieldShouldReturn(_ textField: UITextField) -> Bool{

        testText = textField.text!

        label.text = testText
        // キーボードを閉じる
        textField.resignFirstResponder()

        saveData(str: testText)

        return true
    }

    func saveData(str: String){
        // Keyを指定して保存

        //userDefaults.set(str, forKey: "DataStore") ->削除
        //userDefaults.synchronize() ->削除let data = strData()
        strData.str = str
        try! self.db.write {
           self.db.add(data)
        }

    }

    func readData() -> String {
        // Keyを指定して読み込み
        let data = self.db.objects(strData.self)

        //let str: String = userDefaults.object(forKey: "DataStore") as! String ->削除let str = data[i].str

        return str
    }
}

最も簡単な形だとこのような感じになるかと思います

let str = data[i].str


と[i]がついているのは、検索結果のうち何番目のデータを使用するかを指定しなければならないからです
もし1件以上あることが確実で、最初のデータだけ取り出せれば良い場合はlet str = data.first!.strとすれば大丈夫です(firstとlastがあり、どちらもOptionalです)、0件であればnilで止まります
なお、検索の際の絞込やソートは別途行う必要があります(特に何も指定しなければ順番は保証されませんので、確実にデータを取り出したければ連番を振るなどしてソートのための番号を付けてあげるのが便利だと思います)

ソートをする場合は

let data = self.db.objects(strData.self).sorted(byKeyPath: "[ソートに使う値]", ascending: true)


となります(ascendingはtrueで昇順、falseで降順になります)

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/12/18 11:17

    曖昧な質問に丁寧に教えていただきありがとうございます。解決はしましたが、こちらを参考にもう一試してみようと思います。

    キャンセル

15分調べてもわからないことは、teratailで質問しよう!

ただいまの回答率

91.14%

関連した質問

同じタグがついた質問を見る

  • Swift

    5524questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Realm

    150questions

    RealmとはSQLiteやCore Dataに代わるモバイルデータベースです。iOSとAndroidの両方でサポートされています。