php:下拉列表查询(静态数据+数据库数据)

一、在php中嵌套

效果

1、从php中嵌套html语句

下拉列表的显示

php 复制代码
echo '<div class="text-nav-1 required "><div>' . _('在职状态') . ':</div>
<select name="work_status">';
// 定义选项数组
$options = [
        'all' => _('全部'),
        'inwork' => _('在职'),
        'levwork' => _('离职'),
];
// 检查 $_POST['work_status'] 是否已设置,并赋予相应的默认值
$selectedStatus = isset($_POST['work_status']) ? $_POST['work_status'] : 'all';
foreach ($options as $value => $label) {
        // 判断当前选项是否为选中状态
        $selected = ($value == $selectedStatus) ? ' selected="selected"' : '';
        echo '<option value="' . $value . '"' . $selected . '>' . $label . '</option>';
}
echo '</select></div>';

加入sql的查询语句

php 复制代码
if (isset($_POST['work_status']) and $_POST['work_status'] != '' and $_POST['work_status'] != 'all') {
    $sql = $sql . " and work_status " . LIKE . " '%" . $_POST['work_status'] . "%' ";
}

2、从html嵌套php

html 复制代码
<div class="text-nav-1 required ">
        <div><?php echo _('在职状态'); ?>:</div>
        <select name="work_status">
                <?php
                // 定义选项数组
                $options = [
                        'all' => _('全部'),
                        'inwork' => _('在职'),
                        'levwork' => _('离职'),
                ];

                // 检查 $_POST['work_status'] 是否已设置,并赋予相应的默认值
                $selectedStatus = isset($_POST['work_status']) ? $_POST['work_status'] : 'all';

                foreach ($options as $value => $label) {
                        // 判断当前选项是否为选中状态
                        $selected = ($value == $selectedStatus) ? ' selected="selected"' : '';
                ?>
                        <option value="<?php echo htmlspecialchars($value); ?>" <?php echo $selected; ?>><?php echo htmlspecialchars($label); ?></option>
                <?php
                }
                ?>
        </select>
</div>

二、从数据库中查询后放入下拉列表

效果

php 复制代码
<?php
$query = "SELECT DISTINCT employee_num FROM hr_employees";
$result = DB_query($query, $db);
// 2. 处理查询结果
$options = [];
while ($row = DB_fetch_array($result)) {
        // 假设您希望使用工作状态的实际值作为选项值,而显示的文本则进行一些转换或直接使用
        // 这里简化处理,直接使用employee_num值作为选项值和显示文本
        $options[$row['employee_num']] = $row['employee_num'];
}
// 添加"全部"选项
$options = ['all' => _('全部')] + $options;
// 3. 检查 $_POST['employee_num'] 是否已设置,并赋予相应的默认值
$selectedStatus = isset($_POST['employee_num']) ? $_POST['employee_num'] : 'all';
echo '<div class="text-nav-1 required "><div>' . _('工号') . ':</div>
<select name="employee_num">';
// 4. 生成下拉菜单
foreach ($options as $value => $label) {
        $selected = ($value == $selectedStatus) ? ' selected="selected"' : '';
        echo '<option value="' . $value . '"' . $selected . '>' . $label . '</option>';
}
echo '</select></div>';
?>
相关推荐
久绊A2 分钟前
Hydra-SSH 破解安全防范
开发语言·php
黑白世界46489 分钟前
开源分享: php-tools php gui的一次尝试
后端·php
阿昭L10 分钟前
c++中获取随机数
开发语言·c++
2501_9159184112 分钟前
iOS 开发全流程实战 基于 uni-app 的 iOS 应用开发、打包、测试与上架流程详解
android·ios·小程序·https·uni-app·iphone·webview
3壹16 分钟前
数据结构精讲:栈与队列实战指南
c语言·开发语言·数据结构·c++·算法
lichong95119 分钟前
【混合开发】vue+Android、iPhone、鸿蒙、win、macOS、Linux之dist打包发布在Android工程asserts里
android·vue.js·iphone
Android出海22 分钟前
Android 15重磅升级:16KB内存页机制详解与适配指南
android·人工智能·新媒体运营·产品运营·内容运营
悟乙己24 分钟前
使用 Python 中的强化学习最大化简单 RAG 性能
开发语言·python·agent·rag·n8n
一只修仙的猿27 分钟前
毕业三年后,我离职了
android·面试
max50060029 分钟前
图像处理:实现多图点重叠效果
开发语言·图像处理·人工智能·python·深度学习·音视频