swift
1import UIKit 2 3class ViewController: UIViewController,UITableViewDataSource,UITableViewDelegate{ 4 5 @IBOutlet weak var mytableView: UITableView! 6 var add = UILabel() 7 let item = [""] 8 //var longPressRecognizer: UILongPressGestureRecognizer! 9 //+ボタン 10 @IBAction func addlabel(_ sender: Any) { 11 12 alert() 13 //label() 14 } 15 16 //ラベルについて 17 func label(){ 18 add = UILabel(frame: CGRect(x: 130, y:250, width: 100, height:20)) 19 //ラベルの大きさ、座標指定 20 //add.text = "labelです" 21 //文字を変更 22 23 add.backgroundColor = UIColor.lightGray 24 25 add.font = UIFont.systemFont(ofSize: 30) 26 //文字の大きさ 27 28 add.textColor = UIColor.black 29 //文字カラー 30 31 add.sizeToFit() 32 //文字数にあわせてlabelの大きさを変更(サイズが文字にフィットする) 33 34 self.view.addSubview(add) 35 //実際にviewに見える形でlabelが出現する 36 } 37 38 func alert(){ 39 // テキストフィールド付きアラート表示 40 41 let alert = UIAlertController(title: "タイトル", message: "メッセージ", preferredStyle: .alert) 42 43 // OKボタンの設定 44 let okAction = UIAlertAction(title: "OK", style: .default, handler: { 45 (action:UIAlertAction!) -> Void in 46 47 // OKを押した時入力されていたテキストを表示 48 if let textFields = alert.textFields { 49 50 // アラートに含まれるすべてのテキストフィールドを調べる 51 for textField in textFields { 52 self.label() 53 self.add.text = textField.text! 54 self.add.sizeToFit() 55 print(textField.text!) 56 } 57 } 58 }) 59 alert.addAction(okAction) 60 61 // キャンセルボタンの設定 62 let cancelAction = UIAlertAction(title: "Cancel", style: .cancel, handler: nil) 63 alert.addAction(cancelAction) 64 65 // テキストフィールドを追加 66 alert.addTextField(configurationHandler: {(textField: UITextField!) -> Void in 67 textField.placeholder = "テキスト" 68 }) 69 70 alert.view.setNeedsLayout() // シミュレータの種類によっては、これがないと警告が発生 71 72 // アラートを画面に表示 73 self.present(alert, animated: true, completion: nil) 74 75 } 76 77 func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { 78 return add 79 } 80 81 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 82 return item.count 83 } 84 85 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 86 let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) 87 let item = add 88 cell.textLabel?.text = item[indexPath.row] 89 return cell 90 } 91 92 93 override func viewDidLoad() { 94 super.viewDidLoad() 95 96 } 97 98 override func didReceiveMemoryWarning() { 99 super.didReceiveMemoryWarning() 100 // Dispose of any resources that can be recreated. 101 } 102 103 104}
やりたいこと
labelをコード上から表示させることはできるようになったので今度はtableViewにコード上からlabelをtableViewに挿入できるようになりたい。
困っていること
cellForRowAtの中のコードの書き方がtableViewにただ文字を挿入する方法は分かるのですがlabelをtableViewに追加する方法を分からなくて困っています。
あと引数はこの三つだけいいのかも分からなくて困っています。
swift
1 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 2 let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) 3 let name = add 4 cell.textLabel?.text = name[indexPath.row] 5 return cell 6 } 7 } 8
初心者なので具体的なコードを教えて頂きたいです。
cell.textLabel?.text = name[indexPath.row]←ようにすると以下のエラーがおきます。
type 'UILabel' has no subscript members
回答3件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
退会済みユーザー
2018/03/13 01:57
退会済みユーザー
2018/03/13 06:33
2018/03/13 08:12
退会済みユーザー
2018/03/13 11:35