ページ上のログインまたは登録ボタンをクリックすると、ポップアップレイヤーであるモーダルウィンドウが表示され、ポップアップレイヤー上でログインフォームと登録フォームを簡単に切り替えることができ、非常に便利です。ユーザーにとっては、レイヤーをクリックして他の操作に切り替える必要はありません。これは多くの Web サイトで広く使用されています。
この記事では、jQuery と CSS3 および HTML5 テクノロジーを使用してこの効果を実現する例を組み合わせています。
HTML
メイン ページに 2 つのリンク ボタン、つまりログイン ボタンと登録ボタンが追加されました。
<nav class="main_nav"> <ul> <li><a class="cd-signin" href="#0">登录</a></li> <li><a class="cd-signup" href="#0">注册</a></li> </ul> </nav>
次に、モーダル ウィンドウのポップアップ レイヤー div.cd-user-modal を作成し、ポップアップ レイヤーに ul.cd-switcher を切り替えるための 2 つのリンクを配置し、div に対応するログイン フォームと登録フォームを配置します。 #cd-ログインと div#cd-signup。
<div class="cd-user-modal"> <div class="cd-user-modal-container"> <ul class="cd-switcher"> <li><a href="#0">用户登录</a></li> <li><a href="#0">注册新用户</a></li> </ul> <div id="cd-login"> <form class="cd-form"> <!-- 登录表单 --> </form> </div> <div id="cd-signup"> <form class="cd-form"> <!-- 注册表单 --> </form> </div> </div> </div>
上記は HTML 構造全体であり、フォーム部分は省略しています。必要に応じてフォーム構造を自由に記述できます。また、ソース コードを直接ダウンロードして表示することもできます。
CSS
デフォルトのモーダルウィンドウには、visibility: hidden; および opacity: 0; のスタイルがあり、デフォルトでは非表示になります。 .is-visible を使用して、ディスプレイをポップアップするかどうかを決定します。以下は主要な CSS コードです。詳細な CSS コードについては、ソース コードをダウンロードしてご覧ください。
.cd-user-modal { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(52, 54, 66, 0.9); z-index: 3; overflow-y: auto; cursor: pointer; visibility: hidden; opacity: 0; -webkit-transition: opacity 0.3s 0, visibility 0 0.3s; -moz-transition: opacity 0.3s 0, visibility 0 0.3s; transition: opacity 0.3s 0, visibility 0 0.3s; } .cd-user-modal.is-visible { visibility: visible; opacity: 1; -webkit-transition: opacity 0.3s 0, visibility 0 0; -moz-transition: opacity 0.3s 0, visibility 0 0; transition: opacity 0.3s 0, visibility 0 0; } .cd-user-modal.is-visible .cd-user-modal-container { -webkit-transform: translateY(0); -moz-transform: translateY(0); -ms-transform: translateY(0); -o-transform: translateY(0); transform: translateY(0); } .cd-user-modal-container { position: relative; width: 90%; max-width: 600px; background: #FFF; margin: 3em auto 4em; cursor: auto; border-radius: 0.25em; -webkit-transform: translateY(-30px); -moz-transform: translateY(-30px); -ms-transform: translateY(-30px); -o-transform: translateY(-30px); transform: translateY(-30px); -webkit-transition-property: -webkit-transform; -moz-transition-property: -moz-transform; transition-property: transform; -webkit-transition-duration: 0.3s; -moz-transition-duration: 0.3s; transition-duration: 0.3s; } .cd-user-modal-container .cd-switcher:after { content: ""; display: table; clear: both; } .cd-user-modal-container .cd-switcher li { width: 50%; float: left; text-align: center; } .cd-user-modal-container .cd-switcher li:first-child a { border-radius: .25em 0 0 0; } .cd-user-modal-container .cd-switcher li:last-child a { border-radius: 0 .25em 0 0; } .cd-user-modal-container .cd-switcher a { display: block; width: 100%; height: 50px; line-height: 50px; background: #d2d8d8; color: #809191; } .cd-user-modal-container .cd-switcher a.selected { background: #FFF; color: #505260; } #cd-login, #cd-signup { display: none; } #cd-login.is-selected, #cd-signup.is-selected{ display: block; }
jQuery
ポップアップ レイヤーのポップアップ効果と閉じる効果は、style.is-visible 呼び出しを使用して jQuery によって制御され、切り替えフォームは、demo.is-selected 呼び出しを使用して jQuery によって制御されます。
jQuery(document).ready(function($){ var $form_modal = $('.cd-user-modal'), $form_login = $form_modal.find('#cd-login'), $form_signup = $form_modal.find('#cd-signup'), $form_modal_tab = $('.cd-switcher'), $tab_login = $form_modal_tab.children('li').eq(0).children('a'), $tab_signup = $form_modal_tab.children('li').eq(1).children('a'), $main_nav = $('.main_nav'); //弹出窗口 $main_nav.on('click', function(event){ if( $(event.target).is($main_nav) ) { // on mobile open the submenu $(this).children('ul').toggleClass('is-visible'); } else { // on mobile close submenu $main_nav.children('ul').removeClass('is-visible'); //show modal layer $form_modal.addClass('is-visible'); //show the selected form ( $(event.target).is('.cd-signup') ) ? signup_selected() : login_selected(); } }); //关闭弹出窗口 $('.cd-user-modal').on('click', function(event){ if( $(event.target).is($form_modal) || $(event.target).is('.cd-close-form') ) { $form_modal.removeClass('is-visible'); } }); //使用Esc键关闭弹出窗口 $(document).keyup(function(event){ if(event.which=='27'){ $form_modal.removeClass('is-visible'); } }); //切换表单 $form_modal_tab.on('click', function(event) { event.preventDefault(); ( $(event.target).is( $tab_login ) ) ? login_selected() : signup_selected(); }); function login_selected(){ $form_login.addClass('is-selected'); $form_signup.removeClass('is-selected'); $form_forgot_password.removeClass('is-selected'); $tab_login.addClass('selected'); $tab_signup.removeClass('selected'); } function signup_selected(){ $form_login.removeClass('is-selected'); $form_signup.addClass('is-selected'); $form_forgot_password.removeClass('is-selected'); $tab_login.removeClass('selected'); $tab_signup.addClass('selected'); } });
この例は、CSS3 効果を使用しているため、携帯電話などのモバイル デバイスでも適切な表示効果を発揮します。IE ブラウザを使用している場合は、バージョンを IE9 以降にアップグレードしてください。ソース コードをダウンロードし、わずかな変更を加えてプロジェクトに直接適用することを強くお勧めします。
以上がこの記事の全内容です。皆さんに気に入っていただければ幸いです。