javascriptで<INPUT type=file name=faile1>を
file1.click();でクリックしてファイル選択ダイアログを表示させようとしても表示しません。
formから
<INPUT type=file id=file1 name=image style="DISPLAY: none">
<INPUT type="image" src="./img/up02.jpg" id=button1 value=Button name=button1
を出すとファイル選択ダイアログが表示されます。
独自のボタンイメージでファイル選択ダイアログを表示したいために
<INPUT type="image"をクリックされたときにjavascriptで
<INPUT type=file をクリックさせています。
したいことは、独自のボタンで、ファイル選択ダイアログを表示して、
phpに選択されたファイルパスを送信したいです。
下記コードをご参考にしてください。
<html>
<head>
<title>upload test</title>
</head>
<body>
何かの編集ページとか
<iframe name="uploader" src="" style="width:0px;height:0px;border:0px;"></iframe>
<form name=form1 target="uploader" method="POST" action="http://*.**.**.*/test.php" enctype="multipart/form-data">
<INPUT type=file id=file1 name=image style="DISPLAY: none">
<INPUT type="image" src="./img/up02.jpg" id=button1 value=Button name=button1 LANGUAGE=javascript onclick="return button1_onclick()"/>
</form>
<script type="text/javascript">
<!--
function button1_onclick() {
window.alert("クリックされた");
file1.click();
document.form1.submit();
}
//-->
</script>
</body>
</html>
No.1ベストアンサー
- 回答日時:
直接の原因は
>file1.click();
で要素が取得できていないからではないでしょうか?
引数で this.form を渡してあげるか、あるいは直接に
document.forms["form1"].elements["file1"].click();
みたいに指定してあげればよろしいかと。
ただし、IE以外はテキストボックスをクリックできないみたいなので、DOM Event で発火してあげたほうがよさそう。
http://d.hatena.ne.jp/language_and_engineering/2 …
ついでに・・・
ダイアログをキャンセルした場合はどうするのだろうか?
コメント入れたはずなのに??再度入力してます
ありがとうございます
おっしゃる通りです。気づけなかったorz
javascriptのみで今回の機能の実装はできないと判断したので
違ったアプローチで行きたいと思います。
出来るだけ、javascriptとhtmlで実装したかったのですが
そうも言ってられないので、ajaxなどでアプローチしたいとも思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- HTML・CSS CSSが効かずどのように指定すれば良いか分からないのでアドバイスお願い致します 2 2023/06/07 12:25
- JavaScript clear機能を失わずにファイルアップロード機能を作成したい 3 2023/06/10 16:12
- JavaScript ①入力フォーム→②確認表示画面→③送信完了画面のコードを書いているのです、 入力フォームから受け取っ 2 2022/05/10 16:45
- JavaScript アップロードファイルの種類によって処理を分岐させたいのですが書き方が分からずアドバイスお願いします 4 2023/06/17 19:12
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- HTML・CSS ボタンをクリックした時に、入力フォームのすぐ下部に、「入力欄が空白です」というテキストメッセージが表 1 2022/04/27 16:25
- PHP PHP MySql 画像を取得 1 2022/06/04 14:05
- JavaScript javascript作成してます。ラジオボタンで判定するコードを書いてます。 1 2023/07/18 11:03
- JavaScript javascriptのちょっとした動作不良(原因は突き止めたのですが) 1 2023/06/15 19:58
- PHP PHP MySQLに画像を直接保存 2 2022/06/05 11:50
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・「みんな教えて! 選手権!!」開催のお知らせ
- ・漫画をレンタルでお得に読める!
- ・「黒歴史」教えて下さい
- ・2024年においていきたいもの
- ・我が家のお雑煮スタイル、教えて下さい
- ・店員も客も斜め上を行くデパートの福袋
- ・食べられるかと思ったけど…ダメでした
- ・【大喜利】【投稿~12/28】こんなおせち料理は嫌だ
- ・前回の年越しの瞬間、何してた?
- ・【お題】マッチョ習字
- ・モテ期を経験した方いらっしゃいますか?
- ・一番最初にネットにつないだのはいつ?
- ・好きな人を振り向かせるためにしたこと
- ・【選手権お題その2】この漫画の2コマ目を考えてください
- ・2024年に成し遂げたこと
- ・3分あったら何をしますか?
- ・何歳が一番楽しかった?
- ・治せない「クセ」を教えてください
- ・【大喜利】【投稿~12/17】 ありそうだけど絶対に無いことわざ
- ・【選手権お題その1】これってもしかして自分だけかもしれないな…と思うあるあるを教えてください
- ・集合写真、どこに映る?
- ・自分の通っていた小学校のあるある
- ・フォントについて教えてください!
- ・これが怖いの自分だけ?というものありますか?
- ・スマホに会話を聞かれているな!?と思ったことありますか?
- ・それもChatGPT!?と驚いた使用方法を教えてください
- ・見学に行くとしたら【天国】と【地獄】どっち?
- ・これまでで一番「情けなかったとき」はいつですか?
- ・この人頭いいなと思ったエピソード
- ・あなたの「必」の書き順を教えてください
- ・10代と話して驚いたこと
- ・14歳の自分に衝撃の事実を告げてください
- ・人生最悪の忘れ物
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
二つの入力欄に、同時に同じ文...
-
ASP.NETでNAME属性を固定にしたい
-
doPostBack 関数について
-
【jQuery】input nameの文字列...
-
ファイル選択ダイアログが表示...
-
テキストボックスの入力をリセット
-
JavaScriptにて動的に配列を作...
-
エクセル マクロ submitについて
-
新しくフォルダを作成したい
-
テキストボックスの値同士を比...
-
javascriptとPHPで入力フォーム...
-
ラジオボタンでクリックした値...
-
return trueとreturn falseの用...
-
Selectボックスの幅を自動で広...
-
プルダウン 項目が多いので先頭...
-
<input>の選択肢をプルダウンメ...
-
フォーム内で記入したクエリ送...
-
hiddenのvalueの値を変えたい
-
onclickが動作しない
-
[Javascript]セル内の文字列の...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【jQuery】input nameの文字列...
-
新しくフォルダを作成したい
-
Javascriptでのbuttonのname属...
-
ラジオボタンでクリックした値...
-
二つの入力欄に、同時に同じ文...
-
ASP.NETでNAME属性を固定にしたい
-
cookie使用時にundefinedと表示...
-
JavaScriptにて動的に配列を作...
-
テキストボックスの入力をリセット
-
name属性のないformタグの、中...
-
複数のテキストフィールドを同...
-
GETパラメータの内、空文字のク...
-
動的にTabindexの値を変えたい!
-
テキストボックスの値同士を比...
-
ファイル選択ダイアログが表示...
-
submitボタン押下時にPOSTされ...
-
ボタンを押すとテキストボック...
-
入力フォームに半角スペース以...
-
エクセル マクロ submitについて
-
jquery.validate.jsについて
おすすめ情報