スキップしてメイン コンテンツに移動

サイドバーの広告を、CSSでスクロール固定する

最近よく見かける、記事横のサイドバー広告枠が、画面の上の方までスクロールしたら、画面上部に固定表示するのを、CSSだけで実装してみます。

言葉だけで使えるのが難しい為、実際どういった動きの物を作るのか、Gifアニメーションにしてみました。

広告枠スクロール固定の実行動画Gifアニメーション

position: sticky

今回は、CSSのposition:stickyを使って、広告枠のスクロール固定を実装していきます。
新しい仕様のCSSのため、一部対応していなブラウザがあり、ブラウザ別の対応状況は以下のようになっています。
主要なブラウザは、ほぼサポートされている感じですね♪
IEなどの未対応ブラウザであっても、画面上部でスクロール固定されずに、スクロールで上の方に見切れて行くだけなので、特に害はありません。

position: stickyのブラウザ対応状況 (2019年1月現在)
2019年1月現在のposition: sticky対応状況
Can I use

サンプルード

[HTML]

<body>
  <div class="container">
    <div class="post-body" style="height:2000px">
      記事の内容<br/>
      です<br/>
    </div>
    <div class="post-sidebar">
      <div>
        <small>新着記事</small>
        <hr/>
        <div>NNNNNNNNNNNNNNN</div>
        <div>NNNNNNNNNNNNNNN</div>
        <div>NNNNNNNNNNNNNNN</div>
        <div>NNNNNNNNNNNNNNN</div>
        <br/>
      </div>
      <div id="ad">
        <small>スポンサーリンク</small>
        <hr/>
        <div class="ad-box">
          広告枠
        </div>
      </div>
    </div>
  </div>
</body>

[CSS]

.container {
  position: relative;
}
.post-body {
  background: rgb(219, 219, 219);
  margin-right: 300px;
}
.post-sidebar {
  position: absolute;
  top: 0;
  right: 0;
  width: 290px;
}
.ad-box {
  width: 240px;
  height: 240px;
  background: rgb(224, 63, 63);
  margin-bottom: 10px;
}
#ad {
  position: -webkit-sticky;
  position: sticky;  /*  */
  top: 10px;
}

[JavaScript]

document.addEventListener('DOMContentLoaded', function () {
  var post_body = document.querySelector(".post-body");
  var post_sidebar = document.querySelector(".post-sidebar");
  post_sidebar.style.height = post_body.clientHeight + "px";
});

注意事項

Google Adsenseなど、一部の広告プロバイダでは、スクロール固定の広告を使用すると、ポリシー違反になる可能性があります。
使用する場合は、自己責任でお願いします。

スポンサーリンク
スポンサーリンク
スポンサーリンク

コメント

このブログの人気の投稿

axiosの使い方まとめ (GET/POST/例外処理)

axiosの使い方まとめ (GET/POST/例外処理)最近何かとよく使うJavaScriptでAJAX通信を行うaxiosについて、簡単に使い方をまとめました。GETリクエストをaxiosで送るまずはGETリクエストをaxiosで送る方法です。const res =await axios.get('/users') console.log(res.data)分割代入の記法を使うと、以下のようにも書けますconst{data}=await axios.get('/users') console.log(data)クエリパラメータ (URLパラメータ)を指定クエリパラメータを指定する方法は2つあります。1つ目は、axios.getに指定するURLに直接記述する方法です。axios.get('/user?id=123')2つめは、axios.getの第2引数に、オプション指定する方法です。axios.get('/user',{ params:{ id:123}})POSTリクエストをaxiosで送る次はPOSTリクエストをaxiosで送る方法です。JSON形式でPOSTするJSON形式でPOSTする場合は、axios.postの第2引数に、送信するデータをJavaScriptオブジェクトで指定します。const res =await axios.post('/user',{ id:123, name:'Yamada Tarou'})application/x-www-form-urlencoded形式でPOSTするapplication/x-www-form-urlencoded形式でPOSTする場合は、URLSearchParamsを使います。var params =newURLSearchParams() params.append('id',123) params.append('name','Yamada Tarou')const res =await axios.post('/user', params)axios でファイルをアップロードする画像などのファイルを、axiosでアッ…

[VB, C#] Windows 8, Window 10 で ImeModeが制御できない問題を解決する

[VB, C#] Windows 8, Window 10 で ImeModeが制御できない問題を解決するタイトルの通りですが、Windows 8 以降では Windows Form アプリケーションで、コントロールの ImeMode に Katakana や KatakanaHalf を設定しても、カタカナになってくれません。なぜ ImeMode が効かないのか?Windows 8 以降、IME Mode の切り替えは、ユーザー単位で切り替わるようになった為、アプリから IME Mode 制御が出来ないようになりました。
(IME をON にした場合、常に ひらがな モードになます)※ Windows 7までは、IME Modeの切り替えはアプリ単位で行われていた為、問題なくアプリから IME制御が行えました。対処方法Windows 8 以降、IMEの制御は、InputScope クラスの利用が推奨されています。
しかし、InputScope クラスは、WPF、Windows ストアアプリでしか使えない為、Windows Formアプリでは使用できません。
(Windows Form はもう使うな!という事でしょうか (涙) )結論としては、コントールパネルの設定で、IMEの制御をユーザ単位から アプリ単位に変更する事ができます。
これで、Windows Formアプリでも 従来通りIMEの制御を行う事が出来ます。おわりにこの方法だと、アプリをインストールする端末すべてに設定が必要となり、とっても面倒です。。。
しかし、今の所これしか方法がない状態です。
これからは Windows Formではなく、WPFや Windows ストアアプリで作れという事ですかね (^^;)

MailKitの使い方! エンコーディング指定や添付ファイをメールで送信する方法[C#/VB Tips]

MailKitの使い方! エンコーディング指定や添付ファイをメールで送信する方法[C#/VB Tips]MailKitを使ってメールを送るサンプルコードです。(C#)UTF8/iso-2022-jpのエンコーディング指定、GMail/YahooのSMTPサーバで送るなど、4つのサンプルコードでMailKitの使い方を紹介します。MailKitって何?2017年に.NET標準のSystem.Net.Mail.SmtpClientが廃止予定となり、Microsoftより今後はオープンソースライブラリである、MailKitに置き換えるとアナウンスがありました。既にSmtpClientは非推奨になっており、今後は廃止されていきます。現在、SmtpClientを使用したソースコードには、Visual StudioからMailKitを使うよう警告が出るようになっています。さっそく、MailKitを使ってメールを送信するサンプルコードを作っていきます。UTF8でメールを送信文字エンコーディングを、UTF8でメールを送信するサンプルコードです。
MailKitは、デフォルトの文字エンコーディングがUTF8なっている為、シンプルなコードでメールを送信する事ができます。var host ="<smtp server name>"; var port =25;// or 587using(var smtp =new MailKit.Net.Smtp.SmtpClient()){//SMTPサーバに接続する smtp.Connect(host, port, MailKit.Security.SecureSocketOptions.Auto);//認証が必要な場合は、以下のコメントを解除//smtp.Authenticate("<id>", "<password>");//送信するメールを作成する var mail =new MimeKit.MimeMessage(); var builder =new MimeKit.BodyBuilder(); mail.From.Add(new MimeKit.MailboxAddress("",&quo…