2017-07-27 17 views
0

githubでこのGPA calcのコードが見つかりましたが、それを動作させることができませんでした。見た目は正しく表示されますが、GPAは計算されず、行の追加/削除ボタンは機能しません。ここにgithubのファイルへのリンクがあります。 https://github.com/xandroxygen/GPACalcjavascriptがphpファイルで動作しない理由を理解できません

<?php 

    $GRADELIST = array(
     "A+"=>"4.0", 
     "A"=>"4.0", 
     "A-"=>"3.7", 
     "B+"=>"3.4", 
     "B"=>"3.0", 
     "B-"=>"2.7", 
     "C+"=>"2.4", 
     "C"=>"2.0", 
     "C-+"=>"1.7", 
     "D+"=>"1.4", 
     "D"=>"1.0", 
     "D-"=>"0.7", 
     "E"=>"0.0", 
    ); 

    // check input 
    function validate_input($data) 
    { 
     $data = trim($data); 
     $data = stripslashes($data); 
     $data = htmlspecialchars($data); 
     return $data; 
    } 

    // convert grades to points per hour 
    // returns -1 if grade not recognized 
    function grade_convert($g) 
    { 
     global $GRADELIST; 
     $p = -1.0; 
     if (array_key_exists($g,$GRADELIST)) 
     { 
      $p = $GRADELIST[$g]; 
     } 
     return $p; 
    } 

    // import JSON string 
    $json_data=array(); 
    $raw_data = file_get_contents('php://input'); 
    parse_str($raw_data,$json_data); 

    // parse form input 
    $name = ""; 
    $points = $hours = $gpa = 0.0; 

    $name = validate_input($json_data["name"]); 
    $points = validate_input($json_data["points"]); 
    $hours = validate_input($json_data["hours"]); 
    $classes = $json_data[0]["classes"]; 

    // add classes in 
    foreach($classes as $c) 
    { 
     $c_pts_per_hour = grade_convert($c[grade]); 
     if ($c_pts_per_hour > -1) // else, invalid grade (lowercase, P, IE, W, etc) 
     { 
      // find grade points, multiply by class hours, add to total hours 
      $c_pts = $c_pts_per_hour * $c[hours]; 
      $points += $c_pts; 
      $hours += $c[hours]; 
     } 
    } 

    // calculate and output GPA 
     if (is_numeric($hours) && ($hours > 0)) 
     { 
      $gpa = $points/$hours; 
     } 
    echo $name . ", your GPA is " . number_format($gpa,2) . ", and you have earned " . $hours . " total hours."; 
?> 

スプリット

<!DOCTYPE html> 
<html> 
<body> 
<style> 
    .error {color: #FF0000;} 
    .input-group-btn {padding-bottom: 10px;} 
    h5 {width: 50%;} 
</style> 
<head> 
    <title>GPA Calculator</title> 
    <meta charset="utf-8"> 
    <meta name="viewport" content="width=device-width, initial-scale=1"> 
    <!-- Latest compiled and minified CSS --> 
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css"> 

    <!-- jQuery library --> 
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script> 

    <!-- Latest compiled JavaScript --> 
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script> 

    <!-- Functions for processing and calculating gpa --> 
    <script type="text/javascript" src="../Sandbox_4_App/script.js"></script> 
</head> 

<div class="container"> 
    <div class="jumbotron"> 
     <h1>GPA Calculator</h1> 
     <p>Use your current points and hours, class enrollment, and projected grades to calculate your GPA!</p> 
     <h5>I built this the first week of my current job to teach myself basic principles of web design, like client-side scripting, PHP form handling, and AJAX calls.</h5> 
    </div> 
</div> 

<!-- Current GPA container --> 
<div class="container"> 
    <div class="panel panel-default"> 
     <div class="panel-heading">Calculate GPA</div> 
     <div class="panel-body"> 

      <!-- Form for Name/Points/Hours --> 
      <form role="form" action=""> 
       <div class="row"> 
        <div class="col-xs-4"> 
         <div class="form-group"> 
          <label for="name">Name: <span id="nameREQ"><small>(required)</small></span><span id="nameERR" class="error">This field is required!</span></label> 
          <input type="text" class="form-control" id="name" name="name"> 
         </div> 
        </div> 
        <div class="col-xs-4"> 
         <div class="form-group"> 
          <label for="curr_points">Current Points: 
           <a data-toggle="tooltip" title="Points and hours are found on your transcript"><span class="glyphicon glyphicon-info-sign"></span></a> 
          </label> 
          <input type="text" class="form-control" id="curr_points" name="curr_points"> 
         </div> 
        </div> 
        <div class="col-xs-4"> 
         <div class="form-group"> 
          <label for="curr_hours">Current Hours: 
           <a data-toggle="tooltip" title="Points and hours are found on your transcript"><span class="glyphicon glyphicon-info-sign"></span></a> 
          </label> 
          <input type="text" class="form-control" id="curr_hours" name="curr_hours"><br> 
         </div> 
        </div> 
       </div> 
      <!-- Table for Class/Grade/Hours --> 
       <table class="table table-bordered table-hover" id="tab_logic"> 
       <thead> 
        <tr > 
         <th class="text-center"> 
          # 
         </th> 
         <th class="text-center"> 
          Class 
         </th> 
         <th class="text-center"> 
          Grade 
         </th> 
         <th class="text-center"> 
          Hours 
         </th> 
        </tr> 
       </thead> 
       <tbody id="classes_list"> 
        <tr id='addr0'> 
         <td> 
         1 
         </td> 
         <td> 
         <input type="text" name='class0' placeholder='Class' class="class form-control"/> 
         </td> 
         <td> 
         <input type="text" name='grade0' placeholder='Grade' class="grade form-control"/> 
         </td> 
         <td> 
         <input type="text" name='hours0' placeholder='Hours' class="hours form-control"/> 
         </td> 

        </tr> 
       </tbody> 
       </table> 

      <!-- Add/Delete/Submit Buttons --> 
       <div class="input-group-btn"> 
        <a id="add_row" class="btn btn-default pull-left">Add Row</a><a id='delete_row' class="pull-right btn btn-default">Delete Row</a> 
       </div> 
       <input type="submit" class="btn btn-primary" id="submit" name="submit_form"> 
      </form> 
     </div> 
    </div>  
    <div id="showGPA" class="alert alert-success"> 
     <a class="close" aria-label="close">&times;</a> 
     <p><span id="result"></span></p> 
    </div> 
</div> 


</body> 
</html> 

スプリット

// --- main jQuery function --- 
$(function() { 
    $(".alert.alert-success").hide(); 
    $(".error").hide(); 

    // --- submit a form --- 

    $(".btn.btn-primary").click(function(e) { 
     e.preventDefault(); 
     $(".error").hide(); 
     $("#nameREQ").show(); 

     // validate name, gather input 
     var name = $("input#name").val(); 
     if (name == "") 
     { 
      $("#nameREQ").hide(); 
      $(".error").show(); 
      return false; 
     } 
     var points = $("input#curr_points").val(); 
     var hours = $("input#curr_hours").val(); 

     // process form 
     var formData = "name=" + name + "&points=" + points + "&hours=" + hours; 
     $.post("getGPA.php", formData, function(data) { 
       $("#showGPA").show(); 
       $("#result").text(data); 
      }); 
    }); 

    // --- close the alert box and ready for new submit --- 

    $(".close").click(function() { 
     $(".alert.alert-success").hide(); 
    }); 

    // --- enable tooltips 
    $(document).ready(function(){ 
     $('[data-toggle="tooltip"]').tooltip(); 
    }); 
}); 

ここではいくつかの変更を行った後、私の更新されたコードです。 gpaの計算部分はまだ動作していません。コードのセクションが見当たらないので、行の追加と削除は機能しません。私はその行を追加/削除行コードを取得する方法をよく分かりません。

+1

エラーを試してuはウルポストデータを解析する必要がありますと思いますか? –

+0

@RAUSHANKUMARそれは私にエラーを与えません、ブートストラップが正しく動作していますが、すべての機能は動作しません。行の追加/削除は機能しません.GPAを計算しようとすると0.0と表示されます。私はjavascriptファイルを正しく呼び出すと思ったが、機能は動作していないようだ。私はindex.phpファイルからphpファイルを呼び出す方法もわかりません。 –

+0

@BradleyNewman私は2つのエラーが表示されます - 最初の$ raw_data = file_get_contents( 'php:// input'); $ json_data = json_decode($ raw_data、true); - > $ raw_dataはjsonではありません。 Sec - validate_input($ json_data [0] ["person_name"]); - >あなたはperson_nameではない名前を送信しました – Matx132

答えて

1

あなたのjavascriptでは、行の追加/削除ボタンにアクションをバインドするものは表示されません。それはおそらく彼らが何もしない理由です。

フォームデータをPHPスクリプトに送信するためのコードは問題ありませんが、現時点では値をエスケープしていないため、リクエスト本体を自分で作成するのではなく、オブジェクトを送信する方が良いでしょう。名前が&または/または他の文字の数のいずれかが含まれている場合、リクエストボディが無効になりますので:物事のPHP側で

var formData = { 
    "name": name, 
    "points": points, 
    "hours": hours 
}; 

// just send an object, let jQuery deal with escaping it 
$.post("getGPA.php", formData, function(data) { 
    $("#showGPA").show(); 
    $("#result").text(data); 
}); 

、あなたは生の入力にアクセスしています。それはまったく必要ありません。あなたは通常のPOSTリクエストを実行して適切な値を送信しているので、値を単に$_POSTから得ることができます。 JSONをサーバーに送信しているわけではないので、json_decode()を呼び出すことは意味がありません。

// import JSON string 
// $raw_data = file_get_contents('php://input'); 
// $json_data = json_decode($raw_data, true); 
// remove those lines, they don't do anything useful. 

// parse form input 
$name = ""; 
$points = $hours = $gpa = 0.0; 

$name = validate_input($_POST["name"]); 
// note: you're sending "name" to the server, not "person_name" 

$points = validate_input($_POST["points"]); 
$hours = validate_input($_POST["hours"]); 
$classes = $_POST["classes"]; 

"classes"がどこから来ているサーバーにすべてのクラスを送信していないので、私は、知りません。

+0

あなたが提案した変更を加えましたが、それでも動作していません。私は元のファイルにPHPコードを呼び出さなかったためかもしれないと思いますか?私はちょうどphpのどこかにindex.phpファイルの本文に貼り付けるべきですか? –

+0

いいえ、必要ではありません。あなたのブラウザのコンソールはあなたに何を伝えていますか? JavaScriptのエラーが出ますか? – rickdenhaan

+0

私はdreamweaverを使用してこれをウェブサイトに更新しようとしています。 Dreamweaverが私に伝えている唯一のエラーは、script.jsファイルにあり、3行目にmissingステートメントがあり、15行目に==が表示されていたと言われています。 –

0

私は、あなたが取得している。この

// import JSON string 
    $json_data=array(); 
    $raw_data = file_get_contents('php://input'); 
    parse_str($raw_data,$json_data); 

    // parse form input 
    $name = ""; 
    $points = $hours = $gpa = 0.0; 

    $name = validate_input($json_data["name"]); 
    $points = validate_input($json_data["points"]); 
    $hours = validate_input($json_data["hours"]); 
    $classes = $json_data[0]["classes"]; 
+0

これは実際には他のソリューションよりもはるかに機能しましたが、機能するためには名前フィールドしかありませんでした。提案された変更を行った後、他のフィールドはまだ計算されていません。これはjavascriptエラーですか? –

+0

@BradleyNewmanは、URのインデックス、スクリプト、PHPファイルを一緒に接続する必要がありますが、私はURのGithubリポジトリファイルでそれを見ていないよ、彼らはお互いに接続されていません。また、$ classes = $ json_data [0] ["classes"]のスタンドを得ることができませんでした。もし私がもっと簡単にuを助けることができるならば、また可能ならばur githubファイルを新しいものに更新してください。 –

+0

私は現在のファイルを反映する元の投稿。 –

関連する問題