【Laravel 5.5】WordPress の DB を使ってお勉強。モデルの日時プロパティを楽に扱えるようにする方法

スポンサードリンク


学んだこと

“【Laravel 5.5】WordPress の DB を使ってお勉強。モデルの日時プロパティを楽に扱えるようにする方法” の続きを読む

【Laravel 5.5】WordPress の DB を使ってお勉強。投稿に紐づくカテゴリーを取得して表示する

学んだこと

“【Laravel 5.5】WordPress の DB を使ってお勉強。投稿に紐づくカテゴリーを取得して表示する” の続きを読む

Laravel 5.8 で多対多構造を belongsToMany の引数をほぼ使い尽くしてなんとしてでもリレーションを実現する方法

Laravel 5.8 における belongsToMany の引数まとめ

  • 第 1 引数では最終的な接続先モデル名を名前空間含めて指定する
  • 第 2 引数では中間テーブル名を指定する
  • 第 3 引数では接続元モデル ID を示す中間テーブル内のカラム名を指定する
  • 第 4 引数では最終的な接続先モデル ID を示す中間テーブル内のカラム名を指定する
  • 第 5 引数では接続元モデル ID のカラム名を指定する
  • 第 4 引数では最終的な接続先モデル ID のカラム名を指定する
“Laravel 5.8 で多対多構造を belongsToMany の引数をほぼ使い尽くしてなんとしてでもリレーションを実現する方法” の続きを読む

【Laravel 5.5】WordPress の DB を使ってお勉強。投稿に紐づく投稿者情報をパッと取得する

学んだこと

  • aaa テーブルに xxx_id カラムがある場合、 xxx を取得するには belongsTo() を使う。 aaa モデルクラスで次のように使う。なお、 xxx テーブルのプライマーキーは id とする。
use Illuminate\Database\Eloquent\Relations\BelongsTo;

class Aaa extends Model
{
    public function xxx(): BelongsTo
    {
        return $this->belongsTo('App¥Xxx', 'xxx_id', 'id');
    }
}
  • リレーションへはメソッドとしてもアクセスできるが、プロパティとしてアクセスでき、そのほうが性能が有利になる。なぜなら、実際にアクセスされた時にだけそのリレーションのデータはロードされる (遅延ロード) ため。
  • Eagerロード で N + 1 問題を回避できる。今回の例では、投稿一覧の取得で 1 回、取得できた 5 件の投稿の各ユーザを取得するのにさらに 5 回、 SQL が発行されていた。それを、 Eager ロードすることによって、 2 回の SQL 発行へ減らすことができた。
“【Laravel 5.5】WordPress の DB を使ってお勉強。投稿に紐づく投稿者情報をパッと取得する” の続きを読む

【Laravel 5.5】WordPress の DB を使ってお勉強。フロント側に投稿 (Post) の投稿ステータス (post_status) の日本語を表示したい。

学んだこと、気をつけたことまとめ

  • 既存の属性を元に算出した、新しい値をアクセサを使用し返す
  • フロント側で投稿ステータスの値を判定して対応する日本語を表示、というようなことは絶対に行わない。ビューにロジックが入り込んでしまい読みづらく複雑になってしまうし、同じ内容を必要な回数分コピペしなければならなくなるため。
  • 投稿ステータスの日本語名は、定数ファイル (例えば config/const.php) に入れるのではなく、投稿モデル (app/Models/Wp/PostType/Post.php) に持たせた。投稿ステータスを調べたい、加工修正したい時に最も知っているべきで存在しても違和感のないしっくりくる場所が投稿モデルなため。

やりたいこと

  • フロント側に投稿 (Post) の投稿ステータス (post_status) の日本語を表示したい。
“【Laravel 5.5】WordPress の DB を使ってお勉強。フロント側に投稿 (Post) の投稿ステータス (post_status) の日本語を表示したい。” の続きを読む

Nginx で 80 と 443 ポートアクセスを両方とも受け付けて共存させる設定

ポイントと設定内容

  • server ディレクティブに 80 と 443 の両方の listen を書くだけ。
server {
    listen 80;
    listen 443 ssl;
... 略 ...
}

ちなみに、 80 番ポートへのアクセスを 443 番ポートへのアクセスに強制する設定

“Nginx で 80 と 443 ポートアクセスを両方とも受け付けて共存させる設定” の続きを読む

【Laravel 5.5】WordPress の DB を使って管理者の投稿一覧ページ作りを通してお勉強

やりたいこと

  • WordPress の データベース構造をそのまま使って、管理者の投稿一覧ページを作りたい。 Laravel 5.5 を使いたい。

学んだことまとめ

WordPress

Laravel 5.5

“【Laravel 5.5】WordPress の DB を使って管理者の投稿一覧ページ作りを通してお勉強” の続きを読む

Mac に Rust 言語を本家のやり方に素直に従ってインストールと getting started した記録

環境等

$ sw_vers
ProductName:    Mac OS X
ProductVersion: 10.14.5
BuildVersion:   18F132
$

インストール方法

“Mac に Rust 言語を本家のやり方に素直に従ってインストールと getting started した記録” の続きを読む

Laravel 5.5 で Laravel Mix での設定で Bootstrap 4 を使えるようにする

まとめ

  • Laravel 5.5 の package.json には、 "bootstrap-sass": "^3.3.7" とあり、 Bootstrap のバージョンが 3 である。これを 4 にした。
  • bootstrap-sass のバージョン 4 はなく、 単純な Bootstrap 4 を指定することからか、 package.json 以外の次のファイルの修正が必要となった。
    • resources/assets/js/bootstrap.js
    • resources/assets/sass/_variables.scss
    • resources/assets/sass/app.scss
“Laravel 5.5 で Laravel Mix での設定で Bootstrap 4 を使えるようにする” の続きを読む

StyleCI の Laravel プリセットの各ルールが、 PHP-CS-Fixer のどのルールに対応するかをまとめた

Laravel 5.5 の妥協できる PHP-CS-Fixer 設定ファイルが完成した – oki2a24 を作る途中で、 https://styleci.readme.io/docs/presets#section-laravel の各ルールが、 PHP-CS-Fixer のどのルールと対応するのか、それは PHP-CS-Fixer の @PSR ルールや @PhpCsFixer ルールに含まれるか、の対応が知りたいと思い、一覧表にまとめました。

“StyleCI の Laravel プリセットの各ルールが、 PHP-CS-Fixer のどのルールに対応するかをまとめた” の続きを読む