この記事では、JavaScript メッセージ ボードでメッセージを追加および削除する小さな例を詳細なコード分析とともに紹介しますが、データベース操作は含まれず、基礎となるコード実装のアイデアのみを分析します。 成果を達成するコードインターフェースを実行: 追加するメッセージを入力してください: (最新のメッセージが一番上に表示されます) メッセージを削除: (メッセージをクリックすると削除されます) 主な機能と効果を示します。HTML および CSS スタイルはここでは影響を受けません。JS コードを以下に示します。 <スクリプト> // 必要な要素オブジェクトを取得します。var text = document.querySelector('textarea'); var btn = document.querySelector('ボタン'); var ul = document.querySelector('ul'); // イベントを登録します btn.onclick = function () { // クリック イベントを公開ボタンにバインドします if (text.value == '') { // text.value が空かどうか、つまりユーザーが入力したコンテンツがあるかどうかを判断します alert('空のコンテンツを公開することはできません!'); false を返します。 } else { // ユーザーが入力したコンテンツがある場合、そのコンテンツが取得され、作成された要素 li に割り当てられて表示されます // 1. 要素を作成します var li = document.createElement('li'); li.innerHTML = text.value + "<a href='javascript:;' title='このメッセージを削除'>削除</a>"; // ユーザーが入力したコンテンツを、作成された li 要素に割り当て、その後のメッセージ削除のために末尾に a タグを追加します // 2. 要素を追加します // ul.appendChild(li); // この方法では、メッセージが後で表示されます ul.insertBefore(li, ul.children[0]); // 新しく追加されたメッセージを一番上に、つまり下から上の順序で表示します // 要素を削除します: 現在の a タグが配置されている li ノード、つまりその親要素を削除します var as = document.querySelectorAll('a'); (var i = 0; i < as.length; i++) の場合 { as[i].onclick = 関数(){ // 削除される li 要素は a の親要素、つまり this.parentNode です。 ul.removeChild(this.parentNode); // ul 内の li ノードを削除します。li は現在の a タグの親ノードなので、それらの関係に注意してください。} } } text.value = ''; // 最後に、別のメッセージを表示できるようにメッセージ入力ボックスの内容をクリアします} </スクリプト> コア知識:ページに要素ノードを追加します。 2つのステップでページに新しい要素を追加します。1 . 要素を作成する。2. 要素を追加する 1. 要素を作成します: element.createElement('created element tag'); ページ要素ノードを削除します。 node.removeChild(child); // node は親要素、child は node 内の子要素です 主な実装アイデア:ここでは、主にページにノードを追加する機能とノードを削除する機能を使用し、2 つの機能を異なるボタンにバインドします。たとえば、ノードを追加する機能は「公開」ボタンに与えられ、ノードを削除する機能は「削除」ボタンに与えられ、これにより、メッセージ ボード ケースの簡易バージョンが実現されます。詳細な分析を行うには、JS コードと詳細なコメントを組み合わせることをお勧めします。 以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。 以下もご興味があるかもしれません:
|
>>: MySQL クロスデータベーストランザクション XA 操作の例
Linux に Scala 環境をインストールするのは非常に簡単です。Ubuntu 環境であれば、さ...
目次序文フロントエンド構造バックエンド構造(ノード+エクスプレス) FormDataに基づくファイル...
1. 削除delete は、オブジェクトのプロパティを残さずに削除する唯一の方法ですが、その「代替」...
Docker はコンテナを起動するときにアクセス ポートを指定します。複数の -p オプションを使用...
序文ストレス テスト中に、リソース使用のボトルネックによって発生する最も直接的なパフォーマンスの問題...
1. AデータベースとBデータベースの同期ステータスを確認する次のコマンドを入力すると多くの情報が表...
MongoDB は高性能なデータベースですが、使用していくうちにパフォーマンスの問題が発生することが...
サーバーB(172.17.166.11)の電源がオンまたは再起動されると、サーバーA(172.17....
目次render.js 部分create-context.js 部分差分部分Reactのソースコード...
テーブルを美しくするために、セルごとに異なる境界線の色を設定できます。基本的な構文<TD 境界...
01. コマンドの概要dirname - ファイル名からディレクトリ以外のサフィックスを削除しますd...
1. まず、純粋なHTMLファイルにはindex.htmlというエントリが必要です。 2. Tomc...
ケース1 vue-cliはvue3プロジェクトをビルドし、プロジェクトをLinuxサーバーにアップロ...
この記事では、Web ページを作成する前に確認すべき、いわゆる仕様をいくつかまとめました。皆様のお役...
zip インストール パッケージをダウンロードします。 MySQL8.0 For Windows z...