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

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

ただいまの
回答率

90.52%

  • PHP

    20331questions

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

  • JavaScript

    16401questions

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

  • WordPress

    7202questions

    WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

  • jQuery

    6701questions

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

  • POST

    230questions

    POSTはHTTPプロトコルのリクエストメソッドです。ファイルをアップロードしたときや入力フォームが送信されたときなど、クライアントがデータをサーバに送る際に利用されます。

wordpressでformの値(配列)から取得して$_sessionで表示したい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 565

Nonon

score -2

 前提・実現したいこと

wordpressを使用し、taxonomy.phpで表示されている商品一覧に
自作の簡易カートを設置したい。

・商品にそれぞれ個数を選択できるselectを設置
・カートに入れるbuttonに、
data-name = "商品名",
data-price = "値段",
data-number = "商品No",
data-id = "商品ID"
を設定しています。

また同じページに#cart-boxというdivを配置し、
その中にカートに入れた商品名、個数、総額をjqueryにて計算、表示。
formのimputでそのデータをpostして次ページで内容を表示する。

 発生している問題・エラーメッセージ

dataをconfirm.phpで$_SESSIONを使い表示したときに、
$_SESSION['data']['name']としたときに、配列の中から取り出せるかなと思ったのですがうまいこといきません。

var_dumpで表示してみると、

string(375) "{"item_621":{"name":"テスト","price":1000,"number":"item_621","quantity":"1","sub_total":1000},"item_622":{"name":"テスト","price":1000,"number":"item_622","quantity":"1","sub_total":1000}}"

と出てきます。値はちゃんと送られているのですが、
なんとなく、[]がなくて、配列じゃないような気がします...

次ページで
商品名 0000 0個 ¥0000
商品名 0000 0個 ¥0000
商品名 0000 0個 ¥0000
合計金額 ¥0000

というふうに、値をそれぞれ取って表示するためには
どのように$_SESSIONを使ったらよいのでしょうか?

 [taxonomy.php]

※ループ文などは省きました。
<?php 
/*
Template Name: 商品アーカイブ
*/
get_header() ?>
<h2 class="taxonomy_title"><p><?php echo single_cat_title() ?></p></h2>
<div class="taxonomy_box">
<!-- 商品ボックス -->

</div>

<p class="name"><?php echo the_title() ?></p>
<p class="subname"><?php echo $subname ?></p>
<p class="price"><?php echo $price ?><span>円(税込)</span></p>

<div class="cart_cont">
<select name="items" id="<?php echo $select ?>">
<?php for ($i=1; $i <= 50; $i++) { 
echo '<option>'.$i.'</option>';
} ?>
</select>
<button type="button" class="add_cart" title="カートに追加"
data-name   ="<?php echo the_title() ?>"
data-price ="<?php echo $price ?>"
data-number ="<?php echo $item_num ?>"
data-id     ="#<?php echo $select ?>"
>カートに入れる</button>
</div>

</div>
<!-- 商品ボックスここまで -->
</div>
<div class="cart_box">
<div id="item_list"></div>
<div id="go_cart">
<a href="#">次ページへ</a>
</div>
</div>
<form id="cart_form" name="cart_form" action="<?php echo home_url() ?>/cart_confirm" method="post">
<input type="hidden" id="data" name="data"></form>

<?php 
get_footer() ?>

 cartin.js(表示や計算などを設定しました)

$(document).ready(function(){
var items = new Object();

$(document).on('click',".add_cart", function(){

var data = $(this).data();
var quantity = $(data.id).val();
var sub_total = data.price * quantity;

items[data.number] = new Object();
items[data.number] = {

'name':data.name,
'price':data.price,
'number':data.number,
'quantity':quantity,
'sub_total':sub_total
};

cart_open();
});

var cart_open = function(){

$('#item_list').html('');;

var html = '<ul>';
var key;
var total = 0;

for ( key in items) {

html += '<li>'+items[key].name+'個数'+items[key].quantity+'&nbsp+&nbsp'+comma(items[key].sub_total)+'円</li>';

total += items[key].sub_total;

};

var data = JSON.stringify(items);

$("#item_list").html(html);
$("#cart_box").show();
$("#data").val(data);

}

$(document).on('click',"#go_cart a", function(){
document.cart_form.submit();
});

$(document).on('click',"#close_cart span",function(){
$("#cart_box").hide();
});

});

 confirm.php

<?php 
/*
Template Name: カートページ
*/

get_header();

session_start();

$post_data = stripslashes_deep($_POST['data']);
$_SESSION['data'] = $post_data;
?>

<p><?php var_dump(htmlspecialchars($_SESSION['data'])) ?></p>
<?php

get_footer();?>

 補足情報

wordpress ver4.9.5 です

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • 退会済みユーザー

    2018/05/05 22:07

    複数のユーザーから「やってほしいことだけを記載した丸投げの質問」という意見がありました
    「質問を編集する」ボタンから編集を行い、調査したこと・試したことを記入していただくと、回答が得られやすくなります。

回答 1

check解決した方法

-1

全く未熟者で、
オブジェクトと配列、jsとphpのデータの渡し方など勉強することがたくさんありました...
とりあえず、confirm.phpを下記の通りに修正し、データを取得することができました。
これから$_SESSIONなどを利用して前に進みたいと思います。

cofirm.php

<?php 
/*
Template Name: カートページ
*/

get_header();

$post_data = json_decode(stripslashes_deep($_POST['data']), true);

?>

<?php 
foreach($post_data as $key => $products):?>
<p><?php echo $products['name']; ?></p>
<p><?php echo $products['price']; ?></p>
<p><?php echo $products['quantity']; ?></p>
<p><?php echo $products['sub_total']; ?></p>

<?php endforeach; 

get_footer();?>

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

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

  • ただいまの回答率 90.52%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る

  • PHP

    20331questions

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

  • JavaScript

    16401questions

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

  • WordPress

    7202questions

    WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

  • jQuery

    6701questions

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

  • POST

    230questions

    POSTはHTTPプロトコルのリクエストメソッドです。ファイルをアップロードしたときや入力フォームが送信されたときなど、クライアントがデータをサーバに送る際に利用されます。