REPOP WEBツール倉庫

ブラウザだけで完結する便利なWEBツール、WEBアプリが沢山あります

MutationObserver()を利用したJavaScriptコードの動作確認ツール

MutationObserver()を利用したJavaScriptコードの動作確認ツール

DOMの変更(要素の追加・削除、属性変化など)を監視するMutationObserver()の動作をリアルタイムで確認できます。

プレビュー

<div class="dom-controls">
	<button type="button" id="btn-add">追加</button>
	<button type="button" id="btn-remove">削除</button>
	<button type="button" id="btn-attr">属性変更</button>
	<button type="button" id="btn-text">テキスト変更</button>
</div>

<div id="elements">
	<span class="child-node">0</span>
</div>

<div id="mutation-log"></div>
/* DOM要素 */
	#elements {
	padding: 20px;
	margin-top: 15px;
	min-height: 60px;
}

.child-node {
	display: inline-block;
	background: #2a9271;
	color: #fff;
	padding: 4px 8px;
	margin: 5px;
	border-radius: 4px;
}

.child-node.set-attribute {
	display: inline-block;
	background: #000;
	color: #fff;
	padding: 4px 8px;
	margin: 5px;
	border-radius: 4px;
}

/* ログ */
#mutation-log {
	width: 80%;
	margin-top: 20px;
	background: #222;
	color: #0f0;
	font-family: monospace;
	padding: 10px;
	height: 150px;
	overflow-y: auto;
	border-radius: 4px;
	font-size: 13px;
	line-height: 1.4;
}

.log-entry {
	border-bottom: 1px solid #333;
	padding: 2px 0;
}

.log-time {
	color: #888;
	margin-right: 8px;
}

.log-type {
	color: #ffd700;
	font-weight: bold;
	margin-right: 8px;
}
const target = document.querySelector('#elements');
const logArea = document.querySelector('#mutation-log');

// --- ボタン操作処理 ---

// 子要素を追加
document.querySelector('#btn-add').addEventListener('click', () => {
	if (!target) return;
	
	// 新しい子要素を作成
	const span = document.createElement('span');
	span.className = 'child-node';
	span.textContent = '' + (target.querySelectorAll('.child-node').length + 1);
	target.appendChild(span);
});

// 子要素を削除
document.querySelector('#btn-remove').addEventListener('click', () => {
	if (!target) return;

	// 最後の子要素を削除
	const last = target.querySelector('.child-node:last-child');
	if (!last) return;
	last.remove();
});

// 属性を変更
document.querySelector('#btn-attr').addEventListener('click', () => {
	if (!target) return;
	const children = target.querySelectorAll('.child-node');
	if (children.length === 0) return;

	// すべての子要素のclass属性を変更
	children.forEach(child => {
		const current = child.getAttribute('class');
		child.setAttribute('class', current === 'child-node set-attribute' ? 'child-node' : 'child-node set-attribute');
	});
});

// テキストを変更
document.querySelector('#btn-text').addEventListener('click', () => {
	if (!target) return;
	const children = target.querySelectorAll('.child-node');
	if (children.length === 0) return;

	// すべての子要素のテキストをランダムな英字に変更
	const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ';
	children.forEach(child => {
		child.textContent = chars.charAt(Math.floor(Math.random() * chars.length));
	});
});


// --- MutationObserver()での監視処理 ---
const observer = new MutationObserver((mutations) => {
	mutations.forEach((mutation) => {
		const div = document.createElement('div');
		div.className = 'log-entry';

		const time = `<span class="log-time">[${new Date().toLocaleTimeString()}]</span>`;
		const type = `<span class="log-type">${mutation.type}</span>`;
		let details = '';

		if (mutation.type === 'childList') {
			const changes = [];
			if (mutation.addedNodes.length > 0) changes.push(`要素を追加: ${mutation.addedNodes.length}`);
			if (mutation.removedNodes.length > 0) changes.push(`要素を削除: ${mutation.removedNodes.length}`);
			details = changes.join(', ');
		} else if (mutation.type === 'attributes') {
			details = `属性を変更: ${mutation.attributeName}`;
		} else if (mutation.type === 'characterData') {
			details = `テキストを変更`;
		}

		// ログを出力
		div.innerHTML = `${time}${type}${details}`;
		logArea.insertBefore(div, logArea.firstChild);
	});
});

// 監視を開始(デフォルト:すべてのオプションを有効)
observer.observe(target, {
	childList: true,      // 子要素の追加・削除
	attributes: true,     // 属性の変更
	subtree: true,        // 孫要素以降も監視
	characterData: true   // テキストノードの変更
});

機能・使い方

JavaScriptのMutationObserver()を使用して、DOM要素の変化を監視するコードを生成・テストするツールです。

プレビューエリアのボタン(要素追加・削除など)を操作すると、DOM変更に対応してログが表示されます。

このツールでは、上記すべての変更を監視対象としています。

公開日 :
更新日 :
3Dに傾く透過カードのCSSジェネレーター

3Dに傾く透過カードのCSSジェネレーター

マウスの動きに合わせて傾き、表面に光が反射したような効果を持つ透過カードのデザインを生成します。

JavaScript カラーコード変換実装コード生成ツール

JavaScript カラーコード変換実装コード生成ツール

HEX(16進数)やRGBなどのカラーコードを相互に変換するJavaScriptの実装コードを生成します。

JavaScriptでマウスホイールの回転方向を検出する実装コード

JavaScriptでマウスホイールの回転方向を検出する実装コード

JavaScriptでマウスホイールの回転方向(上・下)を検出するイベントの実装コードを生成します。

JavaScriptで現在時刻をリアルタイムに表示するコード生成ツール

JavaScriptで現在時刻をリアルタイムに表示するコード生成ツール

現在時刻をリアルタイムに更新・表示するJavaScriptコードを生成します。フォーマットをカスタマイズ可能です。

スクロール量で背景色を変化させるJSコード生成ツール

スクロール量で背景色を変化させるJSコード生成ツール

スクロール量に応じて背景色を滑らかに変化させるJavaScriptコードを生成します。色の段階や切り替え位置を自由に設定可能です。

JavaScriptでクリックを検出するイベントの動作テストツール

JavaScriptでクリックを検出するイベントの動作テストツール

右クリックや左クリック、またはダブルクリックを検出するJavaScriptのイベント動作テストができます。

JavaScriptでHTTPSかどうかを判定する動作テストツール

JavaScriptでHTTPSかどうかを判定する動作テストツール

現在のページがHTTPSでアクセスされているか、HTTPでアクセスされているかを判定するJavaScriptコードを生成します。

JavaScriptの長押しイベントを実装するコード生成ツール

JavaScriptの長押しイベントを実装するコード生成ツール

左クリックやタップ長押しのイベントを実装するためのJavaScriptコードを生成します。長押しの時間設定や動作確認が可能です。

JavaScriptのcloneNode()を利用した動作確認ツール

JavaScriptのcloneNode()を利用した動作確認ツール

JavaScriptのcloneNode()を使ってHTML要素を複製数するコードを生成し、動作を確認できます。

JavaScriptの経過時間を表示するコード生成ツール

JavaScriptの経過時間を表示するコード生成ツール

ページ読み込み時や特定の日時からの経過時間を表示するコードを生成します。秒のみ、日時分秒などの形式を選択可能です。

» もっと見る
JSONJavaScriptHTMLCSSSVGPHPPython画像処理色、カラーコード
画像のフチぼかし(透過グラデーションマスク)のCSSジェネレーター

画像のフチぼかし(透過グラデーションマスク)のCSSジェネレーター

画像の端を透過グラデーションでぼかし、背景と滑らかに馴染ませるエフェクトを生成します。mask-imageを使用し、上下左右や円形など複数の方向にフェードアウト可能です。

文字の中に画像(マスクテキスト)のCSSジェネレーター

文字の中に画像(マスクテキスト)のCSSジェネレーター

指定した画像を文字の形に切り抜き、インパクトのあるテキストエフェクトを生成します。グラフィカルな見出しやタイトルの作成に適しています。

フリッカー・ネオン(点滅ネオン)のCSSジェネレーター

フリッカー・ネオン(点滅ネオン)のCSSジェネレーター

不規則な点滅を繰り返す、リアリティのあるネオンサイン文字のエフェクトを生成します。多重シャドウによる発光と透明度の変化で、レトロな雰囲気を演出します。

虹色に輝く枠線(レインボー・ローテート)のCSSジェネレーター

虹色に輝く枠線(レインボー・ローテート)のCSSジェネレーター

枠線が虹色に変化しながら回転し続ける視覚効果を生成します。conic-gradientを活用し、画像不要で軽量な実装が可能です。

ぷかぷか浮遊(フローティング演出)のCSSジェネレーター

ぷかぷか浮遊(フローティング演出)のCSSジェネレーター

要素が空中を漂うような、浮遊アニメーションを生成するツールです。

ぼんやり光るオーラ(グロー・オーラ)のCSSジェネレーター

ぼんやり光るオーラ(グロー・オーラ)のCSSジェネレーター

要素の背後に柔らかい発光エフェクトを追加し、呼吸するように明滅するアニメーションを付与するツールです。

文字の打ち込み演出(タイプライター)CSSジェネレーター

文字の打ち込み演出(タイプライター)CSSジェネレーター

文字が1文字ずつタイピングされるようなアニメーション効果を生成するCSSジェネレーターです。

物理的に押し込むボタン(3Dプッシュボタン)のCSSジェネレーター

物理的に押し込むボタン(3Dプッシュボタン)のCSSジェネレーター

クリックした際に沈み込むような、厚みのある3Dボタンを生成します。奥行き、押し込み感、カラーを直感的に調整可能です。

鏡面反射(ミラーリフレクション)のCSSジェネレーター

鏡面反射(ミラーリフレクション)のCSSジェネレーター

画像やテキストに対して鏡面反射(リフレクション)エフェクトを適用するCSSを生成します。方向、距離、不透明度を調整可能です。

円を描く文字(円形テキスト)のCSSジェネレーター

円を描く文字(円形テキスト)のCSSジェネレーター

入力したテキストを円形や半円に沿って配置。半径や回転角、文字の間隔を個別に調整して、円形状のタイポグラフィを作成できます。

» もっと見る