[解決済み] DOMにまだ追加されていないJQueryオブジェクトにクリックイベントをアタッチする [重複]。
質問
DOMに追加する前にJQueryオブジェクトにclickイベントをアタッチするのに苦労しているんだ。
基本的に、私はこのボタンを持っていて、私の関数はそれをDOMに追加して返します。私が欲しいのは、それ自身のクリックハンドラでボタンを返すことです。ハンドラをアタッチするために、DOMからそれを選択したくありません。
私のコードはこうです。
createMyButton = function(data) {
var button = $('<div id="my-button"></div>')
.css({
'display' : 'inline',
'padding' : '0px 2px 2px 0px',
'cursor' : 'pointer'
}).append($('<a>').attr({
//'href' : Share.serializeJson(data),
'target' : '_blank',
'rel' : 'nofollow'
}).append($('<image src="css/images/Facebook-icon.png">').css({
"padding-top" : "0px",
"margin-top" : "0px",
"margin-bottom" : "0px"
})));
button.click(function () {
console.log("asdfasdf");
});
return button;
}
returnされたボタンはクリックイベントをキャッチできません。しかし、こうすると(ボタンがDOMに追加された後)。
$('#my-button').click(function () {
console.log("yeahhhh!!! but this doesn't work for me :(");
});
うまくいった...しかし、私の思い通りにはならない。
オブジェクトがまだDOMの一部になっていないことが関係しているようです。
ところで、私は OpenLayers を使っていて、ボタンを追加している DOM オブジェクトは OpenLayers.FramedCloud です (これはまだ DOM の一部ではありませんが、いくつかのイベントが発生したらそうなります。) 。
どのように解決するのですか?
これを使う。 domレディに存在する任意の親要素でbodyを置き換えることができます。
$('body').on('click', '#my-button', function () {
console.log("yeahhhh!!! but this doesn't work for me :(");
});
ここを見る http://api.jquery.com/on/ は、1.7以降でlive()に置き換わったon()の使用方法についての詳細です。
以下は、あなたが使用すべきバージョンの一覧です。
<ブロッククオート$(selector).live(events, data, handler); // jQuery 1.3+。
$(document).delegate(selector, events, data, handler); // jQuery 1.4.3+.
$(document).on(events, selector, data, handler); // jQuery 1.7+.
関連
-
HTML+CSS+JavaScriptで簡単な三目並べゲームを作成する。
-
vueにおけるfilterの適用シーンについて解説します。
-
[解決済み] TypeError: $.ajax(...) is not a function?
-
[解決済み】ERROR エラーです。スイッチのname属性が指定されていないフォームコントロールの値アクセッサがない
-
JavaScriptのgetElementById、getElementsByTagNam、getElementsByClassNameの違いと使い方
-
[解決済み] jQueryでJavaScriptオブジェクトから選択する際に、オプションを追加する最も良い方法は何ですか?
-
[解決済み] jQuery チェックボックスの変更とクリックイベント
-
[解決済み] jQueryやgetElementByIdのようなDOMメソッドが、要素を見つけられないのはなぜですか?
-
[解決済み] jQueryの複数要素の同一クリックイベント
-
[解決済み] jQueryオブジェクトのインスペクションからjQueryのバージョンを取得する
最新
-
nginxです。[emerg] 0.0.0.0:80 への bind() に失敗しました (98: アドレスは既に使用中です)
-
htmlページでギリシャ文字を使うには
-
ピュアhtml+cssでの要素読み込み効果
-
純粋なhtml + cssで五輪を実現するサンプルコード
-
ナビゲーションバー・ドロップダウンメニューのHTML+CSSサンプルコード
-
タイピング効果を実現するピュアhtml+css
-
htmlの選択ボックスのプレースホルダー作成に関する質問
-
html css3 伸縮しない 画像表示効果
-
トップナビゲーションバーメニュー作成用HTML+CSS
-
html+css 実装 サイバーパンク風ボタン
おすすめ
-
Vueの要素ツリーコントロールに破線を追加する説明
-
Vueのフォームイベントのデータバインディングの説明
-
[解決済み】Node.js getaddrinfo ENOTFOUND
-
[解決済み】Node.jsで "Cannot find module "エラーを解決するには?
-
[解決済み】JavaScript TypeError: null のプロパティ 'style' を読み取ることができない
-
[解決済み】React - TypeError: 未定義のプロパティ 'props' を読み取ることができない。
-
[解決済み】ERROR エラーです。スイッチのname属性が指定されていないフォームコントロールの値アクセッサがない
-
[解決済み】TypeScript-のAngular Frameworkエラー - "exportAsがngFormに設定されたディレクティブはありません"
-
[解決済み】React-Redux: アクションはプレーンオブジェクトでなければならない。非同期アクションにはカスタムミドルウェアを使用する
-
[解決済み] 動的に生成された要素にイベントバインディングを行うか?