- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我不明白 Yii2 中的过滤和排序如何与关系表一起工作。
我有 3 个表,因为链接可以有多个国家/地区。我想出了如何将其保存到 links_countries 表中。
Links Countries LinksCountries
link_id country link_id
country country
链接和国家/地区通过链接模型中的这种关系进行连接
public function getManyCountries()
{
return $this->hasMany(Countries::className(), ['country' => 'country'])->viaTable('links_countries', ['links_id' => 'links_id']);
}
在我的index.php GridView中
[
'label' => 'Countries',
'attribute' => 'linksCountries.country',
'value' => function ($model) {
$countries = ArrayHelper::map($model->manyCountries, 'country', 'country_name');
return implode(', ', $countries);
},
'format' => 'raw'
],
这会产生这样的网格
如您所见,ID 1034 的链接有多个国家/地区,但过滤器无法以这种方式工作。那么如何显示这样的网格呢?
Link ID Country Link
1034 Andorra linkname1
1034 Kosovo linkname1
我尝试过这种关系
public function getLinksCountries()
{
return $this->hasMany(LinksCountries::className(), ['links_id' => 'links_id']);
}
在 LinksSearch 模型中
$dataProvider = new ActiveDataProvider([
//'query' => $query,
'query' => $this->getLinksCountries(),
]);
但似乎不起作用。
最佳答案
因此,解决方案是基于 LinksCountries 模型显示网格并从 Links 模型中获取值。
LinksCountries.php
<?php
namespace common\models;
use Yii;
class LinksCountries extends \yii\db\ActiveRecord
{
/**
* @inheritdoc
*/
public static function tableName()
{
return 'links_countries';
}
/**
* @inheritdoc
*/
public function rules()
{
return [
[['links_id', 'country'], 'required'],
[['links_id'], 'integer'],
[['modified_date', 'created_date'], 'safe'],
[['country'], 'string', 'max' => 3],
[['modified_by', 'created_by'], 'string', 'max' => 64]
];
}
/**
* @return \yii\db\ActiveQuery
*/
public function getManyCountries()
{
return $this->hasOne(Countries::className(), ['country' => 'country']);
}
/**
* @return \yii\db\ActiveQuery
*/
public function getLinks()
{
return $this->hasOne(Links::className(), ['links_id' => 'links_id']);
}
public function getCountryName() {
return $this->country->country_name;
}
public function getLinkName() {
return $this->links->link;
}
public function getShortDescription() {
return $this->links->short_description;
}
}
LinksCountriesSearch.php
<?php
namespace common\models;
use Yii;
use yii\base\Model;
use yii\data\ActiveDataProvider;
use common\models\LinksCountries;
class LinksCountriesSearch extends LinksCountries
{
public $linkName;
public $shortDescription;
public function rules()
{
return [
[['links_countries_id', 'links_id'], 'integer'],
[['country', 'modified_by', 'modified_date', 'created_by', 'created_date', 'linkName', 'shortDescription'], 'safe'],
];
}
/**
* @inheritdoc
*/
public function scenarios()
{
// bypass scenarios() implementation in the parent class
return Model::scenarios();
}
/**
* Creates data provider instance with search query applied
*
* @param array $params
*
* @return ActiveDataProvider
*/
public function search($params)
{
$query = LinksCountries::find();
$dataProvider = new ActiveDataProvider([
'query' => $query,
]);
$dataProvider->sort->attributes['linkName'] = [
'asc' => ['links.link' => SORT_ASC],
'desc' => ['links.link' => SORT_DESC],
];
$dataProvider->sort->attributes['shortDescription'] = [
'asc' => ['links.short_description' => SORT_ASC],
'desc' => ['links.short_description' => SORT_DESC],
];
$query->joinWith('links');
$query->joinWith('manyCountries');
$this->load($params);
if(!$this->validate()){
// uncomment the following line if you do not want to return any records when validation fails
// $query->where('0=1');
return $dataProvider;
}
$query->andFilterWhere([
'links_countries_id' => $this->links_countries_id,
'links.links_id' => $this->links_id,
'modified_date' => $this->modified_date,
'created_date' => $this->created_date,
]);
$query->andFilterWhere(['like', 'countries.country_name', $this->country])
->andFilterWhere(['ilike', 'links.link', $this->linkName])
->andFilterWhere(['ilike', 'links.short_description', $this->shortDescription])
->andFilterWhere(['like', 'modified_by', $this->modified_by])
->andFilterWhere(['like', 'created_by', $this->created_by]);
return $dataProvider;
}
}
index.php
use yii\helpers\ArrayHelper;
use common\models\Countries;
echo GridView::widget([
'dataProvider'=> $dataProvider,
'filterModel' => $searchModel,
'columns' => [
[
'attribute' => 'links_id',
'width'=>'50px',
],
[
'attribute' => 'country',
'value' => 'manyCountries.country_name',
'vAlign'=>'middle',
'width'=>'200px',
'filterType'=>GridView::FILTER_SELECT2,
'filter'=> ArrayHelper::map(Countries::find()->orderBy('country_name')->asArray()->all(), 'country_name', 'country_name'),
'filterWidgetOptions'=>[
'pluginOptions'=>['allowClear'=>true],
],
'filterInputOptions'=>['placeholder'=>'Select country'],
'format'=>'raw',
],
[
'attribute' => 'linkName',
'format' => 'raw',
'value' => function ($model) {
return Html::a($model->linkName, $model->linkName, ['target'=>'_blank']);
},
],
'shortDescription',
],
]);
关于gridview - Yii2 在 GridView 中使用 viaTable 关系进行排序和过滤,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34894966/
我有一个需要以编程方式作为列(而不是行)绑定(bind)到 gridview 的值列表。例如,如果我的 DAL 返回 10 个值,我需要将这 10 个值显示为 gridview 中的列作为标题文本,并
我有一个使用 out-gridview 显示结果的脚本.这是一个简单的例子: "hello world" | out-gridview 当我使用 Run with PowerShell 运行脚本时,它
我正在尝试使用工作正常的 Kartik 导出小部件,除了它没有在扩展“函数/网格”中获取数据。现在我当然明白它是如何工作的,它实际上并没有显示任何东西,只是呈现另一个 View 。但我不知道如何在导出
在 Android 教程中,GridView tutorial准确的说是有一行代码 GridView gridview = (GridView) findViewById(R.id.gridview)
我正在尝试为与我的 gridview 关联的每一列添加一个标题,这样当页面足够宽以显示多行项目时,列标题应该显示在每一列的顶部,如果页面缩小,以至于该列不再适合。 最终结果看起来像这样: 2 colu
在我使用 comboBox 而不是 default(textBox) 在 gridview 中使用这个搜索之前: [ 'attribute' => 'project_status',
我想在列中显示我的交易表中一个/所有帐户的总余额。余额列应显示添加上一行总余额的余额。 我的网格 View 代码是 'yii\grid\SerialColumn'],
我正在使用 gridview 列出我的所有数据。我的 table 看起来像这样。 $dataProvider, 'columns' => [ 'firstName',
我目前正在构建一个 Windows 8 XAML C# 应用程序。在一个页面中,我有一个用于水平滑动和滚动的滚动查看器。我有几个控件可以很好地与 scorllviewer 配合使用。但是当您滚动并且光
当调整 GridView 的大小时,它的元素被重新排列,该元素的动画似乎不起作用。 在这里你可以找到一个简单的例子:http://pastebin.com/BgST6sCv 如果单击示例中的其中一个方
如何动态更改 gridview 模板列顺序? 最佳答案 迭代 通通栏目 的网格 View 对象和 店铺 他们在 收藏 . List columns = new List(); foreach (Dat
我在 Yii2 中使用了 CRUD 生成器,它为我的 actionIndex 生成了以下代码 Controller ... public function actionIndex() { $s
在我的用户模型中我有一个函数: public function getRole() { if ($this->role == self::ROLE_USER) { return
我正在构建一个带有 Yii2 框架的 webapp,它将为用户(登录)提供下载管理员预先上传文件的能力。 我已经创建了操作 actionDownload在调用 sendFile() 的特定 Contr
我想在 GridView 中订购图像。我已经使用列表框并成功将图像添加到其中。它的显示如下 但我希望这些图像显示在 GridView 中。可能与否。 请帮助我......提前致谢 最佳答案 出于此类目
我试图通过在 QtQuick 2.0 (Qt 5) 中动态填充 ListModel 来填充 GridView。它可以工作,但应用程序启动速度非常慢: 应用程序窗口立即出现,但大约需要 2 秒才会出现浅
我在 Yii2 GridView 小部件中显示一些列,“执行人员名称”是其中之一,但它应该仅在主管登录时显示,而不是在执行人员登录时显示。 当我将可见值硬编码为零时,它不会显示如下: [ 'l
我想用 HTML 制作一个表格。所以我从数据库中获取了一些数据。 每个项目都是一个用户。用户有用户名、名字、姓氏和电子邮件。我想制作一个表格来列出这些用户。 每个用户都必须换行。我已经在互联网上搜索过
我想在 pjax 处于事件状态的排序 gridview 之后运行脚本。重新加载 gridview 后我找不到任何事件处理程序。 pjax调用和gridview刷新后有没有正确的事件处理方法? 最佳答案
在 WinRT 上,我有一个 GridView 。我想在到达 gridview 的末尾时执行一个方法。 但是,没有像 GridView 那样的事件方法。 我尝试检测对 gridview 的操纵,但似乎
我是一名优秀的程序员,十分优秀!