投稿者: admin Page 26 of 46

WordPressの投稿にカスタムフィールド(wp-postmeta)の値を手軽にJOINして取得する。&JSONへ変換

WordPressで投稿のデータにカスタムフィールドを加えて取得する。(全文)

<?php
$posts_join_keys = array();
$posts_join_prefix = 'tmp_join_table_name_';
add_filter('posts_join', 'posts_more_join' );
add_filter('posts_fields','posts_more_fields');
function posts_more_join( $join )
{
 global $posts_join_keys,$posts_join_prefix;
 foreach($posts_join_keys as $key => $k){
 $alias = $posts_join_prefix.$k;
 $join .= sprintf(" INNER JOIN wp_postmeta as %s ON ( wp_posts.ID = %s.post_id AND %s.meta_key = '%s' )",$alias,$alias,$alias,$k);
 }
 return $join;
}
function posts_more_fields($fields){
 global $posts_join_keys,$posts_join_prefix;
 foreach($posts_join_keys as $key => $k){
 $alias = $posts_join_prefix.$k;
 $fields .= sprintf(',%s.meta_value as %s',$alias,$k);
 }
 return $fields;
}
$posts_join_keys[] = 'locate';
$posts_join_keys[] = 'description';
$args = array(
 'posts_per_page' => -1,
 'fields'=> 'wp_posts.ID,wp_posts.post_title',
 'meta_query' => array(array(
 'key' => 'locate',
 'value' => '',
 'compare' => '!='
 ))
);
$query = new WP_Query( $args );
$posts = $query->get_posts();
wp_reset_postdata();
$json = '{data:'.json_encode($query->get_posts()).'}';
?>

上のプログラムの $posts_join_keysに取得したいカスタムフィールドの’meta_key’を追加(push)していけばその分取得できます。

$posts_join_keys[] = 'locate';
$posts_join_keys[] = 'description';

WordPressのシンプルなページネーション(ページ番号)リンク

プラグインなどをつかわずにできるシンプルなページネーション(ページ番号)のリンクのテンプレートです。

WordPressテンプレート

<div class="pagenation">
    <ul>
        <?php
        $page_current_num = (!empty($paged))? $paged:1;
        $page_last_num = $wp_query->max_num_pages;
        if($page_current_num > 1){
            echo sprintf('<li class="prev"><a href="%s">%s</a></li>',get_pagenum_link($page_current_num-1),'PREV');
        }
        $page_start_num = $page_current_num - NUM_PAGENATION_BEFORE_AFTER;
        if($page_start_num < 1) $page_start_num = 1;
        $page_end_num = $page_current_num + NUM_PAGENATION_BEFORE_AFTER;
        if($page_end_num > $page_last_num) $page_end_num = $page_last_num;
        for($i = $page_start_num;$i<=$page_end_num;$i++){
            if($page_current_num==$i){
                echo sprintf('<li class="active">%s</li>',$i);
            }else{
                echo sprintf('<li><a href="%s">%s</a></li>',get_pagenum_link($i),$i);
            }
        }
        if($page_current_num < $page_last_num){
            echo sprintf('<li class="next"><a href="%s">%s</a></li>',get_pagenum_link($page_current_num+1),'NEXT');
        }
        ?>
    </ul>
</div>

CSS(SASS)

//---------------------------------------------------pagination
.pagenation
  padding: 40px 0
  margin: auto
  display: table
  &:after
    clear: both
    content: "."
    display: block
    height: 0
    visibility: hidden
  ul
    &:after
      clear: both
      content: "."
      display: block
      height: 0
      visibility: hidden
    text-align: center
    margin: auto
  li
    float: left
    list-style: none outside none
    margin-left: 3px
    &:first-child
      margin-left: 0
    &.active
      background: #336699
      color: #FFF
      cursor: not-allowed
      padding: 10px 20px
    a
      background: #F2F2F2
      color: #336699
      display: block
      padding: 10px 20px
      text-decoration: none
      &:hover
        background-color: #A1AABA
        color: #FFF
        opacity: 0.8
        transition-duration: 500ms
        transition-property: all
        transition-timing-function: ease

WordPressでカスタムフィールドの値の抜粋を取得する

function get_sub_fields_excerpt_more($key,$limit=30){
    $str = get_field($key);
    $len = mb_strlen($str,ENCODING);
    if($len > NUM_EXCERPT_SLIDER){
        return mb_substr($str,0,NUM_EXCERPT_SLIDER,ENCODING).'...';
    }else{
        return $str;
    }
}

NUM_EXCERPT_SLIDER,ENCODINGは、文字数,文字コードの定数

WordPressで特定のカスタムフィールドが入力されている記事をランダムに取得

WordPressで特定のカスタムフィールドが入力されている記事をランダムに取得する方法です。WP_Query関数を利用

ACF(Advanced Custom Fields ver 4.4.11) ローカル管理画面などでGoogleMapが表示されない。

WordPressプラグイン ACFをローカル管理画面でGoogleMapが表示されない。

/wp-content/plugins/advanced-custom-fields/core/fields/google-map.php の293行目当たりの ‘key’にGoogle API Consoleで取得したAPIKey(制限なし)をいれて解決(とりあえず!
※制限なしだと危険なのであくまで一時的。
※プラグインのバージョンアップでソースが上書きされることへの対策が必要

##エラー発生の環境など

– ローカル
– ドメインは http://hogehoge.dev を /etc/hosts にてローカル(127.0.0.1)に向けている。
– ACFのバージョンは 4.4.11
– 一瞬ちらっと地図がでるがエラー表示に切り替わる

WordPressのqTranslateXプラグインでサブドメインモード(Pre Domain Mode)にすると、CSSのicomoonの@font-face読み込みでクロスドメイン誓約(Access-Control-Allow-Origin)でエラー

言語切替時にドメインが http://example.com  >> http://en.example.com などに切り替わったときにCSSでしている@font-faceの読み込みがエラーになってしまった。
フォント関係ファイルへのクロスドメイン制約を外して対応。

<FilesMatch "\.(ttf|eot|woff|svg)$">
 <IfModule mod_headers.c>
 Header set Access-Control-Allow-Origin "*"
 </IfModule>
</FilesMatch>

(ローカルにhostsで割り当てた際に発生、運用のサーバーで確認し追記よてい、取り急ぎメモ)

 

qTranslate-X(バージョン 3.4.6.8) のサブドメインでの切替設定でデフォルトの言語に戻れない現象

WordPressの多言語プラグイン ‘qTranslate-X’  (バージョン 3.4.6.8) で言語(デフォルト)へと切り替わらない現象があり解決できたのでメモ。

上手く言った方法 (URL変更モード : User Per-Domain mode )

screen-shot-2016-12-14-at-2-31-24-am

×上手できなかった方法 (URL変更モード : 事前ドメインモード )

bd8b40d8-5aef-41e0-95a3-afc790f98975

PHPStorm(WebStorm)でのSCSS/Compassの自動コンパイル設定(Mac OS EI Capitan)

メニューの[Prefrerence]からパネルを開く。

コンパスの有効化

978bbc83-13e4-46f0-9e92-b4b34f921207

File Watchersの設定(変更があった場合に自動コンパイルするファイルタイプ関連の設定)

(scss)

52151a2d-060b-460a-9238-b301293c7bd1

(sass)

screen-shot-2016-12-13-at-11-40-19-am

Program : /usr/local/bin/compass
Arguments : compile
Working directory : $FileDir$
Environment variables : (空)
Output paths to refresh : $FileParentDir$/css/$FileNameWithoutExtension$.css

※追記 : sassファイルが多くなって更新時に編集中のファイルのみをコンパイルしたい場合は、Arguments : compile $FileName$ と指定すると良いです。

 

PHPStormでつかってますが、コードヒントが出てくれて便利です。@includeで一覧したり、

screen-shot-2016-12-13-at-11-21-50-am

先頭数文字タイプすると候補が絞込まれて、その引数も見れたり

screen-shot-2016-12-13-at-11-24-54-am

さらに @includeで書いたmixinの部分を Cmd+クリックで compassのソース(mixin)が見れたり。

screen-shot-2016-12-13-at-11-26-51-am

なかなか便利、wordpressなどの関数も数文字タイプで候補に上がったりで便利すぎて
手放せない開発環境になっています。
(Atom,Sublime,Aptanaとかもどうなのか時間があれば調べてみたいがなかなか><)

CakePHPでHasManyのテーブルをカンマ区切りで取得(MySQL GROUP_CONCAT関数)

Modelのバーチャルフィールドに設定しちゃっておくとラク。

public $virtualFields = array(
 'tags' => '(select group_concat(Tag.name) from tags as Tag where Post.id = Tag.post_id)'
);

負荷とか考えて普段ははずしておきたい場合は動的に $Model->virtualFieldsは動的に変更できるのでその都度設定すれば問題なさそうです。

ただ、FIND_IN_SETでの検索が $Model->find() の ‘conditions’パラーメータでは実現できなかった。なにか方法あるのかなぁ。

今回は単純な Yearな数字だったたので 無理やり LIke %%で処理 (うーん。

GoogleChromeの検索結果をキーボードで操作

1 . Googleアカウントの設定のページヘ移動

https://www.google.com/preferences

2 . インスタント検索の結果を常に表示する を選択

Screen Shot 2016-09-04 at 4.50.55 PM

 

 

Page 26 of 46

Powered by WordPress & Theme by Anders Norén