###前提・実現したいこと
todolistをネットからコピーしたらエラーが出ました
###エラーメッセージ
49行・・・Value of type 'String' has no member 'stringByTrimmingCharactersInSet' 57行・・・Argument labels '(forRow:, inSection:)' do not match any available overloads 94行・・・Method does not override any method from its superclass 107行・・・Method does not override any method from its superclass 114行・・・Method does not override any method from its superclass
###該当のソースコード
swift
1import UIKit 2 3class TableViewController: UITableViewController { 4 5 // ToDoを格納した配列 6 var todoList = [String]() 7 8 9 override func viewDidLoad() { 10 super.viewDidLoad() 11 12 //-------------------- 13 // 読み込み処理を追加 14 //-------------------- 15 let userDefaults = UserDefaults.standard 16 if let storedtodoList = userDefaults.array(forKey: "todoList") as? [String] { 17 todoList.append(contentsOf: storedtodoList) 18 } 19 } 20 21 override func didReceiveMemoryWarning() { 22 super.didReceiveMemoryWarning() 23 } 24 25 /** 26 * +ボタンが押された際の処理 27 */ 28 @IBAction func tapAddButton(sender: AnyObject) { 29 // アラートダイアログ生成 30 let alertController = UIAlertController(title: "ToDoを追加", 31 message: "ToDoを入力してください", 32 preferredStyle: UIAlertControllerStyle.alert) 33 // テキストエリアを追加 34 alertController.addTextField(configurationHandler: nil) 35 // OKボタンを追加 36 let okAction = UIAlertAction(title: "OK", style: UIAlertActionStyle.default) { 37 (action: UIAlertAction) -> Void in 38 // OKボタンが押されたときの処理 39 if let textField = alertController.textFields?.first { 40 // 前後の空白文字を削除する要素を追加 4149 textField.text = textField.text!.stringByTrimmingCharactersInSet(NSCharacterSet.whitespaceCharacterSet()) 42 // 空白文字かどうかを確認する処理 43 if textField.text != "" { 44 // todoListの配列に入力した値を先頭に挿入 45 self.todoList.insert(textField.text!, at: 0) 46 47 // テーブルに行が追加されたことをデーブルに通知 48 self.tableView.insertRowsAtIndexPaths( 4957 [NSIndexPath(forRow: 0, inSection: 0)], 50 withRowAnimation: UITableViewRowAnimation.Right) 51 52 //-------------------- 53 // 保存処理を追加 54 //-------------------- 55 let userDefaults = UserDefaults.standard 56 userDefaults.set(self.todoList, forKey: "todoList") 57 userDefaults.synchronize() 58 } 59 } 60 } 61 // OKボタンを追加 62 alertController.addAction(okAction) 63 64 // キャンセルボタンがタップされたときの処理 65 let cancelAction = UIAlertAction(title: "キャンセル", 66 style: UIAlertActionStyle.cancel, 67 handler: nil) 68 // キャンセルボタンを追加 69 alertController.addAction(cancelAction) 70 71 // アラートダイアログを表示 72 present(alertController, animated: true, completion: nil) 73 } 74 75 /** 76 * テーブルの行数を返却する 77 */ 7894 override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 79 // todoListの配列の長さを返却する 80 return todoList.count 81 } 82 83 /** 84 * テーブルの行ごとのセルを返却する 85 */ 86 override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { 87 // storyboardで指定したtodoCell識別子を利用して再利用可能なセルを取得する 88 let cell = tableView.dequeueReusableCell(withIdentifier: "todoCell", for: indexPath as IndexPath) 89 // 行番号に合ったToDoを取得 90 let todoTitle = todoList[indexPath.row] 91 // セルのラベルにToDoをセット 92 cell.textLabel!.text = todoTitle 93 return cell 94 } 95 96 /** 97 * セルが編集可能かどうかの判定処理 98 */ 99107 override func tableView(tableView: UITableView, canEditRowAtIndexPath indexPath: NSIndexPath) -> Bool { 100 return true 101 } 102 103 /** 104 * セルを削除した際の処理 105 */ 106114 override func tableView(tableView: UITableView, 107 commitEditingStyle editingStyle: UITableViewCellEditingStyle, 108 forRowAtIndexPath indexPath: NSIndexPath) { 109 // 削除可能かどうか 110 if editingStyle == .delete { 111 // ToDoリストから削除 112 todoList.remove(at: indexPath.row) 113 // セルを削除 114 tableView.deleteRows(at: [indexPath as IndexPath], with: .fade) 115 //-------------------- 116 // 保存処理を追加 117 //-------------------- 118 let userDefaults = UserDefaults.standard 119 userDefaults.set(self.todoList, forKey: "todoList") 120 userDefaults.synchronize() 121 } 122 } 123 124}
###最後に
swift初心者です
分からないことがあれば質問してください
よろしくお願いします
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。