javascript - 如何使用 PHP 中动态创建的按钮更改数据库值

标签 javascript php jquery html

我正在使用 PHP 动态创建 html 内容,并且正在创建一个按钮,当单击该按钮时,它应该调用一个 PHP 脚本,该脚本将更新数据库中特定行的列的值

这是我的代码:

<?php
    session_start();

    if(!isset($_SESSION['id'])){
        header("Location: login.php");
    }else{
        require_once("mysqli_connect.php");

        $query = "SELECT * FROM markeri WHERE odobreno ='F'";

        $response = @mysqli_query($dbc,$query);

        if($response){
            echo "<hr>";
            while($row = mysqli_fetch_assoc($response)){
                echo "<div align='center' id='markeri'><h3>Naziv: " . $row['naziv'] . "</h3>";
                echo "<h3>Ulica: " . $row['ulica'] . "</h3>";
                echo "<h3>Opis:</h3>" . "<p>" . $row['opis'] . "</p>";
                echo "<h4>Email: " . $row['email'] . "</h4>";
                echo "<img src='" . $row['link_slike'] . "' width='300px' /></br>";
                echo "<form action='update.php' method='POST'>";
                echo "<textarea rows='10' cols='30' maxlength='500' placeholder='Komentar' name='" . $row['marker_id'] . "'></textarea></br>";
                echo "<input type='button' value='Odobri' name='" . $row['marker_id'] . "b" . "' /></form><hr>";
            }
        }




    }


?>

我尝试过将文本区域的名称设置为等于数据库中的marker_id,并将按钮的名称设置为marker_id + 字符串“b”的值,但我不知道如何在更新时调用它们.php 脚本。通常,当这是正常情况并且没有动态内容时,我知道如何使用 $_POST['name'];

编辑:

按照您告诉我的那样,我使用 AJAX 动态创建 HTML,但我遇到了另一个问题

<script>
    function page_loaded(){
        jQuery.ajax({
            method: "GET",
            url: "get_data_dashboard.php",
            success: function(data){
                var markers = JSON.parse(data);
                for(var i = 0; i < markers.length; i++){
                    var m = markers[i];
                    var markerHTML = "<div class='marker'>" +
                        "<span id='naziv'>Naziv zahtjeva: " + m.naziv + "</span></br>" + 
                        "<span id='ulica'>Ulica: " + m.ulica + "</span></br>" + 
                        "<p id='opis'>Opis:</br>" + m.opis + "</p></br>" + 
                        "<span id='email'>Email: " + m.email + "</span></br>" + 
                        "<img id='slika' src='" + m.link_slike + "' />" + "</br>" + 
                        "<textarea rows='5' cols='30' maxlength='500' id='t" + m.marker_id + "' placeholder='Komentar'>" + "</textarea></br>"
                        + "<div class='buttons'><a href='odobri_prijavu.php?id=" + m.marker_id + "'>Odobri</a>" +
                            "<a href='izbrisi_prijavu.php?id=" + m.marker_id + "'>Izbriši</a>"  + "</div>"  + 
                        "</div><hr>";

                    $('#content').append(markerHTML);
                }

            }
        })



    }
    $(document).ready(page_loaded());

</script>

我尝试使用按钮,但我不知道如何将事件处理程序添加到动态创建的按钮,这些按钮将通过 AJAX 将请求发送到某个 php 脚本,并使用正确的 id 作为值和文本区域的值。所以我使用了 anchor 标记,我能够发送id,但是我无法发送textarea的值,因为我不知道如何引用它,即使我引用它,它也会是NULL,因为它的值一开始就设置为 anchor 标记,我想在文本区域中输入文本。

最佳答案

试试这个

$(".btn_class_nm").click(function(){
       $.ajax({
          type: "POST",
          url: "http://domain.com/phpscript_filenm.php",
         data: {
            val1:"val1",
            val2:"val1",
         },
          success: function(msg){
             alert( "record updated"); //Anything you want
          }
       });   


 });

关于javascript - 如何使用 PHP 中动态创建的按钮更改数据库值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40855078/

相关文章:

javascript - 无法使用选择计数器和 optgroups 取消选择 'select multiple' 选项

javascript - 从没有表单的文本字段输入中获取值

javascript - 是否可以在不附加 ".js"扩展名的情况下在 Dojo 中加载脚本

php - Laravel 删除 X 记录(如果有重复项)的有效方法

php - 如何向PHP服务器发送数据?

javascript - JQuery:为什么ajax请求在beforeSend中的代码执行完成之前执行?

javascript - 我正在使用 react-admin 依赖项,但编辑不起作用

c# - 如何在 C# 中使用 Jint 加载 JavaScript 文件?

php - Excel 2003 数据中的换行符

javascript - 想要在每个 WordPress 站点页面上的 WordPress 插件中运行 jQuery 代码