拙作 Blogger テーマの F-light リリースから2ヶ月。ユーザーは徐々に増えつつはあるもののまだまだ少なく、カスタマイズについて書かれている方もいないようですので、作者おすすめのカスタマイズを紹介したいと思います。
デモサイトの紹介記事に書かれていない事とか、アップデートで実装するほどでもなかったり、ユーザーによって好みが分かれることなどを。
注意事項
HTMLを編集しますので必ず予めバックアップを取ってから行って下さい。
2024/7/10 現在、最新の F-light は v1.37 です。古いバージョンをお使いの方は最新バージョンにアップデートすることをおすすめします。
追加の CSS コードを挿入する位置
特に指定がない場合は/*==== ユーザー カスタム CSS ====*/の直下に追記して下さい。
ガジェットや項目を非表示
一部のガジェットや項目の表示・非表示はレイアウトページでは変更できないため、非表示にするには CSS で display:none にする必要があります。
記事ヘッダー(投稿日、更新日、コメント数)を非表示
#p-header {
display: none!important;
}
目次を非表示
#toc,
#backtoc{
display: none!important;
}
SNS シェアボタンを非表示
.sns-share-buttons {
display: none!important;
}
ラベルを非表示
#p-category,
#p-hashtag {
display: none!important;
}
関連記事を非表示
#related-posts {
display: none;
}
トップページ記事一覧、注目の投稿、人気の投稿の投稿日とコメント数を非表示
/*記事一覧投稿日を非表示*/
#Blog1 .article-header {
display: none;
}
/*注目の投稿投稿日を非表示*/
#FeaturedPost1 .article-header {
display: none;
}
/*人気の投稿投稿日を非表示*/
#PopularPosts1 .article-header {
display: none;
}
/*上記全ての投稿日をまとめて非表示*/
.article-header {
display: none;
}
トップページ記事一覧のスニペットを非表示
.article-snippet {
display: none;
}
カードレイアウトの場合は以下の CSS も追記してください。(タイトルと投稿日が被ってしまうのを回避するため)
.article {
padding-bottom: 10px;
}
ちなみに「注目の投稿」のスニペットに関しては、レイアウトページの設定で表示・非表示を切り替えられます。
目次のオプション
デフォルトで開いた状態に
以下のコードを変更します。「!」を削除するだけです。
s.open=!1
↓↓変更s.open=1
目次を生成する見出しの数を変更
デフォルトでは見出し3つ以上で生成される様になっていますが、この数を変更するには以下の箇所の数値を変更します。
if(a.length<3)
更新日だけ表示
先日 Twitter でたまたまこんな記事がシェアされているのを見かけました。投稿日よりも更新日の表示を優先させた方がアクセスが増えるらしいという内容。実際の所 SEO に効果あるのかどうかは検証していないのでわかりませんけど、参考までに F-light でのカスタマイズ手順を書いておきます。
Tanweb.netブログ記事の更新日を優先して Google 検索に知らせると SEO に効果アリ!(SANGO用カスタマイズ)記事をどんなに新しい情報へとリライトしても、Google 検索結果の日付は投稿日のままなので、期間検索の新しい日付には(新しい情報なのに)登場しないのだ。今回は「ブログ記事は投稿日よりも更新日を優先させて Google 検索にお知らせして欲しい!」をブログします。https://tanweb.net/2018/08/11/22585/
カスタマイズ手順
まずこのコードを検索で探します。
<span id='p-header'>このすぐ下のコード (<time expr:datetime= から </b:if> まで) を変更します。
<time expr:datetime='data:post.date.iso8601' id='p-header-pdate'><svg aria-label='カレンダー' class='svg svg-calendar-days' style='vertical-align:-10%;margin-right:5px'><use href='#svg-calendar-days'/></svg><data:post.date.year/>/<b:eval expr='data:post.date.month lt 10 ? "0" + data:post.date.month : data:post.date.month'/>/<b:eval expr='data:post.date.day lt 10 ? "0" + data:post.date.day : data:post.date.day'/></time>
<b:if cond='data:post.date.year != data:post.lastUpdated.year or data:post.date.month != data:post.lastUpdated.month or data:post.date.day != data:post.lastUpdated.day'>
<span id='p-header-udate'>|<svg aria-label='更新日' class='svg svg-arrows-rotate' style='margin:0 5px'><use href='#svg-arrows-rotate'/></svg><data:post.lastUpdated.year/>/<b:eval expr='data:post.lastUpdated.month lt 10 ? "0" + data:post.lastUpdated.month : data:post.lastUpdated.month'/>/<b:eval expr='data:post.lastUpdated.day lt 10 ? "0" + data:post.lastUpdated.day : data:post.lastUpdated.day'/></span>
</b:if>
↓↓変更
<b:if cond='data:post.date.year != data:post.lastUpdated.year or data:post.date.month != data:post.lastUpdated.month or data:post.date.day != data:post.lastUpdated.day'>
<time expr:datetime='data:post.lastUpdated.iso8601'>最終更新日: <data:post.lastUpdated.year/>/<b:eval expr='data:post.lastUpdated.month lt 10 ? "0" + data:post.lastUpdated.month : data:post.lastUpdated.month'/>/<b:eval expr='data:post.lastUpdated.day lt 10 ? "0" + data:post.lastUpdated.day : data:post.lastUpdated.day'/></time>
<b:else/>
<time expr:datetime='data:post.date.iso8601' id='p-header-pdate'>投稿日: <data:post.date.year/>/<b:eval expr='data:post.date.month lt 10 ? "0" + data:post.date.month : data:post.date.month'/>/<b:eval expr='data:post.date.day lt 10 ? "0" + data:post.date.day : data:post.date.day'/></time>
</b:if>
投稿後に記事が更新された場合は「更新日」のみを表示。更新なし(投稿日と更新日が同じ)の場合は「投稿日」が表示されます。
アイコンだとぱっと見で判り辛いような気がしたので文字表記にしました。
更新あり(デフォルト) |
更新なし(デフォルト) |
更新あり(カスタマイズ後) |
更新なし(カスタマイズ後) |
連絡フォームウィジェット用 CSS
公式ガジェットでよく使われるものの一つということで。
F-lght に馴染むようなデザインを用意してみました。もちろんダークモード対応です。
v1.32~ CSS を追加済みです。
.contact-form-email,
.contact-form-email-message,
.contact-form-name {
max-width:100%;
min-width:100%;
color: var(--color);
padding: .5em;
outline: none;
border-radius: 3px;
background: var(--dark-bg);
transition: .2s;
border: 1px solid transparent;
}
.contact-form-email:focus,
.contact-form-email-message:focus,
.contact-form-name:focus {
box-shadow: 0 0 6px var(--link);
border: 1px solid var(--link);
}
.contact-form-email-message {
min-height: 200px;
}
.contact-form-email,
.contact-form-name {
height:40px;
}
.contact-form-button-submit {
border-radius : 3px;
line-height: .1;
margin: 2em 0;
cursor: pointer;
padding: 1em 2em;
background: var(--brand);
color: var(--brand-font);
transition: .3s;
border: none;
outline: none;
}
.contact-form-button-submit:hover {
transform: scale(1.1);
}
.contact-form-button-submit:active {
transform: none;
}
.contact-form-error-message-with-border,
.contact-form-success-message-with-border {
color: var(--color);
font-weight: bold!important;
}
.contact-form-cross {
width: .9em;
height: .9em;
vertical-align: -5%;
margin:0 5px;
}
.contact-form-cross:hover {
cursor:pointer;
}
1カラム時のメインの幅を縮める
狭めの方が好みの方も多いようなので。
以下の箇所の 900px の数値を変更して下さい。
/*==== 1 カラム レイアウト ====*/
#main-content {
position: relative;
margin: 3em auto 0;
padding: 1em;
max-width: 900px;/*お好みで数値を調整*/
}
2022/10/19 追加: ナビバーとメインの間にガジェットを設置
ナビバーの下のスペース用のおすすめのガジェットを2つ紹介します。
コードの挿入位置について
</nav> と <!-- メインコンテンツ --> の間にコードをコピペします。
①ニュースティッカー ガジェット
IB-Note【jQuery不使用】JavaScriptとCSSで作るニュースティッカー | IB-NoteWebサイトで時々見かけるニュースティッカーをJSとCSSだけで作りました。コピペで簡単に使うことができます。https://itblogger-note.blogspot.com/2022/07/news-ticker.html
F-light デモサイトにお知らせ用としてこちらの IB-Note さん作のガジェットを置いてみたところ、予想以上にいい感じにハマりましたので、F-light 用に最適化した コードを紹介したいと思います。
ニュースタイトルにNEW を付けたい場合は、以下のコードを使用して下さい。(自動で表示させることはできません)
<span class="ticker-new">NEW</span>
コード
<div class='ticker-wrap'>
<div class='ticker-head'>NEWS</div>
<div class='ticker'>
<ul>
<li class='ticker-item'><a href='リンクURL'><span class='ticker-date'>日付</span><span class='ticker-title'>ニュースタイトル</span></a></li>
<li class='ticker-item'><a href='リンクURL'><span class='ticker-date'>日付</span><span class='ticker-title'>ニュースタイトル</span></a></li>
<li class='ticker-item'><a href='リンクURL'><span class='ticker-date'>日付</span><span class='ticker-title'>ニュースタイトル</span></a></li>
</ul>
</div>
</div>
<script>/*<![CDATA[*/
/* News Ticker gadget powered by IB-Note via: https://itblogger-note.blogspot.com/2022/07/news-ticker.html */
(function(window, document) {
const animTime = 5000;
const speed = 100;
const limit = 0;
let animId;
let isRunning = false;
const ticker = document.querySelector('.ticker');
loadTicker();
function loadTicker() {
tickerAnim();
animId = setInterval(tickerAnim, animTime);
isRunning = true;
}
// アニメーション処理
function tickerAnim() {
const items = ticker.querySelectorAll('.ticker-item');
const running = ticker.querySelector('.run');
let idx, link, first, next;
if (!running) { // 実行中の要素がない場合(初回のみ)
first = items[0];
link = first.querySelector('a');
first.classList.add('fadeInDown', 'run');
first.style.zIndex = 1;
setTimeout(textMove, 1000, link); // 第3引数に引数linkを指定。こうしないと即実行されてしまうので注意。
} else {
for (let i = 0; i < items.length; i++) {
if (items[i] == running) {
idx = i; // 実行中要素のインデックスを取得
break;
}
}
next = items[(idx + 1) % items.length];
running.classList.replace('fadeInDown', 'fadeOutDown');
setTimeout(() => {
running.classList.remove('fadeOutDown', 'run');
running.style.zIndex = 0;
link = running.querySelector('a');
link.style.transform = 'none';
next.classList.add('fadeInDown', 'run');
next.style.zIndex = 1;
link = next.querySelector('a');
setTimeout(textMove, 1000, link);
}, 300);
}
}
// テキスト移動処理
function textMove(elm) {
const move = elm.parentNode.clientWidth - elm.clientWidth;
if (move < 0) {
elm.style.transform = 'translateX(' + move + 'px)';
elm.style.transitionDuration = Math.abs(move) / speed + 's';
}
}
// ウィンドウサイズ変更時
window.addEventListener('resize', () => {
const windowWidth = window.innerWidth;
if (windowWidth <= limit) {
ticker.style.display = 'none';
clearInterval(animId);
isRunning = false;
} else {
if (!isRunning) {
ticker.style.display = 'block';
animId = setInterval(tickerAnim, animTime);
isRunning = true;
}
}
});
})(window, document);
/*]]>*/</script>
<style>/*<![CDATA[*/
.ticker-wrap {
display: flex;
max-width: 97%;
width: 900px;/*横幅一杯に表示させる場合は 1155px*/
background: var(--brand);
padding: 4px;
margin: 2em auto 0;
}
.ticker-head {
width: 4.5em;
font-family: verdana;
font-style: italic;
color: #fff; /*F-light v1.29 以降は var(--brand-font) に置き換える*/
line-height: 30px;
padding: 0 4px;
text-align: center;
}
.ticker {
width: 100%;
height: 30px;
font-size: 15px;
background: var(--light-bg);
line-height: 30px;
padding: 0 6px;
overflow: hidden;
}
.ticker ul {
position: relative;
list-style: none;
height: 100%;
padding: 0;
margin: 0;
}
.ticker-item {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
padding-right: 0;
opacity: 0;
}
.ticker-item a {
display: inline-block;
width: auto;
color: var(--color);
white-space: nowrap;
text-decoration: none;
transition: transform 5s linear;
}
.ticker-item a::after {
content: "\00BB";
margin-left: 2px;
font-size: 1.9rem;
}
.ticker-item a:hover {
color: var(--link);
}
.ticker-date {
font-weight: bold;
color: var(--link);
}
.ticker-title {
margin-left: 10px;
}
.ticker-new {
color: var(--red-color);
font-weight: bold;
margin-left: 10px;
animation: blink 1s ease-in-out infinite alternate;
}
.fadeInDown {
opacity: 0;
}
.fadeInDown.run {
animation: fadeInDown 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) forwards;
}
.fadeOutDown {
opacity: 1;
}
.fadeOutDown.run {
animation: fadeOutDown 0.3s cubic-bezier(0.645, 0.045, 0.355, 1) forwards;
}
@keyframes fadeInDown {
0% {
opacity: 0;
transform: translateY(-30px);
}
100% {
opacity: 1;
transform: translateY(0);
}
}
@keyframes fadeOutDown {
0% {
opacity: 1;
transform: translateY(0);
}
100% {
opacity: 0;
transform: translateY(30px);
}
}
@keyframes blink {
0%, 100% {
opacity: 1;
}
50% {
opacity: 0;
}
}
/*]]>*/</style>
コードの詳細や各オプションについては上記の IB-Note さんの記事を参考にしてください。
②アイキャッチ画像付きリンクリスト
QooQ 用カスタマイズ記事
moca*Bloggerメモ*2ndBlogger 「QooQ」 カスタマイズ*ヘッダー・ナビゲーションバーBlogger 日本語テンプレート「QooQ」のカスタマイズ記事です。 Blogger「QooQ」のヘッダーとナビゲーションバーをカスタマイズしてみました。 おすすめ記事などのアイキャッチ画像付きリンクを表示する方法もあわせてご紹介します。https://www.moca-memo.com/2020/02/blogger-qooq-header.html#toc_headline_6
オリジナル作者さんの記事
バンビの初心者ブログ教室【はてなブログ】ヘッダー下におすすめ記事やアイキャッチを並べて表示するカスタマイズ方法 - バンビの初心者ブログ教室自分のブログを訪れてくれた人に読んでもらいたい「おすすめ記事」をトップページのヘッダー下に表示する方法です。https://www.bambi.pro/entry/blog-eyecatch-list
QooQ でよく見かける人気のガジェットです。注目の投稿を一度に4つ並べたいという方に。
コード
オリジナルコードのクラス名 article-img は F-light で使用中のクラス名と重複していて、そのままだと表示が崩れてしまうので、article-image に変更しました。
※画像のアスペクト比は4枚とも同じにして下さい。
<div class='article-area'>
<div class='article-container'>
<div class='article-box'>
<div class='article-image'>
<a href='記事のURL'><img alt='タイトルのテキスト' src='画像のURL'/></a>
</div>
</div>
<div class='article-box'>
<div class='article-image'>
<a href='記事のURL'><img alt='タイトルのテキスト' src='画像のURL'/></a>
</div>
</div>
<div class='article-box'>
<div class='article-image'>
<a href='記事のURL'><img alt='タイトルのテキスト' src='画像のURL'/></a>
</div>
</div>
<div class='article-box'>
<div class='article-image'>
<a href='記事のURL'><img alt='タイトルのテキスト' src='画像のURL'/></a>
</div>
</div>
</div>
</div>
<style>/*<![CDATA[*/
.article-area {
background: var(--light-bg);/*背景色*/
}
.article-container {
width: 90%;/*画像表示の幅*/
display: flex;
box-sizing: border-box;
margin: 0 auto;
padding: 0;
text-align: center;
}
.article-box {
box-sizing: border-box;
border: 2px solid var(--brand);/*画像の枠色*/
width: 25%;
padding: 0;
margin: 30px 15px 0;/*画像周りの空白*/
overflow: hidden;
}
.article-image img {
width: 100%;
display: block;
object-fit: cover;
transition-duration: .5s;/*ゆっくり戻る*/
}
.article-image:hover img {/*マウスオーバーで拡大表示*/
transform: scale(1.1);/*1.1倍に表示*/
transition-duration: .5s;/*ゆっくり拡大*/
}
/*=== smartphone 2列表示 ===*/
@media (max-width: 767px) {
.article-container {
width: 100%;
flex-wrap: wrap;/*折り返し表示(2列)*/
justify-content: space-between;
padding: 8px;
}
.article-box {
width: 45%;
padding: 0;
margin: 8px;
}
.article-image img {
width: 100%;
padding: 0;
object-fit: cover;
}
}
/*]]>*/</style>
2022/11/27 追加: 新着記事に NEW を付ける
トップページの記事一覧の新着記事で、よく「NEW」というマークが付いているのを見かけますよね。あれいつかやってみたいなあと思っていたのですが、昨日 BINUBALL さんがカスタマイズ記事を書かれていて、早速うちでも取り入れてみたところ問題なく実装できましたので、F-light 用の導入手順を紹介したいと思います。
잡담방 (チャットルーム)Blogger에서 새 글에 특별한 표시 주기 (Bloggerで新しい投稿に特別な表示を与える)발행된 지 얼마 되지 않은 글에 특별한 표시를 주고 싶을 때가 있습니다. 자바스크립트를 이용해서 알아낼 수 있습니다. Blogger의 기본 테마인 Contempo 테마에서 적용할 수 있는 방법입니다. 다른 테마에서도 적용되는지는 시험하지 않았으므로 댓...https://rickrollblog.blogspot.com/2022/11/blogger-new-post-style.html
BINUBALL さんのブログは記事リストの枠を赤色のボーダーを囲うというシンプルなスタイルですが、うちではこんな感じに左上に「NEW」マークを表示させます。
※ラベルページや検索ページでも新着記事が含まれていれば NEW が表示されますが、注目の投稿と人気の投稿には表示されません。
導入手順
① JavaScript コードを設置
HTML 編集にて <b:include data='post' name='post'/> を検索で探します。
このタグの直下に以下のコードを挿入します。
<script>
/* Auto add NEW mark powered by BINUBALL via: https://rickrollblog.blogspot.com/2022/11/blogger-new-post-style.html */
(function(){
const idx = <data:i/>;
//<![CDATA[
const date = () => {
const now = new Date().getTime();
const postDate = new Date(document.querySelectorAll('time')[idx].dateTime).getTime();
const diff = (now - postDate) / 1000;
const dayDiff = Math.floor(diff / 86400);
if (dayDiff < 7) { // NEW を表示する日数
document.querySelectorAll('.article')[idx].classList.add('new')
}
console.log(dayDiff);
}
date();
})();
//]]>
</script>
NEW を表示する期間はデフォルトで7日間にしてありますが、if (dayDiff < 7)の数値でお好みに変更できます。
② CSS の追記
以下のコードを /*==== ユーザー カスタム CSS ====*/ の直下に追記します。
NEW の文言や配色など、お好みで変更して下さい。
/*== 新着記事 NEW マーク ==*/
.new:not(#FeaturedPost1 .article)::before {
content: "NEW";
position: absolute;
top: 0;
left: 0;
z-index: 1;
padding: 2px 5px;
border-top-left-radius: 5px;
color: #fff;
font-weight: bold;
font-style: italic;
background: red;
}
@media (max-width: 600px) {
.new .article-category {
display: none;
}
}
2023/08/27 追加: 検索ウィジェットのカスタムデザイン CSS
F-light の検索ウィジェットは初めからナビバーに埋め込んであるのですが、使い勝手が悪い?のかそれとも目立たないから?なのかはわかりませんが、サイドバーに追加で設置している方をたまに見かけます。
そのままだとデフォルトのショボいデザインになってしまいますので、F-light に馴染むようなデザインの CSS を用意してみました。
v1.32~ CSS を追加済みです。
.widget-content form {
position: relative;
max-width: 600px;
margin: 0 auto;
}
.search-input input {
box-sizing: border-box;
background: var(--dark-bg);
color: var(--color);
border-top-left-radius: 5px;
border-bottom-left-radius: 5px;
border: none;
width: calc(100% - 70px);
height: 40px;
padding: 0 .5em;
}
.search-input input:focus {
outline: none;
border: 1px solid var(--brand);
padding: 0 calc(.5em - 1px);
}
.search-input input::placeholder {
color: var(--dark-color);
}
.search-action {
position: absolute;
background: var(--brand);
color: var(--brand-font);
border: none;
border-top-right-radius: 5px;
border-bottom-right-radius: 5px;
top: 0;
right: 0;
width: 70px;
height: 40px;
}
.search-action:hover {
cursor: pointer;
opacity: .8;
}
2023/08/30 追加: SNS シェアボタンのカスタマイズ
カスタマイズ その1: Twitter の鳥さんを 𝕏 に変える
① SVG コードを入れ替える
検索で<symbol id='svg-twitter'を探し、</symbol>までの部分を以下のコードと入れ替えます。
<symbol id='svg-twitter' viewBox='0 0 1200 1227'><path d='M714.163 519.284L1160.89 0H1055.03L667.137 450.887L357.328 0H0L468.492 681.821L0 1226.37H105.866L515.491 750.218L842.672 1226.37H1200L714.137 519.284H714.163ZM569.165 687.828L521.697 619.934L144.011 79.6944H306.615L611.412 515.685L658.88 583.579L1055.08 1150.3H892.476L569.165 687.854V687.828Z'/></symbol>
② 背景色の変更
検索で.tweetを探し、background のカラーコードを黒系に変更します。
.tweet {
background: #000;
}
カスタマイズ その2: ボタンに名前をつける
こんな風に名前付きのデザインに変更します。スマホの方はこれまでとほぼ変わりなしです。
スマホ |
① CSS コードの入れ替え
/*==== SNS シェアボタン ====*/の所の CSS を以下のコードと入れ替えます。
/*==== SNS シェアボタン ====*/
.sns-share-buttons {
width: 450px;
margin: 4em auto;
display: flex;
justify-content: space-around;
max-width: 100%;
}
.sns-share-buttons span {
text-align: center;
font-size: 2.4rem;
display: block;
padding-top: 8px;
line-height: 1;
border-radius: 5px;
height: 55px;
width: 65px;
transition: .3s;
color: #fff;
}
.sns-share-buttons span:hover {
transform: scale(1.1);
cursor: pointer;
}
.btnname {
display: block;
font-size: 50%!important;
font-weight: bold;
padding: 0!important;
height: 1em!important;
}
.copy_btn .btnname {
padding-top: 3px!important;
font-size: 50%;
}
.copy_btn span {
font-size: 50%;
}
.svg-twitter {
margin-bottom: 5px;
}
.svg-facebook-f {
height: 30px;
width: 30px;
margin-top: -1px;
}
.hatebusvg {
height: 28px;
width: 28px;
}
.linesvg {
height: 30px;
width: 30px;
margin: -2px 0 -1px 2px;
}
.svg-get-pocket {
height: 30px;
width: 30px;
margin-top: -2px;
}
.tweet {
background: #000;
}
.facebook {
background: #1877f2;
}
.line {
background: #00b900;
}
.hatena {
background: #00a4de;
}
.pocket {
background: #ef4056;
}
.copy_btn {
background: slategray;
}
.copy_btn::before {
content: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="23" height="23" viewBox="0 0 24 24" fill="none" stroke="%23fff" stroke-width="3" stroke-linecap="round" stroke-linejoin="round"><path d="M10 13a5 5 0 0 0 7.54.54l3-3a5 5 0 0 0-7.07-7.07l-1.72 1.71 M14 11a5 5 0 0 0-7.54-.54l-3 3a5 5 0 0 0 7.07 7.07l1.71-1.71"></path></svg>');
}
@media (max-width: 600px ) {
.sns-share-buttons {
width: 350px;
}
.btnname:not(.copy_btn .copied) {
display: none!important;
}
.sns-share-buttons span {
height: 45px;
width: 45px;
padding-top: 9px;
}
.svg-twitter,
.linesvg {
margin-top: 2px;
}
.copy_btn span {
margin-top: -6px!important;
font-size: 40%!important;
}
}
② HTML コードの入れ替え
検索で<div class='sns-share-buttons'>を探し、行番号の右の▼をクリックして折りたたんでから、以下のコードと入れ替えます。
<div class='sns-share-buttons'>
<span class='tweet' onclick='tweet_btn()' role='button' title='ポスト'><svg aria-label='ポスト' class='svg svg-twitter'><use href='#svg-twitter'/></svg><span class='btnname'>ポスト</span></span>
<script>/*<![CDATA[*/
function tweet_btn(){const w=550,h=550;window.open("https://x.com/intent/tweet?url="+encodeURIComponent(location.href)+"&text="+encodeURIComponent(document.title),"_blank","width="+w+",height="+h+",left="+(screen.width-w)/2+",top="+(screen.height-h)/2+",scrollbars=yes,resizable=yes,toolbar=no,location=yes")}
/*]]>*/</script>
<span class='facebook' onclick='fb_btn()' role='button' title='シェア'><svg aria-label='Facebookにシェア' class='svg svg-facebook-f'><use href='#svg-facebook-f'/></svg><span class='btnname'>シェア</span></span>
<script>/*<![CDATA[*/
function fb_btn(){const w=550,h=420;window.open("https://www.facebook.com/sharer.php?u="+encodeURIComponent(location.href),"_blank","width="+w+",height="+h+",left="+(screen.width-w)/2+",top="+(screen.height-h)/2+",scrollbars=yes,resizable=yes,toolbar=no,location=yes")}
/*]]>*/</script>
<span class='line' onclick='line_btn()' role='button' title='LINEで送る'><svg aria-label='ラインで送る' class='linesvg'><use href='#linesvg'/></svg><span class='btnname'>ライン</span></span>
<script>/*<![CDATA[*/
function line_btn(){const w=550,h=520;window.open("https://social-plugins.line.me/lineit/share?url="+encodeURIComponent(location.href),"_blank","width="+w+",height="+h+",left="+(screen.width-w)/2+",top="+(screen.height-h)/2+",scrollbars=yes,resizable=yes,toolbar=no,location=yes")}
/*]]>*/</script>
<span class='hatena' onclick='hatena_btn()' role='button' title='はてなブックマークに登録'><svg aria-label='はてなブックマーク' class='hatebusvg'><use href='#hatebusvg'/></svg><span class='btnname'>はてブ</span></span>
<script>/*<![CDATA[*/
function hatena_btn(){const w=480,h=480;window.open("https://b.hatena.ne.jp/entry/panel/?url="+encodeURIComponent(location.href),"_blank","width="+w+",height="+h+",left="+(screen.width-w)/2+",top="+(screen.height-h)/2+",scrollbars=yes,resizable=yes,toolbar=no,location=yes")}
/*]]>*/</script>
<span class='pocket' onclick='pocket_btn()' role='button' title='Pocketに保存'><svg aria-label='Pocketに保存' class='svg svg-get-pocket'><use href='#svg-get-pocket'/></svg><span class='btnname'>ポケット</span></span>
<script>/*<![CDATA[*/
function pocket_btn(){const w=550,h=420;window.open("https://getpocket.com/edit?url="+encodeURIComponent(location.href),"_blank","width="+w+",height="+h+",left="+(screen.width-w)/2+",top="+(screen.height-h)/2+",scrollbars=yes,resizable=yes,toolbar=no,location=yes")}
/*]]>*/</script>
<span class='copy_btn' onclick='copyLink()' role='button' title='タイトルとURLをコピーする'><span class='btnname'>コピー</span></span>
<script>/*<![CDATA[*/
const copy_btn=document.getElementsByClassName("copy_btn")[0];function copyLink(){let t=document.title+"\n"+location.href;navigator.clipboard.writeText(t),copy_btn.innerHTML="<span class='btnname copied'>コピー済</span>",copy_btn.setAttribute("title","コピーしました"),setTimeout(()=>{copy_btn.innerHTML="<span class='btnname'>コピー</span>",copy_btn.title="タイトルとURLをコピーする"},2e3)}copy_btn.addEventListener("click",copyLink);
/*]]>*/</script>
</div>
ボタン名はお好みで変更して下さい。名前が長すぎるとはみ出すので注意。
英語表記にするとこんな感じ。
NEW!記事・ページのヘッダー(タイトルや投稿日)を中央寄せにする
1カラムの個別ページでは、この方がバランスがいいと思いませんか?
CSS 変更箇所
2箇所にtext-align: center;を追加し、display: flex;をコメントアウトするか削除して下さい。
/*==== 投稿ヘッダー ====*/
#p-header {
text-align: center; /*追加*/
display: block;
font-size: 1.4rem;
margin: 1.5em 0 1em;
color: var(--dark-color);
}
#p-header a:hover {
color: var(--link);
text-decoration: underline;
}
#p-header-title {
text-align: center; /*追加*/
font-size: 2.2rem;
font-weight: normal;
color: var(--color);
/*display: flex;*/ /*コメントアウト OR 削除*/
margin-top: .5em;
margin-left: -8px;
line-height: 1.3;
}
#p-header-title::before {
content: "\25A0";
padding-right: 2px;
color: var(--brand);
}
最後に
とりあえず思いついたものだけを羅列してみました。今後また何かしら思いついたり、ユーザーさんからの要望等あれば、随意追加していくつもりです。
コメントを投稿
別ページに移動します20 件のコメント (新着順)
ふじやん
>りりさん
F-lightをお使いいただき、気に入って頂けたようで嬉しいです!
カスタマイズは自由ですし、どういう使い方をして頂いても構いませんよ~
りり
はじめまして。本日こちらのブログに辿り着き、すごく理想的なテンプレートで興奮しております!隅々まで見やすくて、操作性も最高です!ナビや見出しのグラデーションも綺麗でワクワクします!素晴らしいテンプレートを公開してくださってありがとうございます。
blogger歴は10年以上あるもののカスタマイズは超初心者なので、わかりやすい解説もあって本当にありがたいです。
ところで、こちらのテンプレートを使えばブログではなく普通のWebサイト(所謂ホームページ)が作れそうと思ったのですが、そういった使い方をしても良いでしょうか?
記事投稿はせず、ページ機能を使う形で…。
ふじやん
> むーなかさん
こちらこそ、自分ではまず気づかないであろう(些細だけど)結構重要なミスに気づけて本当に感謝です!
今後もまたお気づきの点がありましたら、どんな些細なことでも構いませんのでお知らせくださいね(^^)
むーなか
相変わらず神速の対応ありがとうございます。
2個ともsのやつをネットで検索しても結構出てきてしまうので、本当に間違えやすいものなんだと思います。
とりあえず敬愛するふじやんさんの著作物が正しくなったのであれば僕はそれでいいです。ありがとうございました😊
ふじやん
> むーなかさん
ご指摘ありがとうございます。早速6種類のテーマ全て修正しておきました。
実は F-light は元々 QooQ がベースになっていて、当該の表記部分は QooQ からそのまま転用していたため、今まで気にもしてませんでした(^^;
QooQ の xml を確認したらやはりあちらも間違ってますね(笑) くうく堂さんにも指摘しといたほうがいいかも?(^^;
保存してある古いバージョンも全て間違ってるので、おそらく最初から間違えた状態だったのではないかと。あれだけユーザー数の多いテーマなのに誰も気づかなかったのかな?
むーなか
ふじやん様、いつもお世話になっております。バグにはならないのですが、一点スペルミスではないかと思いましたので書かせていただきます。F-lightのライセンス事項にLisenseとあります。2個ともsです。正しくはLicenceの様に2個ともcか(主にイギリス)、Licenseの様に1個目がc、2個目がsの様です(主にアメリカ)。細かい話で恐縮ですがライセンスは大切なので書かせていただきました。今後もお世話になります🙇
GO
>ふじやんさん
色々と有難う御座います。m(__)m
ふじやん
すいません。このコメントの補足です。
どうやら width:70%; と正しい記述にすると、右側の吹き出しが若干(2%ほど)はみ出してしまうようです。
width:70%; を削除したら問題なく表示されましたので、これは削除しちゃって下さい。
(これまでこの部分が効いてなかった為、はみ出すことなく表示されていたと思われます(^^;)
ふじやん
ああー!ごめんなさい!
自分のコメントを消すつもりが間違って GO さんのコメントを削除してしまいました…
というわけで以下に GOさんのコメントを引用しておきますのでご了承下さいm(_ _)m
>ふじやんさん
早速のお返事有難う御座います。>
しかもコードまで m(_ _)m
参考になるサイトを見つつ色々いじっているのですが素人なので少し難しくなるとお手上げ状態でして(^^;
テストサイトでバッチリ仕上げてからメインを変更したいと思います(^^)
2023/10/22 19:53
ふじやん
> GOさん
F-light に限らず、Blogger に関することで分からないことがありましたら、どうぞ遠慮なくお尋ねください!
F-light に着せ替えたメインブログを拝見するのを楽しみにしてますね(^^)
あ、今気づいたんですが、コードの4行目の width: 70%の右の「;」(セミコロン)が抜けていますのでこうしておいて下さい。(このままでもエラーにはならないようですが念のため)
width: 70%;
ふじやん
> GOさん
はじめまして。
F-light へ乗り換え予定とのことで、大変うれしく思います。
さて、ZELO の吹き出し用 CSS の F-light への転用ですが、基本的には ZELO のクラス名(.entry-content)を F-light のクラス名(.post-body)に置き換えるだけでOKです。
あとはダークモードで白文字にならないよう、文字色を設定してやれば完了です。
というわけで、F-light 用に最適化した CSS が下記のコードになります。(アイコン画像URLはGOさんのブログのソースコードからコピーしました)
これを /*==== ユーザー カスタム CSS ====*/ の直下にコピペして下さい。
/* ---------- フキダシ */
.post-body .f-l,
.post-body .f-r {
position: relative;
width: 70%
-webkit-box-sizing: border-box;
-moz-box-sizing: border-box;
box-sizing: border-box;
padding: 16px;
border-radius: 8px;
border: 1px solid #000;
background-color: #ffffe0;
color: #111;
z-index: 1;
}
.post-body .f-l {
margin: 24px 32% 24px 0;
}
.post-body .f-r {
margin: 24px 0 24px 32%;
}
.post-body .f-l::before,
.post-body .f-r::before {
position: absolute;
content: "";
top: 16px;
width: 11px;
height: 11px;
border-right: 1px solid #000;
border-bottom: 1px solid #000;
background-color: #ffffe0;
z-index: 2;
}
.post-body .f-l::before {
right: -7px;
transform: rotate(-45deg);
-webkit-transform: rotate(-45deg);
}
.post-body .f-r::before {
left: -7px;
transform: rotate(135deg);
-webkit-transform: rotate(135deg);
}
.post-body .f-l::after,
.post-body .f-r::after {
position: absolute;
content: "";
width: 56px;
height: 56px;
top: -4px;
border-radius: 50%;
background-size: cover;
background-position: center center;
background-repeat: no-repeat;
}
.post-body .f-l::after {
right: -84px;
}
.post-body .f-r::after {
left: -84px;
}
.me::after {
background-image:url(https://1.bp.blogspot.com/-8gJOG82zSdk/XPxhImHOgpI/AAAAAAAAB84/50pvNG6lnFoytY8XD6Vc8ZJtNFWJ3XeUQCLcBGAs/s320/image.png);
}
.you::after {
background-image:url(https://1.bp.blogspot.com/-KSFyTUvpDcY/XPn854j2DdI/AAAAAAAAB7o/LAqkvZE3GugBvlnl_1Xnirez_a703hwnwCLcBGAs/s320/smile-egao.png);
}
GO
はじめまして
現在テーマの変更を考えているのですが、記事本文中に使用してる吹き出しをそのまま移行できないかと、現在使っているテーマの吹き出しコードをそのままコピペしてみたのですが無理でした。
F-lightにコードの追加だけで、今使用している吹き出しを使用する事はできないでしょうか?
現在使用しているテーマはZEROです
宜しくお願い致します
ふじやん
> chovi さん
可愛い写真が癒やされます😻
嬉しいお言葉ありがとうございます!
大先輩のBloggerユーザーさんにそう言って頂けると励みになります😀
chovi
ふじやんさん
私のブログも見ていただいていたとのことで、こちらこそありがとうございます🙇🏻♂️
F-lightは少し前からテスト用ブログで使わせていただいており、つい先日メインのブログに反映させたばかりです。
拙作なんてとんでもない!
Bloggerを使う上でいろいろ不満に思うところがありましたが、それらが改善されている素晴らしいテーマです😄
ふじやん
> chovi さん
はじめまして。
実はchoviさんのブログ、何度か拝見したことがあったのですが、いつの間にかQooQから拙作テーマに変えられてたのですね。使って頂いてありがとうございます!
こちらこそ、OneShotDiaryでもよろしくお願いします!
chovi
はじめまして。
ブログでF-lightを使わせていただいております。
OneShotDiary のアカウントもフォローしましたので、
これからも何かと参考にさせていただきたいと思います。
どうぞよろしくお願いします。
ふじやん
> むーなかさん
F-light を気に入って頂けたようで嬉しいです。
さて、ご提案の件ですが、実を言いますと F-light のアップデート予定リストの中に結構前から入っていたものの、優先度を低めに設定していたため後回しになっておりました(^^;
早速次回のアップデートで反映させていただきますので、しばらくお待ちいただければと思います。
今回は貴重なご意見、本当にありがとうございました。この様にユーザーさんからご要望を頂けると、改善の優先度を判断するのに助かります。
また何かお気づきの点やご要望がありましたらお知らせいただければ幸いです。
むーなか
はじめまして、ふじやん様。
むーなかと申します。
先日Bloggerでのブログを始めた初心者なのですが、F-lightが大変気に入り使わせてもらっています。
ただ一点ご提案がありましてコメントさせていただきました。
--brand色を変える事でカスタマイズしようとしたのですが設定してみた所文字色は#fffが指定されていました。明るい空色やレモンの様な黄色を--brand色に設定しようとしましたら見づらい文字になりまして、個別にテーマのHTML設定からcolorの部分を変更し、上の文字が黒くなる様にしています。ですが変更箇所が多く、どこを変更したら良いか分からない点もありました。
基本的には、白い文字が見にくくなる様な色の指定は想定されていない設計ということになりそうです。
考えたのですが、もう一つ変数として定義する色に--on-brandを加え、--brandの上に乗る色はその色にする、と言う形にしてはいかがでしょうか。
その様にすれば--brandの色が明るい色で文字が見づらくなった場合--on-brandの色を#000に変更すれば良い、と、初心者でも容易に変更が可能となります。
是非ご検討頂ければ幸いです。
ふじやん
> BINUBALL さん
ご指摘ありがとうございます。修正しました。
間違えているのがコピー用のコードではなく説明文の方で良かったです(^^;
BINUBALL
今こそこの記事を見るようになりました。 if (dayDiff > 7)の不等号の方向が変わる必要があります。