メモ。
HMTL関係
大枠
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="preconnect" href="https://fonts.gstatic.com" crossorigin>
<link rel="preload" href="https://fonts.googleapis.com/icon?family=Material+Icons" as="style" onload="this.onload=null;this.rel='stylesheet'">
<link rel="stylesheet" href="style.css">
<script src="https://code.jquery.com/jquery-3.6.3.js" integrity="sha256-nQLuAZGRRcILA+6dMBOvcRh5Pe310sBpanc6+QBmyVM=" crossorigin="anonymous"></script>
<script src="js/scripts.js"></script>
</head>
<body>
<div id="wrap">
<header></header>
<main></main>
<footer></footer>
</div>
</body>
</html>
jQueryは一蓮托生になってるので必須。
Material IconsというかWEBフォント周りはpreloadしないとしんどいので<head>に書く。
汎用cssはwp作業が多いので直下。
jsはページ別とか用途別で小分けにすると多いけど総量的には多くないので基本的に一元管理。
#wrapは活躍することはあまりないけど、bodyにclassやstyleを振るのが好きでないので代用の意味がある。
header、main、footerは最近よくやる分け方。これにgrid layoutを使えばやりたいことは賄えてる。
画像
キービジュアル的なものはレスポンシブ対応のためにpicture。スライドショーに突っ込んでも問題ないのが決め手。振り分けない場合も後からsourceを足したいときのためにpictureで書いとく。
<picture>
<source srcset="https://placehold.jp/800x1200.png" media="(max-width: 767.98px)">
<img src="https://placehold.jp/980x560.png" alt="" />
</picture>
いわゆる本文内はfigure。リンクを付けたい場合はこんな感じ。
<figure>
<a href=""><img src="https://placehold.jp/980x560.png" alt="" /></a>
<figcaption><a href="">aaaa</a></figcaption>
</figure>
img自体は使ってるけど、直貼りすることは少なくなった。タグが増えることになるけど棲み分けがわかりやすくなった感じがある。
CSS
/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:0;text-decoration:underline;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type="button"]::-moz-focus-inner,[type="reset"]::-moz-focus-inner,[type="submit"]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type="button"]:-moz-focusring,[type="reset"]:-moz-focusring,[type="submit"]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type="search"]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}
*{box-sizing: border-box;}
body{
font-family: "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
color: #111;
}
@media (pointer: fine){}
@media screen and (min-width: 1200px){}
@media screen and (max-width: 1199.98px){}
@media screen and (min-width: 1024px){}
@media screen and (max-width: 1023.98px){}
@media screen and (min-width: 768px){
.onlySP{ display: none;}
}
@media screen and (max-width: 767.98px){
.onlyPC{ display: none;}
}
cssのリセットは必須。CDNとか別ファイルで読むよりはベタ打ちしちゃったほうがいいかなって思ったり。normalize.cssが好みだけどちょっと古くなったので違うのをやってみてる。
※normalize.cssの方が使い勝手が良かった。
色指定は基本的に、#000やら#fffは使わずに、#111とか#fafafaとかちょっとずらす。真っ黒、真っ白は目が痛い。存外落ち着いた感じになるし、比較がなければ意外とわからない。
:hoverを使う際は@mediaでPCに限定する。スマホとかタブレットとかだと:hover解除は他の領域をタップしないといけないわけで、例えば:hover時に要素を半透明にした場合、何だこれって感じになる。マウスがあるから生きる装飾なので、だから限定しましょうという考え。
レスポンシブの区分けは.98のアレをやる。元々不便は感じてなかったけど紹介記事を読む限りやっておいた方がいいんじゃないかなと思った。CSSで決めたbreakpointに合わせてhtmlやjs上の切り替えもやっていく。
font-familyは好みといえば好み、webフォントは極力使わないのが最近のテーマ。webフォントは重いから時間差で置き換わるのはダルいし、置き換わるまで文字が表示されないケースもある。見出しとか特設ページとか、限定的な使用に留めてる。で、既存フォントは環境で変わるわけだけど、そこまで厳密に統一する必要はないと思ってる。閲覧環境の選択肢が多い状況でガチガチにするほうが変なのではと。「問題なく閲覧できる」が目指すべき形じゃないかなと思う。
昨年末辺りから文字の初期サイズを16pxに変更。サイズ指定はremでやってるので、以下の感じに展開する。
font-size: .75rem; /* 12px */
font-size: .875rem; /* 14px */
font-size: 1rem; /* 16px */
font-size: 1.25rem; /* 20px */
font-size: 1.5rem; /* 24px */
font-size: 1.75rem; /* 28px */
font-size: 2rem; /* 32px */
カスタムプロパティを活用すれば一元管理できる。やっぱり変数は便利。
wpでいうstyle.cssに入れてもいいし、宣言部分だけ独立させたほうが使い勝手がいいという場合もある。
:root{
--sans-serif: "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
--serif: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
--logo: url(img/logo.svg);
}
body{
font-family: var(--sans-serif);
line-height: 1.8;
}
:is(h1,h2,h3,h4,h5){
font-family: var(--serif);
font-weight: 400;
}
js(jQuery)
$(function(){
//ページ内リンク
$('a[href^="#"]').not('a.notscroll').click(function(){
var speed = 500;
var headerHeight = 0;
if(window.matchMedia('(max-width:767.98px)').matches){
headerHeight = $('header').innerHeight();
}
var href= $(this).attr("href");
var target = $(href == "#" || href == "" ? 'html' : href);
var position = target.offset().top - headerHeight;
$("html, body").animate({scrollTop:position}, speed, "swing");
return false;
});
//レスポンシブ切り替え
$(window).on('load resize', function(){
if(window.matchMedia('(max-width:1023.98px)').matches){
}else{
}
})
必ず使ってるのはこの2つ。
ページ内移動ということをわかりやすくするためにスムーススクロールを導入。加えて、ヘッダーを固定表示してる状態でページ内リンクに飛ぶとヘッダーと被ってしまう点を解消する(上記はスマホ表示時にheaderの高さ分を調整する内容)。
レスポンシブの切り替えはブラウザ幅の値で行ってる。幅の取得は色々あるけど、css、htmlでの切り替えタイミングと合わせるためにこの書き方。PCだとスクロールバーの幅のことがあったりするのでちゃんと選ばないと面倒くさいことになる。
ちょっと考えるのがこれ。
外部から来た際にハッシュタグがあったら、ということで。
ヘッダーを固定にしてる場合、通常の動作だとブラウザ上部に該当idの要素が来るのでヘッダーと被ってしまう。それを良しとするところが多いのだけど個人的に気持ち悪い。飛んできて、該当箇所にスクロールさせることで「このページのこの辺りにありますよ」を見せるのは良さげな気がしなくもないんだけど、表示位置の調整ができたらそれで良い気もする。
スクロール動作をさせない場合はこんな感じ。
$(window).on('load',function(){
const hash = location.hash;
if(hash){
setTimeout(function(){
var headerHeight = $('header').innerHeight();
var target = $(hash == "#" || hash == "" ? 'html' : hash);
var position = target.offset().top - headerHeight;
$("html, body").scrollTop(position);
});
}
})
アニメーションさせなくていいと思う。
ページのスクロール禁止ギミック
スマホ表示時のメニューとか、ブラウザいっぱいに表示するポップアップとか、ページ自体がスクロールすると不便な状況がある。その際の対策はcssとjsで構築する。
body.scroll-lock{
position: fixed;
left: 0px;
right: 0px;
top: 0px;
bottom:0px;
}
$(function(){
function bodyScrollLock(){
var scrollHeight = window.pageYOffset;
$('body').toggleClass('scroll-lock');
if($('body').hasClass('scroll-lock')){
$('body').css('top',-(scrollHeight));
}else{
var scrollPosition = $('body').css('top').replace(/[^0-9]/g, '');
$(window).scrollTop(scrollPosition);
$('body').css('top','');
}
}
function bodyScrollUnlock(){
$('body').removeClass('scroll-lock');
var scrollPosition = $('body').css('top').replace(/[^0-9]/g, '');
$(window).scrollTop(scrollPosition);
$('body').css('top','');
}
//表示・非表示の切り替え
$('#btn').on('click',function(){
bodyScrollLock();
$('#target').fadeToggle();
})
//非表示
$('#btn_close').on('click',function(){
bodyScrollUnlock();
$('#target').fadeOut();
})
「pageYOffset」が非推奨になったとかで、「scrollY」を使おうねというのがある。ただし、IE9以前に非対応らしい。互換性をもたせた組み方でやるのが無難だとか。
割と使用頻度が多いので関数化したほうが便利。
発火の度にスイッチする内容と、解除のみの内容があれば賄い切れる。
iframeのレスポンシブ化
iOSでのiframe挙動のことがあるので最適解は決まってる感じ。
<div class="youtube">【埋め込みタグ】</div>
.youtube{
width: 100%;
height: 0;
padding-top: 56.25%; /* 16:9 */
position: relative;
}
.youtube iframe{
width: 100%;
height: 100%;
display: block;
position: absolute;
}
padding-topで縦横比を指定する。
応用で、任意の比率でgoogleマップを埋め込んだりもできる。まあマップは比率を固定する必要はあんまりないと思うけど。
コメント