javascript - 不是将 MySQL 数据从表格显示到 HTML 表格中,而是将其显示在可编辑的文本框上

标签 javascript php html css contenteditable

我已经设法将数据从我的数据库表导入到 HTML 表中,但是,我想将它们放在锁定的文本框中,当按下“编辑”按钮时,相应的文本框将被解锁,可以在 MySQL 表中更改和更新数据吗?我该怎么做?

我研究过将它们放入文本框的类似方法,但我没有找到任何明确的答案。

$result = mysqli_query($con,"SELECT * FROM dados");

echo "<table border='2'>
<tr>
<th>nome</th>
<th>Idade</th>
<th>Email</th>
</tr>";

while($row = mysqli_fetch_array($result))
{
echo "<tr>";
echo "<td>" . $row['nome'] . "</td>";
echo "<td>" . $row['idade'] . "</td>";
echo "<td>" . $row['email'] . "</td>";

echo "</tr>";
}
echo "</table>";

这就是表格在我的 PHP 文件中的显示方式,一切都显示正常,但是,我希望每个字段都是一个锁定的文本框,按下“编辑”按钮可以进行编辑。

最佳答案

您可以创建带有两个图标的新列,一个用于删除,另一个用于编辑,当单击该按钮时,javascript 函数将启动并为其提供该行的 ID,它将使用 ajax 查询并获取该行的数据,打开模态进行编辑,您可以使用 ajax 保存数据。

让我们一步步来:

1- 添加新列

<?php
$result = mysqli_query($con, "SELECT * FROM dados");
echo "<table border='2'>
<tr>
<th>nome</th>
<th>Idade</th>
<th>Email</th>
<th>Edit</th>
</tr>";
while ($row = mysqli_fetch_array($result)) {
echo "<tr>";
echo "<td>" . $row['nome'] . "</td>";
echo "<td>" . $row['idade'] . "</td>";
echo "<td>" . $row['email'] . "</td>";
echo "<td><i class=\"fas fa-clock\" data-toggle="modal" data- 
target="#exampleModal" onclick=\"getDataForEdit(" . $row['id'] . 
")\"></i></td>";
echo "</tr>";
}
?>

2- 创建一个模式来插入我们将从 getDataForEdit 函数获得的数据

<div class="modal fade" id="exampleModal" tabindex="-1" role="dialog" aria- 
labelledby="exampleModalLabel"
 aria-hidden="true">
<div class="modal-dialog" role="document">
    <div class="modal-content">
        <div class="modal-header">
            <h5 class="modal-title" id="exampleModalLabel">Modal title</h5>
            <button type="button" class="close" data-dismiss="modal" aria- 
label="Close">
                <span aria-hidden="true">&times;</span>
            </button>
        </div>
        <div class="modal-body">
            <div class="form-group">
                <form action="" method="post">
                    @csrf
                    <div class="md-form mb-4">
                        <label data-error="wrong" data-success="right" 
for="defaultForm-pass">title
                        </label>
                        <div class="row">
                            <div class="col-8">
                                <input type="text" name="name" id="defaultForm- 
pass"
                                       class="form-control validate">
                            </div>
                            <div class="col-2">
                                <input type="text" name="tag" id="defaultForm- 
pass-email"
                                       class="form-control validate">
                            </div>
                            <div class="col-2">
                                <button type="submit" class="btn btn- 
primary">submit</button>
                            </div>
                        </div>
                    </div>
                </form>
            </div>
        </div>
        <div class="modal-footer">
            <button type="button" class="btn btn-secondary" data- 
dismiss="modal">Close</button>
            <button type="button" class="btn btn-primary">Save 
changes</button>
        </div>
    </div>
</div>
</div>

3- 所以现在我们应该先编写 javascript ajax 并获取我们要编辑的行的数据,然后将其插入模态

<script>
function getDataForEdit(id) {
    var response = null;
    return $.ajax({
        type: 'GET',
        url: 'myanswerpage.php?id=' + id,
        success: function (data) {
            insertData(data.name,data.email);
        },
        error: function () {
            alert('getting data was not successful');

        }
    });
}
</script>

<script>
function insertData(name,email) {
    document.getElementById('defaultForm-pass').value = name;
    document.getElementById('defaultForm-pass-email').value = email;
}
</script>

因此,无论何时单击用于编辑的图标,都会打开一个模式,其中包含您要编辑的行的信息。

关于javascript - 不是将 MySQL 数据从表格显示到 HTML 表格中,而是将其显示在可编辑的文本框上,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55520176/

相关文章:

Javascript - 阻止图像请求并将请求的 img-url 替换为另一个

php - 使用 MySQL 创建的菜单仅适用于网站内部,不适用于外部

php - 如何使用mysql和php仅显示今天或仅昨天的数据?

javascript - 加载动态内容时jquery未终止的字符串文字

javascript - 益智游戏中,如何让可移动的方 block 悬停为红色,而其他方 block 保持原样?

用于从 Google 工作表 URL 中提取电子表格 ID 和工作表 ID 的 Javascript 正则表达式

javascript - Controller 不是 NaNunction,未定义

javascript - 如何制作 svg 元素(例如矩形)scrollIntoView?

html - CSS子清除父 float

javascript - 以编程方式更改翻转开关值