Я никогда не использовал его, но я думаю, что это возможно. Из QDataGridBase.class.php:
protected function GetHeaderRowHtml() {
$objHeaderStyle = $this->objRowStyle->ApplyOverride($this->objHeaderRowStyle);
$strToReturn = sprintf(" <tr %s>\r\n", $objHeaderStyle->GetAttributes());
$intColumnIndex = 0;
if ($this->objColumnArray) foreach ($this->objColumnArray as $objColumn) {
if ($objColumn->OrderByClause) {
// This Column is Sortable
if ($intColumnIndex == $this->intSortColumnIndex)
$strName = $this->GetHeaderSortedHtml($objColumn);
else
$strName = $objColumn->Name;
$this->strActionParameter = $intColumnIndex;
$strToReturn .= sprintf(" <th %s><a href=\"%s\" %s%s>%s</a></th>\r\n",
$this->objHeaderRowStyle->GetAttributes(),
QApplication::$RequestUri,
$this->GetActionAttributes(),
$this->objHeaderLinkStyle->GetAttributes(),
$strName);
} else
$strToReturn .= sprintf(" <th %s>%s</th>\r\n", $this->objHeaderRowStyle->GetAttributes(), $objColumn->Name);
$intColumnIndex++;
}
$strToReturn .= " </tr>\r\n";
return $strToReturn;
}
Атрибуты задаются с помощью этого метода:
$this->objHeaderRowStyle->GetAttributes()
GetAttributes реализован в QBaseClass, базовом классе для всех классов в системе.
Если вы попробуете $ colMyColumn-> CssClass = 'class_name'; Вы устанавливаете только класс td: - (
После изучения кода я вижу QDataGridBase.class.php при создании тега th, стиль берется из объекта RowStyle, который описывает строку, поэтому тег td Я предполагаю, что это ошибка, и QDataGrid не завершена.
Или вы просто используете html-таблицу в своем представлении или вам нужно улучшить QDataGrid.
UPDATE:
Это способ сделать это:
$objThStyle = new QDataGridRowStyle();
$objThStyle->CssClass = 'custom-th';
$this->dtgArticle->HeaderRowStyle = $objThStyle;
Но это не идеал, поскольку он применяется ко всем тэгам. QDataGridRowStyle должен быть установлен в объекте столбца, а не в сетке данных.
Это яркий пример того, почему мне не нравится, как Qcodo отображает HTML, CSS и JavaScript. Все является объектом, который должен быть установлен в контроллере. По мнению вы можете сделать очень мало. Представьте себе, как просто установить класс в вашем представлении следующим образом:
<th>Column 1</th>
<th>Column 2</th>
<th>Column 3</th>
<th>...</th>