CSS と JavaScript を使用してマウス ホバー時のテキストの色を反転する
目的のホバー効果を実現するには、黒のテキストが白に反転しますが、黒いカーソルが表示されるように、CSS クリップパスの機能と JavaScript イベント処理を組み合わせることができます。
このアプローチは、プライマリ テキスト レイヤーと反転テキスト レイヤーの 2 つのテキスト レイヤーを作成することで構成されます。反転テキスト レイヤーはプライマリ テキスト レイヤーの背後に配置され、テキストの色は白に設定されています。
JavaScript を使用して、マウスの動きをキャプチャし、反転テキスト レイヤーのクリップ パスを動的に調整します。マウスが動くと、クリップ パスが調整されて反転テキストがより多く表示され、メイン テキストの色が反転しているように見えます。
主要なコード コンポーネントの内訳は次のとおりです:
/* Primary Text Layer */
h1 {
color: #000;
position: relative;
}
/* Inverted Text Layer */
h1:before {
position: absolute;
content: attr(data-text); /* Same text as primary layer */
color: #fff;
background: #000;
clip-path: circle(0 at var(--x, -100%) var(--y, -100%)); /* Dynamic Clip-path */
}
/* Cursor */
.cursor {
position: fixed;
width: 40px;
height: 40px;
background: #000;
border-radius: 50%;
transform: translate(-50%, -50%);
z-index: -2;
}
// Event Listener for Mouse Movement
document.body.onmousemove = function(e) {
// Update cursor position
cursor.style.left = e.clientX 'px';
cursor.style.top = e.clientY 'px';
// Update clip-path of inverted layer based on mouse position
h1.style.setProperty('--x', (e.clientX - p.top) 'px');
h1.style.setProperty('--y', (e.clientY - p.left) 'px');
};
コード例:
WORK
結果:
「WORK」テキストの上にマウスを置くと、黒いテキストが徐々に白に変わります。マウスカーソルの移動に合わせて
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3