[英]How to retrieve value from MYSQL to radio button using PHP?
我有自定义页面模板。 在此模板中,每个表行都有一个带有单选按钮的html表。 我试图从MYSQl中检索单选按钮的值,但我没有运气。
场景:如果用户选择“是”选项,则表行将被禁用。 现在,将检索单选按钮的值,但不会检索“是”选项的禁用功能。
如何解决这个问题?
PHP更新
if (isset($_POST['list_location']) && $_POST['list_location'] != 'Select by Location'){
$list_location = $_POST['list_location'];
$result_location = $wpdb->get_results($wpdb->prepare("SELECT DISTINCT id, submit_time, last_name, first_name, middle_name, mobile_number, email, location, position, message, attachment_resume_id, process_resume FROM resume_databank WHERE location = '" . $list_location . "' ORDER BY location ASC", OBJECT));
echo '<table>';
echo '<tr>';
$optionId = 0;
echo '<th>Submit Time</th>';
echo '<th>Last Name</th>';
echo '<th>First Name</th>';
echo '<th>Middle Name</th>';
echo '<th>Mobile Number</th>';
echo '<th>Email</th>';
echo '<th>Location</th>';
echo '<th>Position</th>';
echo '<th>Message</th>';
echo '<th>Resume</th>';
echo '<th>Processed?</th>';
for ($i=0;$i < count($result_location); $i++){
$row = $result_location[$i];
$optionId = $result_location[$i]->id;
$checkYes = "";
$checkNo = "";
if($result_location[$i]->process_resume == "Yes"){
$checkYes = "checked";
}
if($result_location[$i]->process_resume == "No"){
$checkNo = "checked";
}
echo '<tr>';
echo '<td id="submit_time">' . $result_location[$i]->submit_time . '</td>';
echo '<td id="last_name">' . $result_location[$i]->last_name . '</td>';
echo '<td id="first_name">' . $result_location[$i]->first_name . '</td>';
echo '<td id="middle_name">' . $result_location[$i]->middle_name . '</td>';
echo '<td id="mobile_number">' . $result_location[$i]->mobile_number . '</td>';
echo '<td id="email">' . $result_location[$i]->email . '</td>';
echo '<td id="location">' . $result_location[$i]->location . '</td>';
echo '<td id="position">' . $result_location[$i]->position . '</td>';
echo '<td id="message">' . $result_location[$i]->message . '</td>';
echo '<td id="resumeFile'.$optionId.'"><a href=' . wp_get_attachment_url($result_location[$i]->attachment_resume_id) . '>Download Resume</a></td>';
echo '<td id="radioOption><label for="Yes">Yes</label>
<input type="radio" id="processedOptionYes'.$optionId.'" name="processedOption'.$optionId.'" ' . $checkYes . ' value="Yes" onclick="proccessedCheck('.$optionId.',\'Yes\')"/>
<label for="No">No</label>
<input type="radio" id="processedOptionNo'.$optionId.'" name="processedOption'.$optionId.'" ' . $checkNo . ' value="No" onclick="proccessedCheck('.$optionId.',\'No\')"/></td>';
echo '</tr>';
}
echo '</table>';
}
JS:
function proccessedCheck(optionId,optionAnswer){
if(optionAnswer == 'Yes'){
if (confirm('You have chosen ' + optionAnswer + ', is this correct?')){
jQuery("#processedOptionYes" + optionId).attr('disabled',true);
jQuery("#processedOptionNo" + optionId).attr('disabled',true);
var withlink = jQuery("#resumeFile"+ optionId).html();
var withoutlink = jQuery(withlink).html();
jQuery("#resumeFile"+optionId).html("").append(withoutlink);
jQuery("#inputHidden1").val(optionId);
jQuery("#inputHidden2").val(optionAnswer);
jQuery("#hiddenForm").submit();
}
}
}
隐藏表格和PHP:
<?php
if (isset($_POST['optionAnswer']) && $_POST['optionAnswer']){
$optionId = $_POST['optionId'];
$optionAnswer = $_POST['optionAnswer'];
$queryOptionId = $wpdb->query($wpdb->prepare("UPDATE resume_databank SET process_resume = '$optionAnswer' WHERE id = %d", $optionId));
}
?>
<form id='hiddenForm' method='POST' action=''>
<input type="hidden" id="inputHidden1" name="optionId" />
<input type="hidden" id="inputHidden2" name="optionAnswer" />
</form>
同一组中的单选按钮应具有相同的名称。 然后,您可以使用该名称获取选择了哪个按钮,并且该值将为所选按钮的值(在这种情况下为“是”或“否”)。
在这种情况下,您可以执行类似$value = $_REQUEST['processedOption'];
为拿到它,为实现它。
但是请注意,此设置仅在您的表具有一组这样的按钮时才有效。 如果此表中有多行,则每个组将需要一个不同的名称,否则将只能看到最后一个。 如果是这种情况,我将它们命名为processedOption[$optionId]
,这样PHP就会为您将它们收集到一个数组中。 (选项ID将是键,而“是”和“否”将是值。)
您是否只想将条件语句从单选按钮字段中移出,就可以使其变得更容易管理? 创建2个变量并根据某些条件为它们分配值不会花那么多钱,而是会让事情变得更加清晰。 在这里,尝试只创建2个变量:$ checkYes和$ checkNo,然后回显任何内容。 然后,我们检查$ result_position [$ i]-> process_resume ==“ Yes”,在这种情况下,我们为$ checkYes变量分配了“ checked”。 我们为NO做过同样的事情。 然后,我们在适当的位置添加$ checkYes或$ checkNo ...
<?php
// BE SURE THAT BOTH THE VARIABLES & CONDITIONAL STATEMENTS EXIST
// WITHIN YOUR LOOP... PREFERABLLY AT THE BEGINNING OF THE LOOP.
// OTHERWISE; $i HAS NO MEANING TO THE CONDITIONAL STATEMENTS BELOW.
// CREATE THE $checkYes & $checkNo VARIABLES + INITIALIZE THEM TO EMPTY STRINGS
$checkYes = "";
$checkNo = "";
// NEXT ASSIGN "checked" TO THE $checkYes OR $checkNo VARAIBLE
// IF ANY OF THE CONDITIONS BELOW IS SATISFIED...
// WE'LL USE THESE VARIABLES BELOW: WITHIN THE RADIO BUTTONS SECTION
if($result_position[$i]->process_resume=="No"){
$checkNo = "checked";
}
if($result_position[$i]->process_resume=="Yes"){
// TO DISABLE ALL RADIO BUTTONS WITH A "YES" VALUE;
// SIMPLE ADD "disabled" TO THE $checkYes STRING LIKE SO:::
$checkYes = "checked disabled";
$checkNo = "disabled";
}
echo '<td id="submit_time">' . $result_position[$i]->submit_time . '</td>';
echo '<td id="last_name">' . $result_position[$i]->last_name . '</td>';
echo '<td id="first_name">' . $result_position[$i]->first_name . '</td>';
echo '<td id="middle_name">' . $result_position[$i]->middle_name . '</td>';
echo '<td id="mobile_number">' . $result_position[$i]->mobile_number . '</td>';
echo '<td id="email">' . $result_position[$i]->email . '</td>';
echo '<td id="location">' . $result_position[$i]->location . '</td>';
echo '<td id="position">' . $result_position[$i]->position . '</td>';
echo '<td id="message">' . $result_position[$i]->message . '</td>';
echo '<td id="resumeFile' . $optionId . '"><a href=' . wp_get_attachment_url($result_position[$i]->attachment_resume_id) . '>Download Resume</a></td>';
echo '<td id="radioOption><label for="Yes">Yes</label>
<input type="radio" id="processedOptionYes'.$optionId.'" name="processedOption_' . $optionId . '" ' . $checkYes . ' value="Yes" onclick="proccessedCheck('.$optionId.',\'Yes\')"/>
<label for="No">No</label>
<input type="radio" id="processedOptionNo'. $optionId.'" name="processedOption_' . $optionId . '" ' . $checkNo . ' value="No" onclick="proccessedCheck('.$optionId.',\'No\')"/></td>';
您可以在回显内使用简写的if-else ( ( $result_location[$i]["process_resume"] == "Yes" ) ? " checked" : '' )
因此,我假设您使用$result_location[$i]["process_resume"]
从数据库中获取值。 看到其余的代码,我想应该是$result_position[$i]->process_resume
。
echo '<td id="radioOption><label for="Yes">Yes</label>';
echo '<input type="radio" id="processedOptionYes'.$optionId.'" name="processedOption"'.( ( $result_location[$i]["process_resume"] == "Yes" ) ? " checked" : '' ).'value="Yes" onclick="proccessedCheck('.$optionId.',\'Yes\')"/>';
echo '<label for="No">No</label>';
echo '<input type="radio" id="processedOptionNo'.$optionId.'" name="processedOption"'.( ( $result_location[$i]["process_resume"] == "No" ) ? " checked" : '' ).'value="No" onclick="proccessedCheck('.$optionId.',\'No\')"/></td>';
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.