2017-12-15 9 views
0

著者のカスタムタクソノミを使用しています。ユーザーが文字をクリックすると、索引の下にリストが表示されます。すべての本の著者はその文字で始まります。最初の文字:"tax_clauses"フックを使用してクエリをフィルタリングした後でも、 "name_like"を使用して最初の文字でカスタムタクソミー用語を表示しない

<?php global $product; 

$name_like = isset($_GET['character']) ? $_GET['character'] : ''; 
$letters = range('A', 'Z'); 
$term = get_term_by('slug', get_query_var('term'), get_query_var('taxonomy')); 
    $slug = $term->slug; 
?> 

<div id="content-small"> 
    <div class="list-terms"> 

     <div class="alphanav"> 
      <?php foreach ($letters as $letter): ?> 
       <?php if (strtoupper($name_like) == strtoupper($letter)):?> 
        <a class='selected' href="<?php bloginfo('url'); ?>/auteurs/<?php echo $slug ?>?character=<?php echo strtoupper($letter)?>"><?php echo strtoupper($letter)?></a> 
       <?php else: ?> 
        <a href="<?php bloginfo('url'); ?>/auteurs/<?php echo $slug ?>?character=<?php echo strtoupper($letter)?>"><?php echo strtoupper($letter)?></a> 
       <?php endif;?> 
      <?php endforeach;?> 
      <a class="selected set-height" href="<?php bloginfo('url'); ?>/auteurs/<?php echo $slug ?>?character=#">#</a> 
     </div> 
<?php 

$taxonomy = 'auteurs'; 
$queried_term = get_query_var($taxonomy); 
$args = array(
'name__like' => $name_like, 
    'orderby' => 'name', 
    'order' => 'ASC', 
    ); 

$terms = get_terms($taxonomy, $args, 'slug='.$queried_term); 

if ($terms) { 
    $count = count($terms); 
      $i=0; 
      $term_list = '<div class="tab-auteur"> 
    <input id="tab-one-auteur" type="checkbox" name="tabs-auteur"> 
          <label for="tab-one-auteur">La Liste</label> 
          <ul class="bio-list tab-content-auteur">'; 
      //echo '<h2 class="term-letter">'. strtoupper($name_like) . '</h2>'; 

foreach($terms as $term) { 
    $names = $term->name; 
    $unwanted_array = array( 'Š'=>'S', 'š'=>'s', 'Ž'=>'Z', 'ž'=>'z', 'À'=>'A', 'Á'=>'A', 'Â'=>'A', 'Ã'=>'A', 'Ä'=>'A', 'Å'=>'A', 'Æ'=>'A', 'Ç'=>'C', 'È'=>'E', 'É'=>'E', 
         'Ê'=>'E', 'Ë'=>'E', 'Ì'=>'I', 'Í'=>'I', 'Î'=>'I', 'Ï'=>'I', 'Ñ'=>'N', 'Ò'=>'O', 'Ó'=>'O', 'Ô'=>'O', 'Õ'=>'O', 'Ö'=>'O', 'Ø'=>'O', 'Ù'=>'U', 
         'Ú'=>'U', 'Û'=>'U', 'Ü'=>'U', 'Ý'=>'Y', 'Þ'=>'B', 'ß'=>'Ss', 'à'=>'a', 'á'=>'a', 'â'=>'a', 'ã'=>'a', 'ä'=>'a', 'å'=>'a', 'æ'=>'a', 'ç'=>'c', 
         'è'=>'e', 'é'=>'e', 'ê'=>'e', 'ë'=>'e', 'ì'=>'i', 'í'=>'i', 'î'=>'i', 'ï'=>'i', 'ð'=>'o', 'ñ'=>'n', 'ò'=>'o', 'ó'=>'o', 'ô'=>'o', 'õ'=>'o', 
         'ö'=>'o', 'ø'=>'o', 'ù'=>'u', 'ú'=>'u', 'û'=>'u', 'ý'=>'y', 'þ'=>'b', 'ÿ'=>'y'); 
$firstname = substr($names, strpos($names, ",") + 1); 
$arr = explode(",", $names, 2); 
$lastname = $arr[0]; 
$lastname = strtr($lastname, $unwanted_array); 
$lastname = strtoupper($lastname); 
$comma = ','; 
$whichname = strpos($names, $comma); 

if ($whichname === false) { 
$full = strtoupper($names); 
} else { 
$full = $lastname . ', ' . $firstname; 
} 

$i++; 
       $term_list .= '<li><a href="'.get_term_link($term->slug, 
$taxonomy).'?character='. $name_like .'">' . $full . '</a></li>'; 
      if ($count != $i) { 
        $term_list .= ''; 
       } 
      else { 
        $term_list .= '</ul></div>'; 
       } 
      } 
      echo $term_list; 

} 
else { 
    echo '<ul class="bio-list">PAS DE AUTEURS</ul>'; 
} 
?> 
</div> 

私は多くのことを研究し、「name_like」の動作はWordpressの新しいバージョンで変更されたこのpostの助けを借りて、私は用語を使用しました。

function llps_filter_term_clauses($clauses) { 
    remove_filter('term_clauses','llps_filter_term_clauses'); 
    $pattern = '|(name LIKE)\'%(.+%)\'|'; 
    $clauses['where'] = preg_replace($pattern,'$1 \'$2\'',$clauses['where']); 
    return $clauses; 
} 

add_filter('terms_clauses','llps_filter_term_clauses'); 

、それが働いていた - 私はそれがなかったと確信している...私はプロジェクトにログオンし、次の時間まで:_clausesは私のfunctions.phpファイルにクエリをフィルタリングするフック。それはもはや働いていないと私は私の人生の理由を理解することはできません!

答えて

0

私は同じ問題がありました。おそらく最新のWPバージョンで何かが変わったでしょう。あなたは私がすることをしなかった理由を確認したい場合は

$pattern = '|(name LIKE)\'{.*?}(.+{.*?})\'|'; 

:この中

$pattern = '|(name LIKE)\'%(.+%)\'|'; 

:私はこれは私がそれを固定する方法である4.9.1

に問題をしました、私はこれを変更しましたpreg_replaceの前と後に$句を一時的に表示することをお勧めします。私はあなたのコード内でこのような何かを意味:

function llps_filter_term_clauses($clauses) { 
    echo '<pre>';print_r($clauses);echo "\n"; 
    remove_filter('term_clauses','llps_filter_term_clauses'); 
    $pattern = '|(name LIKE)\'%(.+%)\'|'; 
    $clauses['where'] = preg_replace($pattern,'$1 \'$2\'',$clauses['where']); 
    print_r($clauses);die(); 
    return $clauses; 
} 

あなたは演算子LIKE SQLの典型的な「%」は何かにWPによって変換されていることを確認する必要があります

ここ{be8aacdf46dd49d9036fd16c13613bf303​​6378f188b3535c3416ae7d88844d20} あなたの手紙 {be8aacdf46dd49d9036fd16c13613bf303​​6fd16c13613bf303​​6378f188b3535c3416ae7d88844d20}

{}内の文字列です。そのため、フィルタの正規表現を変更しました。お役に立てれば。

+0

ありがとうございました!完璧に動作します。 – hel2695

関連する問題