0

我已经为此工作了一段时间,并在这里找到了许多关于 SO 的线索,但还没有任何工作。我正在尝试以用户可以通过选择“添加新”选项添加的形式创建一个动态下拉列表,该选项会打开一个模式窗口,可以在其中键入新选项。我使用 jquery 来打开窗口并捕获输入和 ajax 以(希望)发布文本并在 php 中检索它。我在控制台上看到新选项是在 javascript 中捕获的,并且 ajax 会发布一个帖子,但帖子数组是空的。

我的代码都在视图中。When an "add new" is selected a modal window pops up in which text can be entered. 我想在视图中捕获输入的文本而不提交并将其显示在更新的选项列表中。

                  <legend>Animal Info</legend>

                    <div class="control-group <?php if (form_error('animal_species')) { echo 'error'; } ?>">
                        <label class="control-label">Species</label>            
                        <div class="controls">

                            <?php                                                   # Add "Add New"
                            $options = $species + array('addnew' => 'Add New'); 
                            echo form_dropdown('animal_species', $options,
                                                set_value('animal_species', (isset($my_data->animal_species)) ? $my_data->animal_species: ''),
                                                'id = "animal_species"',
                                                'class', 'addnew');
                            echo form_error('animal_species', '<span class="help-inline">', '</span>');                                
                            ?> 

                        </div>
                    </div>                            
              <?php


                  if(isset($new_option))
                  {
                    $new_option = $_POST['new_option'];
                    $species = array($new_option => $new_option) + $species;
                    var_dump($new_option);
                  }

             ?>

  <script type="text/javascript">

      $('#upload_form option[value="addnew"]').click(function(){

          // Show modal window
          $('#add-new').modal('show');

          $('#add-new-submit').on('click', function(){

              // Get new option from text field
              var new_option = $('#add-new-text').val();
              console.log(new_option);

              $.ajax({
                    type: "POST",
                    url: "<?php echo site_url(); ?>main/upload_page",
                    data: {new_option:'new_option'}
                  }).fail(function (jqXHR, textStatus, errorThrown){
                        console.error("The following error occured: " + textStatus, errorThrown);
                  });

              $('#add-new').modal('toggle');                              

           });

      //}); 
      });                 

  </script>

  <!-- add-new field -->
  <div class="modal small hide fade" id="add-new" tabindex="-1" role="dialog" aria-labelledby="add-new-fieldLabel" aria-hidden="true">
      <div class="modal-header">
        <button type="button" class="close" data-dismiss="modal" aria-hidden="true">×</button>
        <h3 id="add-new-fieldLabel">Add New Field</h3>
      </div>
      <div class="modal-body">

          <p>Would you like to add a new item?</p>
          <input type="text" id="add-new-text" name="add-new" placeholder="Type the new option">

      </div>

      <div class="modal-footer">
        <button type="button" class="btn btn-success" id="add-new-submit" name="add-new-submit"/>Add</button>
      </div>

 </div><!-- /add-new field -->

现在字符串 new_options 在控制台中被捕获,但在 php 中为 NULL,所以 ajax 出于某种原因没有发布。这是因为我正在尝试更新同一页面吗?

4

2 回答 2

1

将其更改为:

$.ajax({
    type: "POST",                       
    url: "<?php echo site_url(); ?>main/upload_page",
    dataType: 'text',
    data: {new_option : 'new_option'}
}).fail(function (jqXHR, textStatus, errorThrown){
    console.error("The following error occured: " + textStatus, errorThrown);
});

如果您将能够通过以下方式访问它:

$_POST['new_option'];

在 PHP 中。
没有键,就只是$new_option = $_POST;获取字符串

于 2013-07-01T20:42:35.643 回答
0

因为您将发布的值作为..您$_POST['new_option']需要在 ajax 中将数据对象作为 new_option 传递...

尝试这个

...
$.ajax({
         type: "POST",                       
         url: "<?php echo site_url(); ?>main/upload_page",
         dataType: 'text',
         data:{'new_option':new_option},  //<---here                         
       });
       console.log(new_option);


.....
于 2013-07-01T20:42:59.243 回答