質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

5148閲覧

createelementのimgタグのonclick属性付与

javascripter

総合スコア12

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2016/09/11 12:42

###前提・実現したいこと
windowonload時にcleatelementで作成したドキュメントにonclick属性を付与したい

###発生している問題・エラーメッセージ
ページがフリーズしてしまう。

###該当のソースコード

javascript

1 function addmasu() { 2 var iy=wy*35+35,ix=wx*35+255; 3 var element = document.createElement('img'); 4 element.src = "img/masu.png"; 5 element.id = "masu"+wy+""+wx+""; 6 element.style.position="absolute"; 7 element.style.left = ix; 8 element.style.top = iy; 9 element.onclick=move(); 10 11 var objBody = document.getElementsByTagName("body").item(0); 12 objBody.appendChild(element); 13 } 14 15 function move(){ 16 document.getElementById("masu01").style.top="10"; 17 }

###試したこと
ほかソースコードの確認

###補足情報(言語/FW/ツール等のバージョンなど)
javascript
ieバージョン 11.545.105.86.0

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

とりあえず2箇所問題があります。

JavaScript

1function addmasu( wx, wy ) { // wx, wy の定義が見当たらなかったので 2 var iy = wy * 35 + 35 3 , ix = wx * 35 + 255; 4 var element = document.createElement('img'); 5 element.src = 'https://placehold.jp/24/cc9999/993333/150x50.png'; 6 element.id = 'masu' + wy + '' + wx + ''; 7 element.style.position = 'absolute'; 8 element.style.left = ix; 9 element.style.top = iy; 10 //element.onclick = move(); 11 element.onclick = move; // ここ 12 13 var objBody = document.getElementsByTagName('body').item(0); 14 objBody.appendChild(element); 15} 16addmasu( 1, 1 ); // 実行するものが無かったので 17function move() {console.log( 'true' ); 18 document.getElementById('masu01').style.top = '10px'; // 単位が要る // ここ 19} 20```**動くサンプル:**[https://jsfiddle.net/eLvqcfxz/](https://jsfiddle.net/eLvqcfxz/)

投稿2016/09/11 15:08

kei344

総合スコア69398

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

javascripter

2016/09/11 21:40

onClick属性をつけることはできました。 しかし関数に引数をつけることができないので、引数をつける方法がありました教えてください。
guest

0

自己解決

element.onclick = new Function("move();");

と記述したら期待度売りの動作が得られました!
ありがとうございました

投稿2016/09/11 21:48

javascripter

総合スコア12

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問