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

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

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

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

jQuery

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

HTML

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

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

3回答

789閲覧

jQueryを使ってphpの変数を操作したい!

CopanSassa

総合スコア18

PHP

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

jQuery

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

HTML

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

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2019/08/03 21:31

PHP

$quiz = array("りんご","ばなな","いちご","みかん");

HTML

<p> <?php $quiz[$i];?> </p>

jQuery

$(function(){ 'use strict'; $('#next').on('click', function(){ <?php $i++;?> }); }); </script>

上記のようにjQueryでボタンをクリックしたときにphpの変数を一つ増やし、配列に格納してある問題分を切り替えたいのですがうまくいきません。
何かいい方法はないでしょうか?

また、時間を計るゲームなのでAjaxのように毎回サーバーにアクセスするのは、インターネット環境に依存するので避けたいです。

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

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

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

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

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

guest

回答3

0

php はサーバサイドで動作し、JavaScript は(今回の場合)クライアントサイドで動作しています。

そのため

上記のようにjQueryでボタンをクリックしたときにphpの変数を一つ増やし、配列に格納してある問題分を切り替えたいのですがうまくいきません。

といった動作をサーバに接続しない状態で実現することはできません。

投稿2019/08/03 21:45

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

CopanSassa

2019/08/04 07:01

そうなんですね! もう少しphpついて詳しくならないといけませんね ありがとうございました
guest

0

ベストアンサー

PHP および jQuery は次のように動作します。

  1. ブラウザが URL にアクセスする
  2. サーバーは URL に従い PHP を起動する
  3. PHP がページを作成する
  4. サーバーは作成されたページをブラウザに送信する
  5. ブラウザはページを表示し、JavaScript を起動する
  6. JavaScript は jQuery を読み込み、起動する

つまり、PHP を動かそうと思えば、PHP の動く URL にアクセスしなければいけません。そうすることによってサーバーが PHP を動かし、ページを作成して返します。jQuery が PHP に何かデータを渡すためには、URL にクエリを追加するか、またはクエリをポストするしかありません。

たとえば最初の問題を表示する URL が https://exapmle.com/ だったとします。その場合、jQuery を使って https://example.com/?q=1 に遷移することにより、PHP に q=1 というクエリを渡すことができます。
PHP 側ではこのクエリを受け取り、問題文を生成します。

あなたが調べるべきは以下の事項です。

  • 「GET POST 違い」
  • 「jQuery ページ遷移」
  • 「PHP クエリ解析」
  • 「PHP データベース 取得」

これらを調べることにより、大まかにやりたいことを実装する方法が見えてくるでしょう。しかし、それらを組み合わせるには更なる知識が必要になるかもしれません。

jQuery に関して不明なことを調べるには jQuery を、JavaScript に関して不明なことを調べるには MDN Web Doc を使ってください。また PHP に関して不明なことを調べるには PHP マニュアル を使ってください。

また、検索中にみつかった情報が「侍エンジニア塾」または「TECHACADEMY」だった場合、それは無視してください。Qiita や teratail だった場合、「いいね」や「高評価」が多くついていることを確かめ、そのうえでコメントを読んで信憑性を確認してください。

投稿2019/08/03 22:12

編集2019/08/03 22:54
Zuishin

総合スコア28660

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

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

Zuishin

2019/08/04 00:20

あと、時間を計るのは PHP を使わなくても JavaScript ですればいいと思います。
CopanSassa

2019/08/04 07:00

なんて詳しすぎる解説なんですか!! ありがとうございます!! とても参考になります 「侍エンジニア塾」や「TECHACADEMY」は無視した方がいいのですね! よかったらなぜ無視すべきなのかも教えてもらえないでしょうか?
guest

0

時間を計るゲームなのでAjaxのように毎回サーバーにアクセスするのは、インターネット環境に依存するので避けたいです。

使うブラウザ、ネット環境を厳密に縛ることは開発者によってできるわけではないのでこの考え方は矛盾しています。
Webを通す時点でサーバー利用するわけですし。
「何かしらでPHPの情報を更新したい」時点で、更新したいタイミングでのサーバーへのリクエストは避けられません。

投稿2019/08/04 00:15

m.ts10806

総合スコア80850

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

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

CopanSassa

2019/08/04 07:01

おっしゃる通りです! mts10806さんには、いつも回答してもらって本当に助かっています またよろしくお願いします
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問