知っておくと便利なcssの小技 part9

  • このエントリーをはてなブックマークに追加

こんにちは、工藤です。
今回は個人的に知っておくと便利だなと思うcssの小技part9です。

バックナンバー



ナビをhoverしたときに、中央から線を出す

img01

ナビなどをhoverしたときに、テキスト下部の中央から線が表示されるあれです。
なんとなくおしゃれになります。
ソースは一見複雑そうですが、登録しておけばちょっとだけ値などを変えるだけで簡単に実装できます。

DEMO

HTML


CSS


装飾自体はaタグに行っていきます。

14行目

このあとabsoluteを使うので、aタグに『position: relative;』を設定しておきます。


16行目

aタグの『::after』に設定していきます。『::after』用の『content: “”;』を忘れずに。


18~25行目

ここはラインの設定です。
まずは『absolute』でaタグ内の好きな位置に置けるように設定します。
次に『background』などで色の指定をします。borderを使うわけではないのでテクスチャを使ったラインなども引けます。
20~25行目でラインの大きさ、位置を調整しています。
『left: 0』;と『right: 0;』、『margin: 0 auto;』で中央配置にしているのは、今回『width: 50%;』にしてラインの長さを短くしたためです。
例えば『width: 100%;』にした場合にはleftとbottomのみでの位置設定で大丈夫です。
あとは『height』で好きな高さを設定するのも忘れずに。


26~28行目

『transform』でhoverしていない時のラインのサイズを設定します。
hoverしていない時は何も見えていない状態なので『0』を指定します。


29~31行目

『transition』でスピードの設定をします。


33行目~

hoverしたときの設定なので、26~28行目で0にした『transform』の値を『1』にします。
これでhover時に中央から線が出てくるナビの完成です。

ちなみに34行目の『ul.naviList li.now a::after』は開いているページに対して、線をそのまま引いておきたい時の記述です。
いらない場合は取ってしまってください。



背景を固定する

img02

パララックス(のような)サイトで見られる、スクロールしたときに背景が固定されているあれです。
数行の記述で実現できます。

DEMO

HTML


CSS


3行目

背景画像を設定します。この時『background-size:』『cover』等を設定します。


4行目

背景固定用のcssの『background-attachment: fixed;』を設定します。
これだけで簡単に背景固定ができます。

執筆者:工藤[ WEBデザイナー ]

WEBデザイナー。 最近はWordPressを触るのが好きです。よろしくお願いします。

関連記事

プログラミング

SharePoint REST APIを使用してリストの情報を取得し、headerにナビを作る

SharePointで作成したリストの情報をREST APIを使用して取得してみましょう。 今回は、APIで取得した情報を、headerにリンクとして差し込んでみます。サイト全体共通のナビでも、リストを使用すると、一か所で管理できるので便利です。 目次1 前提条件2 1.REST APIで情報を取得2.1 REST APIのURL2.2 データを取得する処理3 2.取得した情報をheaderに表示 前提条件 SharePoint Online モダンUI カスタムJSが使用で […]

WordPress

WordPressで権限やユーザーごとに管理画面のサイドメニュー表示を切り分ける

デフォルトだといろいろな項目が表示されているWordPressの管理画面のサイドメニュー。 慣れていない人にはわかりづらいですよね。 また、権限によってデフォルトで非表示にしてくれたりもしますが、この部分は見せたくないな…ということも多いと思います。 今回はWordPressで権限やユーザーごとにサイドメニューの表示を変更する方法をご紹介します。 目次1 権限の種類について2 function.phpに記述する2.1 サイドメニューの非表示用のコード2.2 権限ごとに振り分け […]

プログラミング

jQuery+PHPで大容量ファイルを分割アップロードするお話

ファイルのアップロードを行う際に注意しないといけないのが「アップロード容量」と「タイムアウト」です。 どちらもサーバーの設定に関わるところでレンタルサーバーでは対処しきれないところもあり、大容量にするとそれだけアップロードに時間がかかりタイムアウトが発生しやすくなります。 そこでフロント側で分割してファイルをアップし、バックエンド側で受け取った後に結合するようにするとよいでしょう 注意すべき点として通常のPOSTでの送信ではないため、あらかじめそこら辺を考慮した処理が必要とな […]

株式会社8bit (エイトビット)

東京都目黒区でWebサイト制作、Webシステム開発などを行っております。
コーポレートサイトやWebサービスの企画・提案を得意としており、自社での経験を元にアイデアをカタチにするお手伝いをさせていただいております。

Web制作に関するご相談はお気軽にどうぞ

弊社に制作をご依頼いただく際の費用感をご確認いただける、
見積りシミュレーションをご用意いたしました。