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

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

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

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

WordPress

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

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回答

667閲覧

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

Nonon

総合スコア10

POST

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

WordPress

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

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グッド

0クリップ

投稿2018/05/05 08:23

前提・実現したいこと

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 です

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

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

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

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

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

guest

回答1

0

自己解決

全く未熟者で、
オブジェクトと配列、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();?>

投稿2018/05/05 11:57

Nonon

総合スコア10

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問