it-swarm-ko.tech

쉼표로 구분 된 분류 용어 목록을 표시 하시겠습니까?

드루팔 7.

내 node.tpl.php에서 분류 용어 목록을 인쇄하려고합니다 (분류 체계를 "채널"이라고 함). 내가 사용하는 경우 :

<?php print render($content['field_channel']); ?>

분명히 작동하지만 인라인으로 가져 오는 가장 좋은 방법은 CSS를 사용하여 왼쪽으로 띄우는 것입니다. 쉼표로 구분하고 싶습니다. 어떤 아이디어?

고마워.

10
Mike

field.tpl.php 또는 theme_field() 을 사용하여 필드 테마를 시도 할 수 있습니다.

예를 들어 (field.tpl.php 사용) :

  1. "modules/field/theme"에서 field.tpl.php를 테마 디렉토리로 복사하십시오.
  2. 해당 파일을 복사하고 이름을 field--field-channel.tpl.php로 바꾸십시오.
  3. 원하는대로 파일을 편집하십시오.

이 작업을 수행하기위한 빠른/더러운 예제로 field--field-channel.tpl.php는 다음과 같습니다.

<div class="<?php print $classes; ?> clearfix"<?php print $attributes; ?>>
  <?php if (!$label_hidden) : ?>
    <div class="field-label"<?php print $title_attributes; ?>><?php print $label ?>:&nbsp;</div>
  <?php endif; ?>
  <div class="field-items"<?php print $content_attributes; ?>>
    <?php foreach ($items as $delta => $item) : ?>
      <div style="display:inline;" class="field-item <?php print $delta % 2 ? 'odd' : 'even'; ?>"<?php print $item_attributes[$delta]; ?>>
        <?php 
          print render($item);
          // Add comma if not last item
          if ($delta < (count($items) - 1)) {
            print ','; 
          }
        ?>
      </div>
    <?php endforeach; ?>
  </div>
</div>

.tpl 파일을 사용하여 여러 가지 방법으로이 작업을 수행 할 수 있지만 이는 하나의 옵션 일뿐입니다. 스타일 대신 클래스를 DIV에 추가하고 인라인 스타일을 사용하는 대신 스타일 시트를 변경하는 것이 좋습니다.

11
Laxman13

텍스트 포맷터 모듈을 이제 Drupal 7, 사용할 수 있으며 사용자 정의 테마 작업없이이 작업을 수행 할 수 있습니다.

11
jhedstrom

theme_field 접근 방식을 사용하는 한 가지 방법이 있습니다 (template.php 파일에 추가).

/**
 * Implements theme_field()
 *
 * Make field items a comma separated unordered list
 */
function THEMENAME_field__NAME_OF_FIELD__NAME_OF_CONTENT_TYPE($variables) {
  $output = '';

  // Render the label, if it's not hidden.
  if (!$variables['label_hidden']) {
    $output .= '<div class="field-label"' . $variables['title_attributes'] . '>' . $variables['label'] . ':&nbsp;</div>';
  }

  // Render the items as a comma separated inline list
  $output .= '<ul class="field-items"' . $variables['content_attributes'] . '>';
  for ($i=0; $i < count($variables['items']); $i++) {
    $output .= '<li>'. drupal_render($variables['items'][$i]);
    $output .= ($i == count($variables['items'])-1) ? '</li>' : ', </li>';
  }
  $output .= '</ul>';

  return $output;
}
7
cdmo

CSS에서만 쉽게 할 수 있습니다.

. field-type-taxonomy-term-reference .field-items .field-item {
 표시 : 인라인 블록; 
 * display : 인라인; 
 * zoom : 1; 
} 
. field-type-taxonomy-term-reference .field-items .field-item : after {
 content : ","; 
} 
. field-type-taxonomy-term-reference .field-items .field-item : last-child : after {
 content : ""; 
} 
4
Steven Wright
2
ipwa
<?php
if ($node->taxonomy) {
    foreach($node->taxonomy as $term) {
        if ($term->vid == 3) { // the id of the vocabulary
            $my_terms[] = l(
                t($term->name),
                'taxonomy/term/' . $term->tid
            );
        }
    }
}

if ($my_terms) { ?>
    <div class="clear-block">
        <div class="terms">
            <?php print implode(", ", $my_terms); ?>
        </div>
    </div>
<?php } ?>
0
brunorios1

구분자와 랩퍼에 대해서도 훨씬 쉬운 분류법 포맷터 모듈을 사용하십시오. http://drupal.org/project/taxonomy_formatter

프로젝트 페이지에서 자세한 내용 :

분류 항목에 대한 사용자 정의 포맷터를 제공하기 위해 작성된 작은 모듈입니다. 기본 포맷터는 둘 다 div로 싸인 용어를 출력합니다. 이 모듈은 요소 유형, 랩퍼 유형, 둘 다에 대한 클래스, 사용 된 구분 기호 및 페이지에 링크되는지 여부를 지정할 수있는 새 포맷터를 추가합니다. 이것은 훨씬 더 사용자 정의 가능한 레이아웃 옵션을 제공합니다.

0
Greta