
本文档旨在指导开发者如何在 Moodle 表单的 `select` 组件中,将数据库中的实际 ID 值作为选项值传递,而非默认的索引值。通过使用 `get_records_menu` 函数简化数据获取,并结合 `set_data` 方法设置表单数据,实现选项值的正确传递。
在 Moodle 表单开发中,select 组件常用于提供下拉选择功能。 默认情况下,addElement('select', ...) 方法会将数组的键(key)作为 zuojiankuohaophpcnoption> 的 value 属性。 然而,在某些情况下,我们需要将数据库中实际的 ID 值作为选项值传递,以便在表单提交后能够直接使用这些 ID 值。 本文将介绍如何实现这一目标。
Moodle 提供了 get_records_menu 函数,可以方便地从数据库中获取数据,并将其格式化为适合 select 组件使用的数组。 该函数接受表名、查询条件、排序字段和要返回的字段作为参数。
以下代码演示了如何使用 get_records_menu 函数从 m_tl_mastercourse 表中获取 id 和 name 字段,并将 id 作为选项值, name 作为选项文本:
global $DB;
$options = $DB->get_records_menu('m_tl_mastercourse', [], 'id', 'id, name');
$mform->addElement('select', 'master_id', get_string('selectcourse'), $options);在上述代码中:
生成的 HTML 代码如下所示:
<select id="id_master_id" name="master_id"> <option value="1">php01</option> <option value="2">ios01</option> <option value="3">and01</option> </select>
为了在编辑表单时预先选中某个选项,需要使用 set_data 方法设置表单数据。 以下代码演示了如何将 master_id 设置为 99:
$formdata = new \stdClass(); $formdata->master_id = 99; $mform = new edit_form(); $mform->set_data($formdata); $mform->display();
在上述代码中:
通过使用 get_records_menu 函数和 set_data 方法,可以方便地将数据库中的实际 ID 值作为 Moodle select 组件的选项值传递,并在编辑表单时预先选中某个选项。 这使得表单开发更加灵活和高效。
注意事项:
以上就是如何将 Moodle Select 组件的选项值作为实际值传递的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号