繁体   English   中英

在Javascript警报框中的新行上显示PHP数组的每个条目

[英]Displaying each entry of PHP array on a new line in Javascript alert box

我有一个简单的查询,可以从数据库中选择一些信息:

  $dep_qry = "select product_name, sum(theoretical_stock_level) as opening_stock, sum(quantity_scanned) as closing_stock, department_description, stock_item_code, custom_1 AS size, IFNULL(unit_cost_price, 0.00) AS cost_price from stocktake_products where stocktake_id = '{$stocktake_id}' AND is_deli = 0 
                         group by product_name, department_description
                         order by department_description ASC;";

    $dep_res = db::c()->query($dep_qry);

然后,我有以下代码将成本价为0.00的产品放入数组中。 然后,我检查数组中元素的数量。 如果数组中包含一些信息,我想向用户显示一个警报,告诉用户哪些商品的成本价为0。以下代码有效,但是我想知道是否有可能在数组上显示每个条目。警报框中的单独一行? 只是为了使其更加用户友好。

while ($row1 = $dep_res->fetch(PDO::FETCH_ASSOC))
    {
        $cost_price = number_format($row1['cost_price'],2);
        $pname = $row1['product_name'];
        if ($cost_price == 0.00)
        {
            $products[$i] = $pname;
        }
        $i++;
    }

    $numOfNoCosts = count($products);
    if ($numOfNoCosts > 0)
    {
        echo "<script> alert('".json_encode($products)."') </script>";
    }

如果有更好的方法,我很乐意接受建议!

尝试这样在每一行显示类似数组的值

alert(arrayname.join("\n"));

尝试将其显示为数组:

alert(JSON.stringify(your_array));

首先准备一个带有php数组值的js变量。 像这样

<script type="text/javascript">
    var obj = <?php echo json_encode($Your_array); ?>;
</script>

下面是一个完整的经过测试的示例

<?php $phpArray = array(
          0 => "Mon", 
          1 => "Tue",  
          2 => "Wed", 
          3 => "Thu",
          4 => "Fri", 
          5 => "Sat",
          6 => "Sun",

    )
?>


<script type="text/javascript">

    var jArray= <?php echo json_encode($phpArray ); ?>;

   alert(jArray.join("\n"));

 </script>

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM