database - Codeigniter foreach 选择菜单“已选择”选项
问题描述
我正在为应用程序创建主题选择选项。我希望用户从选择选项中选择他们想要的主题,浅色或深色。
我将主题名称存储在数据库中,如下所示:
然后我调用模型中的所有主题并使用以下代码返回数组:
public function getThemes() {
$query = $this->db->query('SELECT * FROM theme');
return $query->result_array();
}
我正在使用构造函数来获取数据并将其渲染到我的设置视图,如下所示:(我在 $this->data 中同时发送一些东西,这就是它在数组中的原因,但我删除了该代码)
$this->data = [
'themes' => $this->model_setting->getThemes()
];
$this->render('backend/standart/administrator/setting/setting_general', $this->data);
在我的 HTML 视图中,我有以下 HTML,它成功显示了正确的 2 个可用主题:
<div class="col-sm-12">
<label>Select Your Desired Theme</label><br>
<select class="form-control" name="site_color_theme" id="site_color_theme">
<?php foreach ($themes as $theme): ?>
<option value="<?= $theme['theme']; ?>" ><?= $theme['name']; ?></option>
<?php endforeach; ?>
</select>
</div>
当我保存设置表单时,我正在使用主题名称更新数据库中的选项表。Html 正文类调用此选项表并找到所选主题并使用它来呈现特定的 CSS 样式表。
我遇到的问题是当我保存我的设置时,选择选项不显示保存的主题名称以表明这是选择的活动主题。
当用户访问设置页面选择另一个主题时,如何获得选择选项以显示所选主题?
解决方案
- 你应该在表中有
active_theme
列theme
active_theme
设置1
为何时提交表单下拉列表site_color_theme
(其余主题记录设置为0
)- 您应该使用 Codeigniter 表单助手来做到这一点:https ://www.codeigniter.com/user_guide/helpers/form_helper.html#form_dropdown
// $themes = Theme list array [id => theme-name, id => theme-name]
// $active_theme = Record of "active_theme" with value equal to "1"
// $extra = Custom HTML attributes e.g. class="something" onclick="function(js)"
echo form_dropdown('site_color_theme', $themes, $active_theme, $extra);
推荐阅读
- flutter - 如何允许从具有空安全性的飞镖中的函数返回空值
- powershell - 我的测试代码和功能代码是否需要在同一个目录中才能使 Pester Code Coverage 工作?
- python - Django:列出模板中每个用户组(多对多)关系的用户详细信息和组
- c# - ListBox 在 IE11 的开发者工具中以 disabled 属性呈现
- angular - 复用ngrx效果链
- python - 正则表达式替换单词
- javascript - AmCharts 4:无法查看特定值的网格的各个线
- r-markdown - 在 Rmd 块中打印自定义 HTML 对象 - 为什么 x 失败但 print(x) 工作?
- java - 如何在另一个控制器中注入控制器类?我如何使用带有“test/controller1/hello”的 helloworld() 实现该方法?
- c# - 使用 ado.net 按公司明智地获取计数数据