从ajax调用时,HTML不显示在div中

时间:2017-01-19 11:45:54

标签: javascript php jquery ajax

这是我正在使用的ajax脚本

mypage.php 

$(".sales_anchor").click(function(e)
{
    e.preventDefault();
    var store_username = $("#storeUsername").val(); 
    var store_id = $("#storeID").val();
    var sale_id = $(this).attr('id');
    $.ajax(
    {
        url: 'scripts/sales_sales_products.php',
        data: {"store_id": store_id, "sale_id": sale_id,"store_username": store_username},
        method: 'POST',
        success: function(data)
        {
            data = $(data).find("div#mainContentOfSale");
            $("#contents").html(data);
            console.log(data);
        }
    });
})
<div id="contents"></div>

并且

sales_sales_products.php

include_once '../includes/custom_functions.php';

$stmtgetallsales = $mysqli->prepare("SELECT * FROM store_sales ss 
    INNER JOIN store s ON s.store_id=ss.store_id 
    WHERE s.store_id=?");
$stmtgetallsales->bind_param("i",$_POST['store_id']);
$stmtgetallsales->execute();
$getallsales = $stmtgetallsales->get_result();
$sales_rows = $getallsales->num_rows;
$stmtgetallsales->close();
?>
    <script src="js/3.1.1/jquery.min.js"></script>
<script src="../js/jquery.countdown.min.js"></script>
<div class="container" id="mainContentOfSale">

                <?php while($allsales = $getallsales->fetch_assoc())
                {
                  $stmtgetsaleproducts = $mysqli->prepare("SELECT * FROM store_products sp
                    INNER JOIN store_sale_products ssp ON sp.product_id = ssp.product_id 
                    WHERE ssp.sale_id=? AND sp.store_id=?");
                  $stmtgetsaleproducts->bind_param("ii",$allsales['sale_id'],$_POST['store_id']);
                  $stmtgetsaleproducts->execute();
                  $getsaleproducts = $stmtgetsaleproducts->get_result();
                  $sale_product_rows = $getsaleproducts->num_rows;
                  $stmtgetsaleproducts->close();

                ?>
                  <script>
                    $(document).ready(function() {

                      $('.products_title').hide();
                      $(".timer").each(function() {
                        var time = this.id;
                        var timeLeft = time.split('-').reverse().join('-');
                        $(this).countdown(timeLeft, function(event) {
                          $(this).text(event.strftime("%D days %H hours %M minutes %S seconds remaining"));
                        });
                      })
                    });

                  </script>
                  <div class="sale_title">
                    <h2 class="title" id="sale_products"><?php echo $allsales['sale_name']; ?></h2> <span class="badge"><?php echo $sale_product_rows; ?></span> <span class="timer" id="<?php echo $allsales['sale_till']; ?>"></span></div>

                  <div class="sale_title"><span class="discount">Discount: <span class="color-text"><?php echo $allsales['sale_discount']; ?></span>%</span></div>
                  <div class="product_area wrapper ">
                    <?php while($saleproducts = $getsaleproducts->fetch_assoc()){?>

                      <div class="product">
                        <a href="<?php echo " index.php?store=".$_POST['store_username']." &view=single&product=".$saleproducts['product_id']; ?>">
                          <div class="product-image">
                            <img src="<?php echo image_check($saleproducts['product_image1']); ?>" />
                          </div>
                        </a>
                        <div class="product-details">
                          <div class="product-name">
                            <a class="name" href="<?php echo " index.php?store=".$_POST['store_username']." &view=single&product=".$saleproducts['product_id']; ?>"><span><?php echo substr($saleproducts['product_name'], 0, 20); ?></span></a>
                          </div>
                          <div class="product-price">
                            <span class="price">@ Rs. <?php echo sale_price($allsales['sale_discount'],$saleproducts['product_price']); ?>/</span>
                          </div>
                        </div>
                      </div>

                      <?php }?>

                    <?php } ?>

当我使用类sales_anchor调用锚标记时,它调用此脚本并在inspect元素和网络选项卡中检查脚本时它确实填充了数据和html,一切都很好。但它并没有在当前页面和contents div中调用。我做错了什么?

response

1 个答案:

答案 0 :(得分:0)

您在屏幕截图中遇到JSON.parse错误。 (注意结果窗口上方的红色条说SyntaxError: JSON.parse: unexpected character at line 1 column 9 of the JSON data

这是因为$ .ajax正在尝试将响应解析为对象的JSON字符串(默认行为)。

请将您的ajax功能更改为:

$(".sales_anchor").click(function(e)
{
    e.preventDefault();
    var store_username = $("#storeUsername").val(); 
    var store_id = $("#storeID").val();
    var sale_id = $(this).attr('id');
    $.ajax(
    {
        url: 'scripts/sales_sales_products.php',
        dataType: "text",
        data: {"store_id": store_id, "sale_id": sale_id,"store_username": store_username},
        method: 'POST',
        success: function(data)
        {
            data = $(data).find("div#mainContentOfSale");
            $("#contents").html(data);
            console.log(data);
        }
    });
})
<div id="contents"></div>