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

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

新規登録して質問してみよう
ただいま回答率
85.48%
CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

Q&A

解決済

1回答

7596閲覧

cakephp3のformhelperをカスタマイズしたい

退会済みユーザー

退会済みユーザー

総合スコア0

CakePHP

CakePHPは、PHPで書かれたWebアプリケーション開発用のフレームワークです。 Ruby on Railsの考え方を多く取り入れており、Railsの高速性とPHPの機動性を兼ね備えています。 MVCやORMなどを「規約優先の考え方」で利用するため、コードを書く手間を省くことができます。 外部のライブラリに依存しないので、単体での利用が可能です。

0グッド

0クリップ

投稿2016/01/29 00:24

cakephp3のformhelperについて質問です。
mysqlにusers tableをつくりcakephp3のbakeコマンドで
以下のようなformを作りました。(1部転載)

cakephp3 <?= $this->Form->create($user) ?> <fieldset> <legend><?= __('Add User') ?></legend> <?php echo $this->Form->input('address'); ?> </fieldset> <?= $this->Form->button(__('Submit')) ?> <?= $this->Form->end() ?>

このformをカスタマイズして要素を見た時に以下のような感じにしたいと思っております。

html

1 <div class="form-group"> 2 <label class="col-sm-3 control-label" >郵便番号<span class="label label-danger">必須</span></label> 3 <div class="col-sm-9"> 4 <input name="username" required="required” id="username" type="text"> 5 <p class="help-block" style="font-size:10px;">※数字7ケタ、ハイフンなし</p> 6 </div> 7</div>

自分なりに調べてみて以下のコードまでたどり着きましたが、なかなか思い通りに行きません。

cakephp3 <?= $this->Form->create($user) ?> <legend><?= __('Add User') ?></legend> <?php $this->Form->templates([ 'inputContainer' => '<div class="col-sm-9">{{content}}</div>', ]); ?> <div class="form-control"> <?php echo $this->Form->label('郵便番号'); ?> <?php echo $this->Form->input('address',['label' => false, 'class' => 'form-control']) ?> </div>

因みに上記の要素はこんな感じです

html

1<div class="form-control"> 2 <label for="address">郵便番号</label> 3 <div class="col-sm-9"> 4 <input name="address" class="form-control" required="required" maxlength="7" id="address" type="text"></div> 5 </div> 6</div>

アドバイスお願い致します。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

ご希望の表示をCSSで実現できますが、どうでしょうか。
ヘルパーをカスタマイズするよりも簡単にできます。

CSS

1.form-control:after { 2 content: "※数字7ケタ、ハイフンなし"; 3 color: #ff0000; 4 font-size: 10px; 5} 6.form-control label:after { 7 content: "必須"; 8 color: #ff0000; 9 font-size: 10px; 10}

追記

ヘルパーのカスタマイズはこのような感じです。

PHP

1<?php 2$this->Form->templates([ 3 'inputContainer' => '<div class="col-sm-9">{{content}}</div><p class="help-block" style="font-size:10px;">※数字7ケタ、ハイフンなし</p>', 4]); 5?> 6<div class="form-control"> 7<?php echo $this->Form->label('郵便番号', '郵便番号<span class="label label-danger">必須</span>', ['class' => 'col-sm-3 control-label', 'escape'=>false]); ?> 8<?php echo $this->Form->input('address',['label' => false, 'class' => 'form-control']) ?> 9</div> 10?>

投稿2016/01/31 08:31

編集2016/02/08 15:46
coba-coba

総合スコア1409

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

coba-coba

2016/02/08 15:46

問題が解決していないようなので、ヘルパーのカスタマイズ方法を追記しました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問