- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试用此人的全名填充 Yii2 中的下拉列表,名字和姓氏在我的数据库中的不同列中。
在我的个人表中
...
在我的 Person.php 模型中有
public function getFullName()
{
return $this->first_name . ' ' . $this->last_name;
}
这是我在 GridView 中取回全名的辅助函数,工作正常。但是我在填充下拉菜单时遇到了问题。
// Get person
$person = Person::find()
->orderBy('last_name')
->asArray()
->all();
// Person drop down
$personMap = ArrayHelper::map($person, 'fullName', 'dep_id');
这样我在下拉列表中什么也得不到,但人员 ID 是正确的。那么我需要如何正确地处理这个问题呢?
最佳答案
你不能像那样使用 ArrayHelper::map()
因为 fullName
没有出现在模型属性中。
但是你可以指定闭包而不是属性名来达到想要的结果:
$person = Person::find()
->orderBy('last_name')
->all();
$personMap = ArrayHelper::map(
$person,
function ($person, $defaultValue) {
return $person->getFullName();
}
'dep_id'
);
如果您应用asArray()
,您将无法调用模型方法,但您仍然可以像这样包含全名:
$person = Person::find()
->orderBy('last_name')
->asArray()
->all();
$personMap = ArrayHelper::map(
$person,
function ($person, $defaultValue) {
return $person['first_name'] . ' ' . $person['last_name'];
}
'dep_id'
);
我不建议使用它,因为它是获取全名的重复逻辑。
至于细节:在 map()
方法中 $from
和 $to
参数 getValue()
方法将被调用()。如果你检查 official documentation对于该方法,您会找到一些将 $key
指定为闭包的示例。
通常这样的列表也形成反之亦然:由 id 索引的字符串变量。
在这种情况下,您可以将其作为 $items
传递以显示 drop-down list .
在您的情况下,当模型集至少包含两个姓名完全相同的人时,可能会出现一些问题。
要更改它,只需切换第二个和第三个参数即可。
关于Yii2 DropDownList 全名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28174440/
我正在尝试用此人的全名填充 Yii2 中的下拉列表,名字和姓氏在我的数据库中的不同列中。 在我的个人表中 编号 名字 姓氏 dep_id (fk) ... 在我的 Person.php 模型中有 pu
我目前正在像这样连接名字和姓氏(使用 PostgreSQL): concat(customers.firstname, ' ', customers.lastname) 我在这里遇到的问题是我的客户只
从 (new Date()).toString() 返回的字符串看起来像这样: "Tue Nov 22 2016 14:14:51 GMT-0800 (Pacific Standard Time)"
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
已经将近 3 天了,我仍然无法修复该错误。简单的情况,我想搜索人名(姓名和姓氏)。 示例: 首先我写给 John(结果:John Newman、John Stable、John Carens) 然后我
我在我的项目中使用 Laravel 5.3,我试图获取多个列并在 View 的下拉选择元素中显示数据。我正在做这样的查询: $users = User::select( DB:
我目前正在使用此脚本从给定路径中提取名称、文件夹、文件夹名称: Get-ChildItem "C:\user\desktop" | Select Name, ` @{ n = 'Folde
我通过在 ApplicationUser 中添加几个字段扩展了 ASP NET 身份架构。派生自 IdentityUser 的类.我添加的字段之一是 FullName . 现在,当我写 User.Id
我正在开发一个 Android 应用程序,其中任何使用我们的应用程序登录到 Facebook 的 Android 用户,我需要从 Facebook 中提取他的照片、他的性别和他的全名。我正在为此使用
我是一名优秀的程序员,十分优秀!