javascript - 根据选定的下拉值填充文本字段

标签 javascript php html json

我有以下 PHP 代码,它将查询结果(只是产品名称及其相应单价的映射)输出到 JSON 文件。 PHP 代码还填充下拉列表。

我在创建 JSON 文件和填充下拉列表时没有任何问题。我主要关心的是:

当用户从下拉列表中选择产品名称时,如何自动填充另一个文本字段以显示产品相应的单价?

<label for="p_name">Product Name</label>
<div class="input-group">
  <div class="input-group-btn">
    <input type="text" class="form-control" name="p_name" id="p_name" style="width: 300px;" required>
    <button type="button" class="btn btn-default dropdown-toggle" data-toggle="dropdown"> <span class="caret"></span></button>
    <ul class="dropdown-menu" role="menu" style="width: 300px;">
        <?php
            $connstring = pg_connect("host=localhost dbname=myDB user=postgres password=password")
            or die('Could not connect: ' . pg_last_error());
            $select = "SELECT p_name, unit_price FROM Product";
            $executeSelect = pg_query($select) or die('Postgresql: ' . pg_last_error());

            $result = array();

            while ($line = pg_fetch_array($executeSelect, null, PGSQL_ASSOC)) {

                $index = 0;
                foreach ($line as $col_value) {
                    if ($index % 2 == 0)
                    {
                        //Display Product Name in the drop down list
                        echo "<li><a>$col_value</a></li>";
                        $index++;
                    }
                    else
                    {
                        $index++;   
                    }


                }   
                //Store query output to the result array
                $result[] = $line;

            }

            //Save the query output to a JSON file
            file_put_contents('C:\Apache\htdocs\productList.json', json_encode($result), LOCK_EX);


            pg_free_result($executeSelect);
            pg_close($connstring);                                                              
        ?>
    </ul>
  </div><!-- /btn-group -->
</div><!-- /input-group -->     


<label for="unit_price">Unit Price</label>
<input type="number" class="form-control" name="unit_price" id="unit_price"></input>

最佳答案

使用Javascript显示产品对应的单价。

用于在服务器上加载 JSON 文件的 JQuery。

$.getJSON('products.json', function(data) {
    // process the data
});

有关 $.getJSON() 的更多信息,请查看 this link

提示:最好在文档的 onReady() 事件中加载整个 JSON 文件并填充“产品名称”下拉框。 根据我的经验,使用 PHP 并不是一个好的设计选择。

关于javascript - 根据选定的下拉值填充文本字段,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36231554/

相关文章:

javascript - 如何使用react-redux将ReactJS组件正确连接到Redux?

javascript - 如何在 JavaScript 中用数字填充表格?

php - 无法在 Chrome 或 Firefox 中下载生成的 .ics 文件

php - Joomla 时区与 MySQL 时区不同

html - 如何做好hr设计师

javascript - 当我将脚本元素放在头部以从 URL 加载它时,我的 Javascript 不起作用

javascript - 创建 jQuery 元素后访问 JSON 数据

php - ajaxSubmitButton 在 Linux 服务器上不起作用

php - 使用 php mysql 选择一个未知的数据库表

html - 如何在另一个模糊图像上添加图像