1

这是我第一次尝试使用 Ajax 和 PHP 从 MySQL 中删除一行。我收到错误:

PHP 致命错误:在第 10 行的 /home/insightd/public_html/dev/wp-content/plugins/id-ffui/lib/delete.php 中的非对象上调用成员函数 delete()

一切正常,但该行没有删除。

HTML 表单的删除部分:

  echo "<div class='ffui-media-item'>";
  echo "<div class='ffui-delete' align='center'><a href='#' id='" . $media_item['ID'] . "' class='delbutton' title='Click To Delete'>X</a></div>";

jQuery/Ajax 部分:

<script type="text/javascript">
  $(function() {
   $(".delbutton").click(function(){
    //Save the link in a variable called element
    var element = $(this);

    //Find the id of the link that was clicked
    var del_id = element.attr('id');

    //Built a url to send
    var info = {"id" : del_id };
      if(confirm("Are you sure you want to delete this Record?")) {
        $.ajax({
          type: "POST",
          url: "<?php echo plugins_url('id-ffui/lib/delete.php') ?>",
          data: info,
          success: function(){   
          }
        });
        $(this).parents(".ffui-media-item").animate({ backgroundColor: "#fbc7c7" }, "fast")
          .animate({ opacity: "hide" }, "slow");
      }
    return false;
  });
});
</script>

和 delete.php 文件:

global $wpdb;
global $ffui_db_version;

$ffui_items = $wpdb->prefix . "ffui_items";

if($_POST['id']) {
  $id = $_POST['id'];
    $wpdb->delete( $ffui_items, array( 'ID' => `$id` ) );
}

任何帮助将不胜感激。提前致谢。

4

2 回答 2

2

不正确的反引号:

$wpdb->delete( $ffui_items, array( 'ID' => `$id` ) );
                                           ^---^--

PHP 在其代码中不使用反引号。应该只是'ID' => $id

至于实际的错误消息,您似乎没有包含 wordpress 库,因此$wpdb实际上并不存在。

于 2013-10-21T17:03:59.963 回答
2

如果您显示的代码是整个 delete.php,则 $wpdb 尚未实例化。您需要先加载核心 WP 文件:

require_once( dirname( dirname( dirname( dirname( __FILE__ )))) . '/wp-load.php' );

您的其余代码在此之后。如果是这种情况,则不需要“全局”命令,因为您不是在函数或对象内部进行操作。

这是 wp-load.php的一个很好的解释:

于 2013-10-21T17:10:21.640 回答