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変更に対応してログが表示されます。

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

JSONとJSオブジェクトの相互変換ツール

JSONとJSオブジェクトの相互変換ツール

JSONコードとJavaScriptのオブジェクト(Object)コードを相互変換します。

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

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

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

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

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

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

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

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

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

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

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

スクロールして要素が画面内に入ったことを検知し、アニメーション表示させるコードを生成します。移動距離や時間を調整可能です。

JavaScriptのscrollIntoView()を利用した画面スクロールの動作確認ツール

JavaScriptのscrollIntoView()を利用した画面スクロールの動作確認ツール

要素の位置までスムーズにスクロールするscrollIntoView()の動作を確認できます。オプション(behavior, block)の効果を視覚的に試せます。

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

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

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

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

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

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

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

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

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

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

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

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

» もっと見る
JSONJavaScriptHTMLCSSPHPPython画像処理色、カラーコード
PNG/JPG to WebP

PNG/JPG to WebP

高品質を維持したまま、PNG/JPGをWebPに変換し圧縮します。

SVG to PNG/JPG/WebP

SVG to PNG/JPG/WebP

SVG画像をPNG, JPG, WebPに変換。解像度を指定してラスタライズできます。

カラーピッカーツール

カラーピッカーツール

美しいカラーパレットから色を選んでコピー。HEX, RGB, RGBA、カラーネームに対応。

JSONとPHP配列の相互変換ツール

JSONとPHP配列の相互変換ツール

JSONコードとPHP配列コードを相互変換

JSONとPython辞書の相互変換ツール

JSONとPython辞書の相互変換ツール

JSONコードとPythonの辞書型(dict)コードを相互変換します。

HTMLタグ除去・抽出ツール

HTMLタグ除去・抽出ツール

HTMLコードからタグを除去し、テキストデータのみを抽出します。実体参照のデコードや空白処理も可能です。

HTMLエスケープツール

HTMLエスケープツール

HTMLの特殊文字(<, >, &, " 等)を実体参照に変換(エスケープ)、または元に戻す(アンエスケープ)ツールです。

HTMLテーブル1行目をヘッダーセクションに変換

HTMLテーブル1行目をヘッダーセクションに変換

テーブルの1行目をthead要素、最後の行をtfoot要素に変換します。WordPressのヘッダーセクションに対応。ExcelやWebからコピーした表もOK。スタイル属性やタブ・改行の一括削除機能付き。

JSONとCSVの相互変換ツール

JSONとCSVの相互変換ツール

JSON配列とCSVデータを相互に変換します。ヘッダーの有無も切り替え可能です。

WebP to PNG/JPG 変換ツール

WebP to PNG/JPG 変換ツール

WebP画像をPNGまたはJPG形式に変換します。JPEG画質の調整も可能です。

» もっと見る