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

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

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

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

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

Smarty

Smartyは、PHPアプリケーションで使用されるテンプレートエンジンです。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

Q&A

解決済

3回答

1566閲覧

JavaScriptで配列の取得

Takanori

総合スコア26

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

JavaScript

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

Smarty

Smartyは、PHPアプリケーションで使用されるテンプレートエンジンです。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

0グッド

0クリップ

投稿2015/12/01 02:47

tpl側に下記のformを作成して

<form method="post" name="print" action="/hoge/hogehoge/"> ホゲコード:<select name="hoge_id[]" multiple> <option value="b">b</option> <option value="b1">b1</option> <option value="b2">b2</option> <option value="r">r</option> <option value="r1">r1</option> </select><br> <input type="button" value="Excel出力" onclick="func_submit();"> </form>

共通のjsファイルに下記のメソッドを定義
function func_submit() {
alert(document.print.hoge_id[].value);
}

とりあえずjsで上手く取得できているかalertで確認したいのですが、hoge_id[]はjs側ではどのように書いたらよろしいでしょうか?

配列以外の他のリストの値等は取得できるのですが(alert(document.print.hoge.value);など)配列の書き方がわかりません。

初歩的な質問で申し訳ないのですが、どなたかご教示頂けませんでしょうか。

何卒、宜しくお願い致します。

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

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

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

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

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

think49

2015/12/01 04:28

https://teratail.com/help を参考に markdown で書いていただけるとコードが読みやすくなる為、助かります。 蛇足ですが、form[name] は使用せず、form[id] を使用する事をお勧めします。
guest

回答3

0

func_submit() の名前から submit する事を期待しているようなので onsubmit で待つのが適切ではないかと思います。

HTML

1<script> 2'use strict'; 3function handleSubmit (event) { 4 var form = event.target || event.srcElement, 5 options = form.elements['hoge_id[]'].options, 6 values = []; 7 8 for (var i = 0, l = options.length, option; i < l; ++i) { 9 option = options[i]; 10 11 if (option.selected) { 12 values.push(option.value); 13 } 14 } 15 16 console.log(values); 17 18 event.preventDefault ? event.preventDefault() : event.returnValue = false; // 検証用(本番では外して下さい) 19} 20</script> 21<body> 22<form method="post" name="print" action="/hoge/hogehoge/" onsubmit="handleSubmit(event);"> 23 <select name="hoge_id[]" multiple> 24 <option value="b">b</option> 25 <option value="b1">b1</option> 26 <option value="b2">b2</option> 27 <option value="r">r</option> 28 <option value="r1">r1</option> 29 </select> 30 <input type="submit" value="Excel出力"> 31</form>

Re: Takanori さん

投稿2015/12/01 04:03

think49

総合スコア18162

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

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

0

ベストアンサー

これでどうですか。

javascript

1alert( 2 Array.prototype.map.call( 3 document.print['hoge_id[]'].querySelectorAll(':checked'), 4 function(e){ return e.value } 5 ) 6);

投稿2015/12/01 03:33

Lhankor_Mhy

総合スコア36080

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

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

think49

2015/12/01 04:25 編集

:checked は select[option] を走査しない為、document.print['hoge_id[]'].querySelectorAll(':checked') は空の NodeList を返します。 Lhankor_Mhy さんが期待するコードは次のようになると思います。 Array.prototype.filter.call(document.forms['print']['hoge_id[]'].options, function (option) { console.log(option); return option.selected; }).map(function (option) { return option.value; }); 残念ながら、:selected な擬似クラスは Selectors API Level 4 にも存在しません。
Lhankor_Mhy

2015/12/01 04:48

うーん、でも実際には動作するんですよね…… 「動作しても仕様に反するからダメだ」ということでしたら納得したいのですが、これはCSS3の仕様だと理解していましたが、違いましたでしょうか。 > For example, the :checked pseudo-class initially applies to such elements that have the HTML4 selected and checked attributes as described in Section 17.2.1 of HTML4 https://drafts.csswg.org/selectors-3/#checked お教えをいただけますと幸いです。必要であれば質問を立てます。
think49

2015/12/01 05:31

すみません。仰る通り、確かに動作しますね。 動作しない事の確認もしていたつもりでしたが、コード上で問題があったようです。失礼致しました。 http://jsfiddle.net/L3gfzats/1/ Selectors API Level 4 をもう一度、読み直してみたところ、HTML Living Standard へのリンクがあり、selected option elements も対象に含まれていましたので仕様的にも問題なさそうです。お騒がせしました。m(_ _)m https://html.spec.whatwg.org/multipage/scripting.html#selector-checked
Lhankor_Mhy

2015/12/01 06:18

いえ、ご指摘ありがとうございます。 ご提示いただいたURLがとても参考になります。ブックマークさせていただきました。
Takanori

2015/12/10 06:51

Lhankor_Mhyさんやり方で解決致しましたので、ベストアンサーにさせて頂きます。 他の方もご回答、コードの書き方のご指摘などありがとうございました。
guest

0

やりたいことがよくわかっていないのですがconsole.logでオブジェクトを取得して中身を見れば良いのでは無いでしょうか?
配列として欲しいならQuerySelecterやXpath等でhtmlelementオブジェクトを取得して配列に変換するとか

投稿2015/12/01 02:55

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問