2

これに約 4 時間苦労して、会社を作成するためのフォームを含むモーダル ドロップダウン (Twitter ブートストラップ モーダル) を作成しようとしています。これは CodeIgniter に組み込まれています。

input type="submit" と input type="button" に問題があります。

必須フィールドは 1 つだけです。それは会社名です。input type="button" を使用すると、検証はモーダル内で正しく実行されますが、フォームは company_id、user_id、active、および cdate とともに会社名のみを挿入します。

input type="submit" を使用すると、すべてのデータが正常に挿入されます。ただし、検証が失敗し、[会社の作成] をクリックした後に「ページが見つかりません」というメッセージが表示されますが、データはまだ挿入されています。

何か案は?ありがとう!AJAX の初心者...

私のAJAX関数:

   $(document).ready(function(){

  $('#create_btn').live('click', function(){
      //we'll want to move to page specific files later

    var name = $('#name').val();

    $.ajax({
        url: CI_ROOT + "members/proposals/add_client",
        type: 'post',
        data: {'name': name },
        complete: function(r){
          var response_obj = jQuery.parseJSON(r.responseText);

          if (response_obj.status == 'SUCCESS')
          {
              window.location = CI_ROOT + response_obj.data.redirect;
          }
          else
          {       
            $('#error_message2').html(response_obj.data.err_msg);
          }
        },
    });     


  });

});

挿入を処理する私のコントローラー関数:

    function add_client()
{

    $this->form_validation->set_rules('name', 'Company Name', 'trim|required|xss_clean');

    load_model('client_model', 'clients');
    load_model('industry_model');

    $user_id = get_user_id();
    $company_id = get_company_id();

    if (!$user_id || !$company_id) redirect('home');

    if ($_POST)
    {

        if ($this->form_validation->run() == TRUE)
        { 

        $fields = $this->input->post(null , TRUE);


        $fields['user_id'] = $user_id;
        $fields['company_id'] = $company_id;
        $fields['active'] = 1;
        $fields['cdate'] = time();


        $insert = $this->clients->insert($fields);

            if ($insert)
            {
                $this->message->set('alert alert-success', '<h4>Company has been added</h4>');
                header('location:'.$_SERVER['HTTP_REFERER']);
            }
            else
            {
                $this->message->set('alert alert-error', '<h4>There was an issue adding this Company, please try again</h4>');
            }                   


        }


        else
        {  
            $err_msg =  validation_errors('<div class="alert alert-error">', '</div>'); 
            $retval = array('err_msg'=>$err_msg);
            $this->ajax_output($retval, false);
        }

    }

    $this->data['industries'] = array(0=>'Select Industry...') + $this->industry_model->dropdown('industry');   

    $this->insertMethodJS();
    $this->template->write_view('content',$this->base_path.'/'.build_view_path(__METHOD__), $this->data);           
    $this->template->render();
}

そして最後に、私の見解:

    <div class="modal hide fade" id="milestone" tabindex="-1" role="dialog" aria-labelledby="myModalLabel" aria-hidden="true" style="width: 600px !important;">
  <div class="modal-header">
    <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
    <h3 id="myModalLabel">Add a Company</h3>
  </div>

  <div class="modal-body">

    <?php echo form_open_multipart(base_url().'members/proposals/add_client', array('class' => '', 'id' => 'client_form'));?>   

    <div id="error_message2"></div> 

    <div class="row-fluid">
        <div class="span5">

            <input type="hidden" name="cdate" id="cdate" value="" />

            <div class="control-group">
            <label class="control-label">Company Name: <span style="color: red;">*</span></label>
                <div class="controls">
                    <input type="text" id="name" name="name" value=""/>
                </div>
            </div>  

            <div class="control-group">
            <label class="control-label">Company Abbreviation:<span style="color: red;">*</span></label>
                <div class="controls">
                    <input type="text" id="abbreviation" name="abbreviation" value=""/>
                </div>
            </div>      


            <div class="control-group">
            <label class="control-label">Company Image: </label>
                <div class="controls">
                        <input type="file" name="client_image" size="20" /> 
                </div>
            </div>

            </div>  

            <div class="span5">

            <div class="control-group">
            <label class="control-label">Website:</label>
                <div class="controls">
                    <input type="text" id="website" name="website" value=""/> 
                </div>
            </div>  

       </div>

    </div>  



<div class="row-fluid">
    <div class="span5" style="margin-top: 25px;">

    <div class="control-group">
            <div class="controls">
                <p><strong>Client</strong></p>
            </div>
    </div>  


    <div class="control-group">
        <label class="control-label">Address 1:</label>
            <div class="controls">
                <input type="text" id="address1" name="address1" value=""/>
            </div>
    </div>  

    <div class="control-group">
        <label class="control-label">Address 2:</label>
            <div class="controls">
                <input type="text" id="address2" name="address2" value=""/>
            </div>
    </div>      

    <div class="control-group">
        <label class="control-label">City:</label>
            <div class="controls">
                <input type="text" name="city" id="city"  value=""/>
            </div>
    </div>  


    <div class="control-group">
        <label class="control-label">State:</label>
            <div class="controls">
                <?= form_dropdown('state', usa_state_list(), set_value('state'), 'id=state');  ?>     
            </div>
    </div>  

    <div class="control-group">
        <label class="control-label">Zip:</label>
            <div class="controls">
                <input type="text" id="zip" name="zip" value=""/>
            </div>
    </div>  

    <div class="control-group">
        <label class="control-label">Country:</label>
            <div class="controls">
                <?= form_dropdown('country', country_list(), set_value('country'), 'id=country');  ?>    
            </div>
    </div>

  </div>
</div>
</div>

  <div class="modal-footer">
    <button class="btn" data-dismiss="modal" aria-hidden="true">Close</button>
    <button type="submit" class="btn btn-primary" id="create_btn">Create Company</button>
  </div>
 </form> 
</div>

というわけで、まとめます。input type="button" を使用すると、モーダル内で検証がうまく機能し、会社名だけが company_id、user_id、active、および cdate とともにデータベースに挿入されます。

現在、input type="submit" を使用すると、すべてのデータが正しく挿入されますが、検証に失敗し、ページへのリダイレクトが見つかりません。

もう一度、ありがとう!

4

1 に答える 1

1

問題はajax関数呼び出しにあります。

フォームが起動しないようにする必要があります(したがって、実行中のURLに投稿を介して送信します)。

変化する:

$('#create_btn').live('click', function(){

に:

$('#create_btn').live('click', function(e){
    e.preventDefault();

これで問題が解決するはずです。そうでない場合は、私に知らせてください。さらに掘り下げます。また、将来にわたって利用できるように、に切り替えるliveことをお勧めします。ライブ、バインドなどと同じものを1つの関数でより効率的に処理します。onon

編集:何が起こっているのか(そしてなぜ使用しなければならないのかe.preventDefault();)を説明するために、それは実際にタグの属性<input type="submit">で指定されたURLにフォームを送信するためです。したがって、コードで起こっていることは、ボタンをクリックするとすぐにJavaScriptが実行され、その直後にネイティブブラウザーの送信イベントが発生することです。<form>action

于 2012-10-16T18:54:34.303 に答える