したがって、「 selfView 」というアクションを持つユーザーコントローラーがあります。これは次のようになります。(users_controller.php)
function selfView() {
$user = $this->User->find('first', array('conditions' => array('User.id' => $this->Auth->user('id'))));
$formms = $this->Form->find('all', array('fields' => array('Form.id', 'Form.name'), 'recursive' => -1));
$this->set(compact('user', 'formms'));
$this->render('view');
}
これにより、1つのフォームを持つプロファイルページがレンダリングされます。これはページにレンダリングされる最初のフォームであり、期待どおりに正常に機能します。
コードスニペットを表示:(users / view.ctp)
<div id="passwordChange">
<?php echo $form->create('User', array( 'action' =>'updatePass' ));?>
<fieldset>
<legend><?php __('Change Password');?></legend>
<?php
$options = array('type'=>'password', 'div' => array('class' => 'required'));
echo $form->input(__('old_password', true), $options);
$options = array('div' => array('class' => 'required'), 'error' => array('confirmPassword' => __('Passwords do not match please try again',true), 'noempty' => __('Please provide a password',true)));
echo $form->input(__('password', true), $options);
$options = array('type'=>'password', 'div' => array('class' => 'required'));
echo $form->input(__('confirmation_password', true), $options);
echo $form->hidden('User.id', array('value' => $user['User']['id']));
?>
</fieldset>
<?php echo $ajax->submit(__('Change Password', true), array('url' => array('controller' => 'users', 'action' => 'updatePass'),
'update' => 'storage',
'complete' => '$("#UserUpdatePassForm input[type=password]").val(""); '));
$form->end();?>
<a href="#">Cancel</a>
</div>
「users/view.ctp 」から生成されるHTML:
<form action="/high-school-app/users/updatePass" method="post" id="UserUpdatePassForm">
<fieldset style="display: none;">
<input type="hidden" value="POST" name="_method">
</fieldset>
<fieldset>
<legend>Change Password</legend>
<div class="required">
<label for="UserOldPassword">Old Password</label>
<input type="password" id="UserOldPassword" value="" name="data[User][old_password]">
</div>
<div class="required required">
<label for="UserPassword">Password</label>
<input type="password" id="UserPassword" value="" name="data[User][password]">
</div><div class="required required">
<label for="UserConfirmationPassword">Confirmation Password</label>
<input type="password" id="UserConfirmationPassword" value="" name="data[User][confirmation_password]">
</div>
<input type="hidden" id="UserId" value="" name="data[User][id]">
</fieldset>
<div class="submit">
<input type="submit" onclick="return false;" id="submit2026598409" value="Change Password" update="storage">
</div>
<script type="text/javascript">
//<![CDATA[
jQuery('#submit2026598409').click( function() { jQuery('#submit2026598409').parents('form').ajaxSubmit({beforeSend:function(request) {request.setRequestHeader('X-Update', 'storage');}, complete:function(request, textStatus) {$("#UserUpdatePassForm input[type=password]").val(""); }, success:function(data, textStatus) {jQuery('#storage').html(data);}, async:true, type:'post', url:'/high-school-app/users/updatePass'}); return false;});
//]]>
</script>
<a href="#">Cancel</a>
</form>
次に、フォームをレンダリングする要素を呼び出します。(users / view.ctp)
echo $this->element('my_apps' , array('applications' => $applications));
そして、これはすべてがうまくいかないところです。何をしようとしても、この2番目のフォームを正しく印刷することはできません。フォームの中央部分が印刷されますが、開始タグと終了タグは印刷されません。それらがなければ、フォームは私には役に立たない。この時点で、私は本当にそれを手で書きたくありません。
これは、form(elements / my_apps.ctp)を出力するために使用しようとしている要素のコードです。
<?php echo $form->create('Applications', array( 'url' => array('controller' => 'applications', 'action' => 'assign', 'id' => null))); ?>
<fieldset>
<legend><?php __('Assign Application to User');?></legend>
<?php
$options = array('--' => __('Select One',true), 'test' => 'test', 'test2' => 'test2');
echo $form->label('Application.form_id', __('Form Name',true).":");
echo $form->select('Application.form_id', $options, $selected = '--');
echo $form->hidden('Application.user_id', array('value' => $user['User']['id']));
?>
</fieldset>
<?php echo $form->end(__('Assign', true));?>
これは、「elements/my_apps.ctp」が出力するものです。
<fieldset style="display: none;">
<input type="hidden" value="POST" name="_method">
</fieldset>
<fieldset>
<legend>Assign Application to User</legend>
<label for="ApplicationFormId">Form Name:</label>
<select id="ApplicationFormId" name="data[Application][form_id]">
<option value=""></option>
<option selected="selected" value="--">Select One</option>
<option value="test">test</option>
<option value="test2">test2</option>
</select>
<input type="hidden" id="ApplicationUserId" value="" name="data[Application][user_id]">
</fieldset>
<div class="submit">
<input type="submit" value="Assign">
</div>
次のような開始タグと終了タグは印刷されません。
<form action="/high-school-app/applications/assign" method="post" id="ApplicationAssignForm">
.....
.....
</form>
何か案は?デバッグするために私がやるべきことは役に立ちます。
アップデート:
私は手でコードを書き込もうとしましたが、それでも削除されています。ある種の後処理は行われていますか?それは私のフォームタグを削除する責任がありますか?