duanlidi1051 2011-10-31 00:46
浏览 31
已采纳

用php数组提交

My objective with this code is when an user click in edit button, is sent this all=<?php echo $arr; ?> to the page edit.php .

This code simply does nothing (no ajax call in firebug).

<?php 
$arr = array("one", "two", "three")
?>
    <div id="content">
    <input class="edit" type="submit" value="Edit" /> 
    </div>

    <script type="text/javascript">
    $(document).ready(function () {
        $(".edit").submit(function () {
            $.ajax({
                url: "edit.php",
                type: "post",
                dataType: "html",
                data: "<?php echo json_encode( $arr ); ?>",
                success: function (data) {
                    $('#ad').html(data);
                }
            });
        });
    });

    </script>
  • 写回答

6条回答 默认 最新

  • dongren4758 2011-10-31 00:54
    关注

    Edit As @MilanJaric showed, you do need to operate on the click of the submit button. In addition, however, you should prevent the default action of the click as well. End Edit

    You need to echo the data json_encoded and wrapped in quotes:

    <div id="content">
      <input class="edit" type="submit" value="Edit" /> 
    </div>
    
    <script type="text/javascript">
      $( function()
      {
        $( '.edit' ).click( function( e )
        {
          $.ajax( {
            url: 'edit.php;,
            type: 'post',
            dataType: 'html',
            data: '<?php echo json_encode( $arr ); ?>',
            /* It's hard to tell based on your code, but if you wanted a var at the server named "all" use this instead of the above line:
            data: {
              all: '<?php echo json_encode( $arr ); ?>'
            },
            */
            success: function( data )
            {
              $( '#ad' ).html( data );
            }
          } );
    
          e.preventDefault();
        } );
      } );
    </script>
    

    IMO, however, it gets real ugly to echo PHP inside your JS especially if you have to do a lot of it, so when the need arises, I use an IIFE to inject PHP data into the code as a JS var. This allows me to isolate all PHP echoing within the parens of the invocation of the IIFE:

    <?php 
      $arr = array("one", "two", "three")
    ?>
    
    <div id="content">
      <input class="edit" type="submit" value="Edit" /> 
    </div>
    
    <script type="text/javascript">
      ( function( arr )
      {
        $( function()
        {
          $( '.edit' ).click( function( e )
          {
            $.ajax( {
              url: 'edit.php;,
              type: 'post',
              dataType: 'html',
              data: arr,
              /* It's hard to tell based on your code, but if you wanted a var at the server named "all" use this instead of the above line:
              data: {
                all: arr
              },
              */
              success: function( data )
              {
                $( '#ad' ).html( data );
              }
            } );
    
            e.preventDefault();
          } );
        } );
      }(
        '<?php echo json_encode( $arr ); ?>'
      ) );
    </script>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制
  • ¥20 usb设备兼容性问题
  • ¥15 错误(10048): “调用exui内部功能”库命令的参数“参数4”不能接受空数据。怎么解决啊
  • ¥15 安装svn网络有问题怎么办