お仕事・制作日記

このサイトのリニューアル2018

久しぶりのリニューアル。目的は2つありました。

  • MovableTypeからWordPressに移行する
  • Webレスポンシブに(再)対応する

MovableTypeからWordPressに移行

個人的にはMovableTypeは、まっさらな状態からコーディングする身としてはとても扱いやすかったのですが、CMSを扱う案件の中では、少なくともここ3、4年、一度もMovableTypeを扱うことはなく、すべてWordPressでした。CMSを扱う新規案件では、まずWordPressで提案しています。

さよなら、MovableType

というわけで、このサイトもWordPressに移行することにしました。

Webレスポンシブに(再)対応

このサイトは「Webサイト制作に関する情報」とい特性から、ほとんどのユーザーは平日の9:00から18:00まで、デスクトップによる利用がほとんどです。スマホが登場したときには、スキル試しということでWebレスポンシブにしていたのですが、それ以降のリニューアルでは、Webレスポンシブにはしていませんでした。
ただ、一つの制作サンプルとして、やはりWebレスポンシブ対応にした方がいいな、と対応し直すことにしました。

技術的なところでは、CSSで、単位は、vm と em を多用していることと、BEMのCSS設計を取り入れていることが特徴です。また、Gulpを導入することで、クロスブラウザ対応やファイルの軽量化を簡単に実現しています。

大まかな制作フロー

  1. ローカル環境を作って、WordPressを導入する
  2. MTのデータを管理画面からエクスポートする
  3. ローカルのWordPressにMTのデータをインポートする
  4. ローカル環境で、デザインの調整やら一通り制作する
  5. 本番環境にステージング用のドメインを用意し、そちらにローカル環境と同じものを構築する
  6. 本番の参照先をステージングと同じにする

ローカル環境を作って、WordPressを導入する

ローカル環境はMAMPで作りました。そこにWordPressをインストール。
MAMPをご存知ではない方、「ローカル環境MAMPにWordPressをインストール」という記事を書いていますのでよかったらそちらもチェックしてみてください。

MTのデータを管理画面からエクスポートする

管理画面の「ツール」→「記事のエクスポート」を選択します。これにはカテゴリ情報もコメント情報も含まれています。

ローカルのWordPressにMTのデータをインポートする

MTの「本文」と「続き」が、WordPressでは「本文」にまとまるので注意です。必要に応じて、エクスポートしたテキストデータをCSSでレイアウト修正しやすいように、続きの前後にタグを追加しておくと便利です。

WordPressの「ツール」→「インポート」で、Movable Type と TypePad にある「インポーターの実行」を選択し、画面の指示に従っていくとファイルを選択する画面になるので、エクスポートしたファイルを選択します。

たったこれだけでほぼ完了!残りは、各ページのURLをリニューアル前後は同じにすること。このサイトの場合を例に対応したことのメモです。

パーマリンクを変更する
「設定」→「パーマリンクの設定」で共通の項目は、カスタム構造にチェックを入れ、「/%category%/%postname%.html」にしました。
カテゴリページのURLを変更する
デフォルトでは、カテゴリページには、「/category/xxx」というのが入力されてしまいます。そのため、「/category/」はなしにしたいのですが、やり方はググると色々紹介されていましたが、自分はプラグインを入れて解決しました。
プラグイン「No Category Base (WPML)」
カテゴリ名
残念なことに、カテゴリ名については階層とベースネームは引き継いでいませんでした。デフォルトのまま調整しようとするときっとストレスしか感じないかもしれません。プラグインを使うことでMTのときと同じようなドラッグ&ドロップで調整できてよかったです。
プラグイン「Category Order and Taxonomy Terms Order」
画像などの資材
MTで管理せずに直接サーバーにアップロードしたファイルをうっかり忘れるところでした。同じパスで閲覧できるように、管理外のファイルをコピーします。

ローカル環境で、デザインの調整やら一通り制作する

このサイトの場合は、このサイト専用にテーマごと作成。ファイル構成は、トップ、カテゴリ一覧、検索結果ページ、記事ページ、固定ページ、エラーページというシンプルな構成で共通要素も多く、凝った仕様にしていないため、自由自在にできました。

本番環境にステージング用のドメインを用意し、そちらにローカル環境と同じものを構築する

ローカル環境で一通りの制作が完了したら、いよいよ本番反映です。ただし、いきなり本番反映は危険です。今回は新規DBにデータ移行も関わるので、閲覧できなくなる時間も発生してしまいます。そこで、本番環境にステージング用のドメインを用意し、そちらにローカル環境と同じものを構築します。

本番の参照先をステージングと同じにする

一旦、本番を参照先をステージングにすることで、もし問題が起きてもすぐに差し戻せるようにすることができます。その際に、管理画面の「設定」→「一般」のアドレス(URL)をステージングから本番に変更します。変更することで管理画面は見れなくなりますが、本番の参照先を認識するまでの間です。本番に参照先が変更され、問題ないことが確認できたら、ステージング用のドメインを削除して終了です。

ハマったこと

コメント通知が有効にならない。結局、これはgmailではないメールアドレスを設定することで解決したのですが、根本的な原因は今も分かっていません、、。ここだけで2、3時間ハマってしまった、、、無念。

それ以外は元々はシンプルな構成であることが幸いして、すんなりWordPress化、Webレスポンシブ対応することができました。

後追いで対応すること

  • SNSボタンの設置
    設置し忘れてました、、プラグインを試してみようかと思います(デザイン調整考えたらプラグインよりオリジナルで作った方が早い気も?!)。
  • トップページ
    もうちょっとトップページ感を出そうかと思います。
  • デザイン
    もうちょっとデザイン入れようかな
  • 閲覧数・ランキング
    GoogleアナリティクスのAPIを使って、1日1回ランキングを生成するようにしたいと思います。

最近の記事

投稿を公開したときに指定したページにアクセスする

この記事では「管理画面で投稿やカスタム投稿の公開ステータスを更新したときに何かしらの処理をする」方法の備忘録です。 functions.php を修正し・・・

WordPress

ローカルフォントをWebフォント指定する

Google Fonts はとても便利だが、適用するまでの遅延が気になったので、同様の効果をローカルにあるフォントを利用して実現させる。 事前に用意する・・・

CSS

[ソフト] Web font用のwoff、woff2にフォントを変換する無料サービス

WOFFコンバータ ダウンロードhttps://opentype.jp/woffconv.htm 以下、リンク先の「概要」を抜粋。 フォント・・・

CSS

JSON

JSON.parse() 配列とオブジェクトのリテラル記法を組み合わせた文字列をデータとして取り扱えるようにする。 // JSONデータ let ・・・

JavaScript

いろいろな判定

真の場合。偽の場合は、!== を使う。 プリミティブ値の判定 文字列の判定 if (typeof a === 'string') {} ・・・

JavaScript

Custom Post Type UI で 投稿画面にタクソノミー が表示されなくなった場合 → REST API

数ヶ月前、WordPress本体をバージョンアップして、エディタがガラリと変わった。その際、それまでサイドナビに、Custom Post Type UI(CP・・・

WordPress

なるほどデザイン

書籍「なるほどデザイン」を読んだときにメモしたノートが出てきた。3, 4年前に読んだ本。テキストのみで備忘録として残しておくが実際はイラストと合わせ・・・

デザイン

グーグルの考えるデザインガイドライン

使えるデザインになっている?→ デザインは正しいインプットによって、人の暮らしや夢を助けるツールサクサクと動く、機能するデザインになっている?→ デザインが機・・・

デザイン

売れるデザイン

書籍「売れるデザインのしくみ」を読んだときにメモしたノートが出てきた。3, 4年前に読んだ本。2009年に出版されたと知って驚き。10年前と言えば、・・・

マーケティング・ブランディング

スタバに学ぶ。

書籍「スターバックスはなぜ値下げもテレビCMもしないのに強いブランドでいられるのか?」を読んだときにメモしたノートが出てきた。3, 4年前に読んだ本。20・・・

マーケティング・ブランディング

人気の記事

overflowをautoにした要素のスクロール位置を変更する → scrollTop scrollLeft

まずはサンプル。 これは、overflowをautoにした要素のスクロール位置を変更するサンプルです。 これは、overflowをautoにした要素のスクロ・・・

JavaScript

iframeの高さを自動調整する

iframeで呼び出した際、iframe自体はスクロールさせずに高さを取得してiframe全体を表示させます。 サンプル:iframeの高さを自動調整するデモ・・・

JavaScript

WP_Queryを使って絞り込み検索するのにコレは便利!

めっちゃ参考になるページを見つけた。 絞り込みをするたびに色々ググっていたが、これがあればほとんどのことが解決できそうな気がする。 参考: これは便利!Word・・・

WordPress

http://localhost:8888/ → http://localhost/

http://localhost:8888/ での参照ではなく、http://localhost/ で参照できるようにします。 MAMPの設定を変更する M・・・

MAMP

イラストレーターでレイヤーごとにPNGで書き出す

【2020年07月13日】 macOS Catalina(10.15.5) / Adobe iLLustrator 2020(24.2.1) にて動作確認済・・・

Illustorator

背景画像の拡大・縮小 → background-size !

W3Cで「モジュール背景とボーダー」について2011年2月15日付けで更新されてますね。 CSS3では、背景画像の幅・高さを拡大・縮小するプロパティが追加され・・・

CSS

アーカイブページでカスタムフィールドやタクソノミーで絞り込みした状態でリスト表示する

<?php $args = array( 'paged' => 1, 'posts_per_page' => 20, 'post・・・

WordPress

Advanced Custom Fields を使った条件分岐(セレクトボックス、チェックボックス、ラジオボタン、真偽)のテンプレート記述方法

前回、「入力フォームを自由にカスタマイズできる「Advanced Custom Fields」」で基本的なフィールド名を出力方法を紹介したが、今度は条件分岐に関・・・

WordPress

WordPressのカテゴリー一覧ページでカテゴリー名とスラッグを取得する → get_queried_object()

やりたいこと カテゴリー一覧ページで、そのカテゴリー一覧ページに属する記事一覧を取得するためにループさせるのとは別に、タイトルやカテゴリー別にデザインを変・・・

WordPress

カウントアップ、カウントダウンするJavaScript

ポイントを使ったり、増やしたりしたときに、結果のポイント数に差し替えるのではなくて、カウントアップしたり、カウントダウンして動的に動かそうと思って作ってみた。・・・

JavaScript

運用情報お仕事・制作日記このサイトのリニューアル2018 | シンプルシンプルデザイン