- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
正如标题所示,保存表单后我无法使按钮保持在一行中。我可以通过 JavaScript 在一行中添加一个按钮。
我有一个 php 代码,如下所示。下面的 html/php 代码的工作方式是,在添加行时,我们可以从每一行中选择日期并保存它。现在我正在尝试连续添加一个按钮。这是 script (完全是 JS)我已经使用它来连续添加一个按钮(具有任何文本)。
我现在在添加行时遇到的问题是该按钮确实显示在每一行中,但保存表单并返回后,该按钮可能从每一行中消失因为没有保存任何内容在 JSON 中。
html/php代码:
<?php
$output = array();
问题陈述:
我现在遇到的问题是,我可以添加任意多的行,但保存表单后按钮不会保留。只有包含日期的行才会保留在网页上。
我想知道需要在上面的 php/javascript 代码中进行哪些更改,以便按钮在保存表单后保留。当我检查 JSON 时,那里没有保存任何内容,因此这可能是保存表单后按钮不保留的原因。
编辑 1:
在 JSON 中,它为 null {"row_delete":null},这就是保存表单后按钮不会保留在每一行中的原因。
最佳答案
按钮未显示,因为您无法在 php 请求中获取 HTML 按钮元素值。要获取按钮值,您必须使用带有值的额外隐藏变量
<?php
if (!empty($_POST)) {
$output = array();
if (!empty($_POST['house_sitting_date'])) {
$output['house_sitting_date'] = $_POST['house_sitting_date'];
}
if (!empty($_POST['row_delete'])) {
$output['row_delete'] = $_POST['row_delete'];
}
$fp = fopen('ptp-ess_landing_house.json', 'w');
fwrite($fp, json_encode($output));
fclose($fp);
}
$data = [];
if(file_exists('ptp-ess_landing_house.json')) {
$data = json_decode(file_get_contents('ptp-ess_landing_house.json'));
}
?><form method="post">
<!-- Add New Row Button START -->
<div class="plus-minus-button" style="text-align:center;">
<button type="button" id="addRow" onclick="rowAdd()">+</button>
</div>
<!-- Add New Row Button END -->
<div id="rows" style="display:flex; justify-content: center;"> <!-- Big div START -->
<!-- This is what I have tried to add a button (START) -->
<!-- Remove Button START -->
<div class="rows-delete" style="text-align:center;">
<h4 style="text-align:center;">Delete Rows</h4><?php
if (empty($data->row_delete)) {
?><div class="row-delete" style="margin-right:30px; margin-top:20px;">
<button type="button" />Remove</button>
<input type="hidden" name="row_delete[]" value="1" />
</div><?php
}
else {
foreach ($data->row_delete as $row_delete){
?><div class="row-delete" style="margin-right:30px; margin-top:20px;">
<button type="button">Remove</button>
<input type="hidden" name="row_delete[]" value="<?php echo $row_delete;?>" />
</div><?php
}
}
?></div>
<!-- Remove Button END -->
<!-- This is what I have tried to add a button (END) -->
<!-- Sitting Date START -->
<div class="sitting-days" style="text-align:center;">
<h4 style="text-align:center;">Select Date</h4><?php
if (empty($data->house_sitting_date)) {
?><!-- Select Date START -->
<div class="select-date" style="margin-right:30px; margin-top:20px;">
<input type="date" class="house-sitting-date" name="house_sitting_date[]" value="">
</div><?php
}
else {
foreach ($data->house_sitting_date as $date){ ?>
<!-- Select Date START -->
<div class="select-date" style="margin-right:30px; margin-top:20px;">
<input type="date" class="house-sitting-date" name="house_sitting_date[]" value="<?php if($date) {echo $date;}?>">
</div><?php
}
}
?></div>
<!-- Sitting Date END -->
</div>
<!-- Big div END -->
<hr />
<div style="text-align:center;">
<input type="submit" value="submit" />
</div>
</form>
<script>
function rowAdd(event) {
document.getElementById("rows")
.insertAdjacentHTML('beforeend', newRow());
}
function newRow() {
var row_delete = document.querySelectorAll('input[name="row_delete[]"]');
var row_delete_length = row_delete.length + 1;
return `<div id="default-node" class="sitting-days" style="display:flex; justify-content:center; margin-bottom:20px;">
<div class="row-delete" style="margin-right:30px;">
<button type="button">Remove</button>
<input type="hidden" name="row_delete[]" value="` + row_delete_length + `" />
</div>
<div class="select-date" style="margin-right:30px;">
<input type="date" class="house-sitting-date" name="house_sitting_date[]" value="">
</div>
</div>`;
}
</script>
注意:未提供删除原始代码,我认为您有足够的能力来做到这一点
关于javascript - 如何让php/json中的按钮保持在一行?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59868480/
我想做的是让 JTextPane 在 JPanel 中占用尽可能多的空间。对于我使用的 UpdateInfoPanel: public class UpdateInfoPanel extends JP
我在 JPanel 中有一个 JTextArea,我想将其与 JScrollPane 一起使用。我正在使用 GridBagLayout。当我运行它时,框架似乎为 JScrollPane 腾出了空间,但
我想在 xcode 中实现以下功能。 我有一个 View Controller 。在这个 UIViewController 中,我有一个 UITabBar。它们下面是一个 UIView。将 UITab
有谁知道Firebird 2.5有没有类似于SQL中“STUFF”函数的功能? 我有一个包含父用户记录的表,另一个表包含与父相关的子用户记录。我希望能够提取用户拥有的“ROLES”的逗号分隔字符串,而
我想使用 JSON 作为 mirth channel 的输入和输出,例如详细信息保存在数据库中或创建 HL7 消息。 简而言之,输入为 JSON 解析它并输出为任何格式。 最佳答案 var objec
通常我会使用 R 并执行 merge.by,但这个文件似乎太大了,部门中的任何一台计算机都无法处理它! (任何从事遗传学工作的人的附加信息)本质上,插补似乎删除了 snp ID 的 rs 数字,我只剩
我有一个以前可能被问过的问题,但我很难找到正确的描述。我希望有人能帮助我。 在下面的代码中,我设置了varprice,我想添加javascript变量accu_id以通过rails在我的数据库中查找记
我有一个简单的 SVG 文件,在 Firefox 中可以正常查看 - 它的一些包装文本使用 foreignObject 包含一些 HTML - 文本包装在 div 中:
所以我正在为学校编写一个 Ruby 程序,如果某个值是 1 或 3,则将 bool 值更改为 true,如果是 0 或 2,则更改为 false。由于我有 Java 背景,所以我认为这段代码应该有效:
我做了什么: 我在这些账户之间创建了 VPC 对等连接 互联网网关也连接到每个 VPC 还配置了路由表(以允许来自双方的流量) 情况1: 当这两个 VPC 在同一个账户中时,我成功测试了从另一个 La
我有一个名为 contacts 的表: user_id contact_id 10294 10295 10294 10293 10293 10294 102
我正在使用 Magento 中的新模板。为避免重复代码,我想为每个产品预览使用相同的子模板。 特别是我做了这样一个展示: $products = Mage::getModel('catalog/pro
“for”是否总是检查协议(protocol)中定义的每个函数中第一个参数的类型? 编辑(改写): 当协议(protocol)方法只有一个参数时,根据该单个参数的类型(直接或任意)找到实现。当协议(p
我想从我的 PHP 代码中调用 JavaScript 函数。我通过使用以下方法实现了这一点: echo ' drawChart($id); '; 这工作正常,但我想从我的 PHP 代码中获取数据,我使
这个问题已经有答案了: Event binding on dynamically created elements? (23 个回答) 已关闭 5 年前。 我有一个动态表单,我想在其中附加一些其他 h
我正在尝试找到一种解决方案,以在 componentDidMount 中的映射项上使用 setState。 我正在使用 GraphQL连同 Gatsby返回许多 data 项目,但要求在特定的 pat
我在 ScrollView 中有一个 View 。只要用户按住该 View ,我想每 80 毫秒调用一次方法。这是我已经实现的: final Runnable vibrate = new Runnab
我用 jni 开发了一个 android 应用程序。我在 GetStringUTFChars 的 dvmDecodeIndirectRef 中得到了一个 dvmabort。我只中止了一次。 为什么会这
当我到达我的 Activity 时,我调用 FragmentPagerAdapter 来处理我的不同选项卡。在我的一个选项卡中,我想显示一个 RecyclerView,但他从未出现过,有了断点,我看到
当我按下 Activity 中的按钮时,会弹出一个 DialogFragment。在对话框 fragment 中,有一个看起来像普通 ListView 的 RecyclerView。 我想要的行为是当
我是一名优秀的程序员,十分优秀!