- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我使用选择从不同的产品中进行选择,然后使用该值执行数据库查询咨询以获取产品的价格,然后用它设置输入标签。
<section id="products">
quantity: <input type="number" id="quantity"><br><br>
<section id="selectProd">
<?php
$query = $conn->query("SELECT name FROM Products ORDER BY name");
?>
Product: <select id="comProduct" class="comProduct">
<?php while ($option = $query->fetch_object()) { ?>
<option><?php echo $option->name; ?></option>
<?php } ?>
</select>
<script>
$(document).on("ready",function(){
$("#comProduct").on("click", function(){
var value = $("#comProduct option:selected").text();
<?php
$servername = "localhost";
$username = "root";
$password = "";
$database = "BERAKA";
$conn = new mysqli($servername, $username, $password, $database);
if ($conn->connect_error) {
die("Connection failed: " . $conn->connect_error);
}
$valuephp = $_GET['value'];
$query = $conn->query("SELECT price FROM products where name='$valorphp'");
?>
document.getElementById("ppu").value = "<?php $query->fetch_object(); ?>";
});
});
</script>
</section> <br>
Price per unit: <input type="text" id="ppu" >
</section>
不知道为什么不起作用,请帮忙
最佳答案
您很容易受到 sql injection attacks 的攻击。坐下来放松一下 - 当您的服务器获得 pwn3d 时,您的问题将变得毫无意义。
此外,您的代码也存在很大缺陷:
document.getElementById("ppu").value = "<?php $query->fetch_object(); ?>";
您的 fetch 调用不会做任何有用的事情。 fetch 将返回一个对象,但由于您不捕获该对象或以任何方式输出它,因此数据库行数据将简单地丢失。即使 fetch 调用确实奇迹般地进行了输出,您也不能将 PHP 对象转储到 Javascsript 代码上下文中。
你需要更多类似这样的东西:
<?php
...
$row = $query->fetch_object();
$price = $row->price;
?>
document.getElementById('ppu').value = <?php echo json_encode($price); ?>;
在不使用 json_encode()
的情况下,永远不要永远将文本从 PHP 直接转储到 JS 上下文中。您面临着将无效文本转储到 JS 代码块中的风险,这将触发 JS 语法错误,并杀死整个 <script>
阻止该错误代码所在。始终使用 json_encode(),这样无论您将什么内容转储到 JS 代码中,该值都将是有效的 javascript。
关于javascript - 从select中获取值(value)并与DB比较以获得价格,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26998186/
这个问题在这里已经有了答案: final keyword in method parameters [duplicate] (9 个回答) 关闭 8 年前。 在此示例中,声明 Object fina
我的目标:是通过我的函数更新字段获取选定值并使用函数输出值运行它。 问题:当我从列表中选择值时,它不会触发函数,也不会更新字段。 感谢您的帮助。 HTML 12 14 16 18 20 22 24
我有一本具有这种形式的字典: myDict = {'foo': bar, 'foobar baz': qux} 现在,我想拆分字典键中的空格,使其成为下一个键并获取值(重复)。 myDictRev1
vector a; vector b; int temp_holder; cout > temp_holder) a.push_back(temp_holder); cout > temp_h
Java 的开发过程中免不了与 Date 类型纠缠,准备总结一下项目经常使用的日期相关操作,JDK 版本 1.7,如果能够帮助大家节约那么几分钟起身活动一下,去泡杯咖啡,便是极好的,嘿嘿。当然,我
我正在使用 jquery ui 日期选择器来获取 fromDate 和 toDate 以下是from日期的代码 $("#from_date").datepicker({
我是一名优秀的程序员,十分优秀!