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

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

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

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

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

1回答

4637閲覧

session変数(配列)にページ遷移を行わずに値を代入したい

sika

総合スコア52

PHP

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

JavaScript

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

1クリップ

投稿2015/02/09 14:37

session変数を新規配列として持ち、
html要素のクリックした際に代入したデータを非同期通信を使って、そのデータをサーバ側に蓄積もしくは戻り値をsession変数に代入という処理を行いたいのですが、具体的にphp側で受け取ったデータをどのように処理を行えば良いのかわかりません。

lang

1<?php 2 session_start(); 3 $_SESSION['dataA'] = array(); 4 $_SESSION['dataB'] = array(); 5?> 6 7<script> 8 $('#dataBox li').click(function(){ 9 $.ajax({ 10 url: 'session.php', 11 type: 'POST', 12 data: { 13 dataA : $(this).children('img').attr('src'), 14 dataB : $(this).children('img').attr('alt') 15 }, 16 dataType: 'html' 17 }).then(function(data){ 18 //session.phpの戻り値の処理 19 }); 20 }); 21 22</script> 23 24<body> 25 <div id="dataBox"> 26 <ul> 27 <li><img src="aaa.jpg" alt="aaa" ></li> 28 <li><img src="bbb.jpg" alt="bbb" ></li> 29 <li><img src="ccc.jpg" alt="ccc" ></li> 30 <li><img src="ddd.jpg" alt="ddd" ></li> 31 </ul> 32 </div>

現在は上記の様なソースで構築し、
①#dataBoxのliタグをクリックしたらajax処理開始
②選択リスト内の画像パスとalt属性を送信データとして参照
③phpでデータを蓄積もしくはsession変数へ代入を行う処理
という流れで作成しております

こちらの③にあたる処理のアドバイスをいただける方、
ご教授宜しくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

普通にPOSTで受け取って、$_SESSION変数にセットするだけですよ。

lang

1<?php 2$image_src = $_POST['dataA']; 3$image_alt = $_POST['dataB']; 4 5session_start(); 6$_SESSION['image_src'] = $image_src; 7$_SESSION['image_alt'] = $image_alt; 8 9//通信元に何か戻したい場合は最後に表示 10echo 1;

バリデーションやエラー処理などは適宜行ってくださいね。
詳しくは公式のドキュメントを参照されると良いかと思います。
http://php.net/manual/ja/session.examples.basic.php
http://php.net/manual/ja/book.session.php

もし同一のPHPファイルでやりたい場合は、引数でコントロールしてみてください。

lang

1if( $_POST['mode'] === "save" ){ 2 $image_src = $_POST['dataA']; 3 $image_alt = $_POST['dataB']; 4 5 session_start(); 6 $_SESSION['image_src'] = $image_src; 7 $_SESSION['image_alt'] = $image_alt; 8}

lang

1//中略 2 data: { 3 dataA : $(this).children('img').attr('src'), 4 dataB : $(this).children('img').attr('alt'), 5 mode: 'save' //★追加 6 },

ここでは直接変数へ代入しましたが、元のソースコードにある配列に追加していきたい場合は、array_pushなどを用いてください。
http://php.net/manual/ja/function.array-push.php

lang

1if( ! is_array($_SESSION['image_src']) ) $_SESSION['image_src'] = array(); 2if( ! is_array($_SESSION['image_alt']) ) $_SESSION['image_alt'] = array(); 3 4array_push($_SESSION['image_src'], $image_src); 5array_push($_SESSION['image_alt'], $image_alt);

投稿2015/02/09 16:06

編集2015/02/09 16:20
munyaX

総合スコア783

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

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

sika

2015/02/11 02:29

ご教授ありがとうございます。 アドバイスいただいたソースをまだ完全に把握できていないので phpのeho$_SESSION変数にデータが送られたまでは確認できましたが 他のページへ遷移をおこなった際にsession値の維持に成功できていません。 いただいたソースで勉強します。 心よりお礼申し上げます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問