gpt4 book ai didi

php - html.php 表单将 bool 单选按钮值呈现为 `on`

转载 作者:可可西里 更新时间:2023-10-31 23:45:20 25 4
gpt4 key购买 nike

所以我有一个包含三个按钮的 html.php 页面:“清除页面”、“检索”和“更新详细信息”。

当用户第一次打开表单时,它是空白的,他们可以输入 id="siteId"值或 id="siteName"值,然后按“检索”按钮以请求存储站点的其余详细信息来自 mySQL 数据库并显示在表单中。

如果用户想要更改/更新任何详细信息,他们可以在相同的表单中执行此操作,然后单击“更新详细信息”按钮将站点的详细信息推送回数据库。

到目前为止一切都(有点)好。但是,在成功显示站点详细信息后(在从数据库中检索到站点详细信息之后)单击“更新详细信息”按钮时,单选按钮表示的任何 bool 数据都将返回为 on,观察到在当前值数组上使用 print_r

对于每个单选按钮,php 条件语句与 html 一起使用,以确定在从数据库检索数据后,应为每个行/字段检查哪个单选按钮。这可能就是为什么当按下更新按钮而不是先前确定的 bool 值时,表单以某种方式为所有单选按钮设置 on 的值吗?

如果是这样,我需要通过条件检查任何给定集合的哪个单选按钮需要检查,那么修复方法是什么?

html.php 页面片段:

  } // close isset IF

?>

<h1 id="heading">Cell Site Details</h1>


<!--fieldset id="Site:"-->
<!--legend>Site:</legend-->
<div id="formContentDiv">
<form id="formContent" action="#" method="post" accept-charset="utf-8">
<input type="hidden" name="submitted" value="true">
<div id="clearPageDiv">
<a href="index2.php">
<input type="button" id="buttonClear" name="clearPage" class="button" value="Clear Page">
</a>
</div><!-- closes clearPageDiv -->
<div id="retreiveDiv">
<input type="submit" id="buttonRetreive" name="retreive" class="button" value="Retreive">
</div><!-- closes retreiveDiv -->
<div id="updateDiv">
<input type="submit" id="buttonUpdate" name="update" class="button" value="Update Details">
</div><!-- closes updateDiv -->

<div class="formRowDiv">
<label>
<span>Site Id:</span>
<input type="text" id="siteId" name="siteId" class="textInputShort" maxlength="" $value="">
<script>
siteId.value = <?php echo json_encode( ucfirst( $siteId ) ); ?>;
</script>
</label>
</div>

<div class="formRowDiv">
<label>
<span>Site Name:</span>
<input type="text" id="siteName" name="siteName" class="textInput" maxlength="" $value="test">
<!--input type="submit" value="Retreive"-->
<script>
siteName.value = <?php echo json_encode( ucwords( $siteName ) ); ?>;
</script>
</label>
</div>

<div class="formRowDiv">
<label>
<span># HSPA BBUs:</span>
<input type="text" id="numHspaBbu" name="numHspaBbu" class="textInputShort" maxlength="" $value="">
<script>
numHspaBbu.value = <?php echo json_encode( $numHspaBbu ); ?>;
</script>
</label>
</div>

<div class="formRowDiv">
<label>
<span># LTE BBUs:</span>
<input type="text" id="numLteBbu" name="numLteBbu" class="textInputShort" maxlength="" $value="">
<script>
numLteBbu.value = <?php echo json_encode( $numLteBbu ); ?>;
</script>
</label>
</div>

<div class="formRowDiv">
<label><span>Ext. Alarm Terminations:</span></label>
<label>
<input type="radio" name="extAlarmsTerminated"
<?php
if ( $extAlarmsTerminated == "hspa" ) {
echo 'checked';
}
?>
>
<span>HSPA</span>
</label>
<label>
<input type="radio" name="extAlarmsTerminated"
<?php
if ( $extAlarmsTerminated == "lte" ) {
echo 'checked';
}
?>
>
<span>LTE</span>
</label>
<label>
<input type="radio" name="extAlarmsTerminated"
<?php
if ( $extAlarmsTerminated == "hspa-lte" ) {
echo 'checked';
}
?>
>
<span>HSPA-and-LTE</span>
</label>
</label>
</div><!-- close formRowDiv -->

var $extAlarmsTerminated 是以下站点详细信息数组中的一个这样的单选按钮组:

$inputVals = array( $siteId, $siteName, $numHspaBbu, $numLteBbu, $extAlarmsTerminated );
print_r( $inputVals );

print_r 首先显示输出,用户按下检索按钮后显示的 bool 单选按钮值:

Array ( [0] => P6969 [1] => Toledo Centre [2] => 1 [3] => 1 [4] => hspa-lte

print_r 输出显示用户按下更新详细信息按钮后同一站点详细信息的单选按钮值:

Array ( [0] => P6969 [1] => Toledo Centre [2] => 1 [3] => 1 [4] => on )

编辑:
我将从数据库中检索到的每个字段输入值分配给 PHP $_SESSION 变量,当单击“更新详细信息”按钮时,将引用 $_SESSION 变量,这解决了单选按钮被分配 的原始问题

但我仍然无法保存用户可能对详细信息所做的任何更改。我已经研究过 JS/AJAX 作为实现这一目标的可能方法,但我所知道的很少的 JS 让我变得更加危险而不是有用。以下是我在阅读多个类似问题时能够拼凑起来的内容:

<div class="formRowDiv">
<label>
<span>Site Name:</span>
<input type="text" id="siteName" name="siteName" class="textInput" maxlength="" $value="test">
<script>
siteName.value = <?php echo json_encode( ucwords( $siteName ) ); ?>;
</script>
</label>
</div>
<script>
$( document ).ready( function() {
$( "#siteName" ).on( 'change', function() {
var siteName = document.getElementById( 'siteName' ).value;
$.ajax ({
url: 'ajax.php',
data: { siteName : siteName },
success: function( result ) {
alert( 'Site Name value changed to: ' + siteName );
}
});
});
});
</script>

好消息是,当 $siteName 的字段输入值发生变化时,我收到了 JS 警报,回显了 $siteName 的变化值。我创建了在同一目录中引用的 ajax.php 文件,它包含:

<?php
echo ( $_GET[ 'siteName' ] );
?>

我想我可以通过以下方式访问这个更改后的 $siteName 值:

$siteName = $_GET[ 'siteName' ];

但显然不是。是否确实有一种方法可以访问我认为现在必须存储在 ajax.php 中的这个已更改的 PHP 变量?

最佳答案

尝试分配 value=每个输入复选框的属性,例如您的代码将是:

<input type="radio" name="extAlarmsTerminated" value='HSPA'
...
<input type="radio" name="extAlarmsTerminated" value='lte'
...
<input type="radio" name="extAlarmsTerminated" value='HSPA-lte'

结果:print_r($_POST)输出:

Array ( [submitted] => true [update] => Update Details [siteId] => P6969 [siteName] => Toledo Centre [numHspaBbu] => 1 [numLteBbu] => 1 [extAlarmsTerminated] => HSPA-lte )

I thought I could then get access to this changed $siteName value with something like:

$siteName = $_GET[ 'siteName' ]; But apparently not. Is there indeed a way to access this changed PHP var that I think must be now stored in ajax.php?

首先,您使用的是 POST 而不是 GET 方法,因此您应该寻找 $_POST['siteName']

其次,如果您要确保传递正确的值,请在您的表单中更改此值 <form id="formContent" action="#" method="post" ...

<form id="formContent" action="test.php" method="post" ...其中 test.php 包含:

<?php
echo ( $_POST['siteName'] );
?>

关于php - html.php 表单将 bool 单选按钮值呈现为 `on`,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42885524/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com