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

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

ただいまの
回答率

88.92%

JavaScriptでphpのデータベースの値を検索

解決済

回答 2

投稿

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

ohayou

score 18

phpで登録した値をjavascriptにもってきて、javascript側であるカラムの値について条件分岐する。ということをやりたいです。

現在値をjavascript側に持ってくることはできています。

<!DOCTYPE html>
<html>

<script type="text/javascript">
var map = L.map('map');
L.tileLayer('https://cyberjapandata.gsi.go.jp/xyz/std/{z}/{x}/{y}.png', {
  attribution: "<a href='https://maps.gsi.go.jp/development/ichiran.html' target='_blank'>地理院タイル</a>"
}).addTo(map);

</script>

<?php
//mysql接続
$pdo = new PDO($dsn, $user, $password);
//配列に入れる
$sql = 'SELECT * FROM latlng';
$result = $pdo->query($sql);
foreach($result as $row){
  $latitudes[]=$row['ido'];
  $longitudes[]=$row['keido'];
  $comments[]=$row['comment'];
  $cates[]=$row['cate'];
}
$phpjson=json_encode($latitudes);
$phpjson2=json_encode($longitudes);
$phpjson3=json_encode($comments);
$phpjson4=json_encode($cates);

?>
<script type="text/javascript">

var test=JSON.parse('<?php echo $phpjson; ?>');
var test2=JSON.parse('<?php echo $phpjson2; ?>');
var test3=JSON.parse('<?php echo $phpjson3; ?>');
var test4=JSON.parse('<?php echo $phpjson4; ?>');

var ki = L.icon({
  iconUrl:'',
})

for(var i=0;i<test.length;i++){
  var latlng = [lat, lng];
  var com=test3[i];
  var data=[{"lat":test[i],"lng":test2[i], "com":test3[i], "cate":test4[i]}];

//データベースのcateというカラムの値が「ki」だった場合以下の処理がおこなわれる

if(cate=="ki"){
  var marker=new L.Marker(new L.latLng(latlng), {com:com});
  marker.bindPopup("<a href='#'><script>document.write(com); </script></a>");
  searchLayer.addLayer(marker);
}

</script>

</html>
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • m.ts10806

    2018/12/25 07:23

    前の質問に書いたajaxについては何かしら調べたり試されたりしたのでしょうか。
    1ファイルに混在するのはよくありませんし、phpの情報をほぼそのまま使っているのはセキュリティ上のリスクが高いです。
    変数名もマジックナンバーや意味を持たせないものを使っていて不具合やケアレスミスの温床となっています。(前の質問はまさにそこ)
    一度構成を見直された方が確実に進むと思います。

    キャンセル

  • ohayou

    2018/12/26 11:54

    返信遅れてすみません。
    昨日は朝しか時間がなかったため連続して質問させていただきました。
    一度構成を見直したいと思います。アドバイスありがとうございました!

    キャンセル

回答 2

checkベストアンサー

0

以下の記述で判定できると思います。

var data={"lat":test[i],"lng":test2[i], "com":test3[i], "cate":test4[i]};

//データベースのcateというカラムの値が「ki」だった場合以下の処理がおこなわれる

if(data["cate"]=="ki"){

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

-2

どの点でつまづいているのでしょうか?

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/12/25 06:47

    そうです!

    キャンセル

  • 2018/12/25 07:24

    この内容は回答ではないので回答欄ではなく「質問への追記・修正の依頼」の方に書くべきです。

    キャンセル

  • 2018/12/25 07:26

    すみません、以後気をつけます。

    キャンセル

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

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

関連した質問

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