1

これが私が取得しようとしているものですresponse14.php?questionID=1&question=yes&approved=1

ここに私が現在得ているものがありますresponse14.php?questionID=[object%20Object]&question=undefined&approved=1

jsファイルは次のとおりです。

$(document).ready(function(){
    $(".save_btn").on('click', function() {
         var check = $("input[name=no]").is(":checked")?2:1;
         var questionID = $("textarea[id=questionID]").val();
         var question = $("textarea[value=question]").val();
        location = "response14.php?questionID=" +questionID + "&question=" +question + "&approved=" +check;

フォームは次のとおりです。

echo "<script src='viewsonly.js' type='text/javascript'> </script><br><center>";    
    include("db_conn.php");

$qry_strings4 = "SELECT * FROM `Y new questions`";
$preps4 = $pdo_conn->prepare($qry_strings4);
            $preps4->execute();
           // $row = $preps4->fetch(PDO::FETCH_ASSOC);
        //echo "$count";
            echo "<table style='border:0px; background-color:lightgrey; width:75%'><thead style='border:0px;'><tr style='border:0px solid white; background-color:#153E7E; text-align:left; color:white; padding: 5; margin: 5;'><th style='border:1px white; padding: 5; margin: 5;'>Question</th><th style='border:1px white; padding: 5; margin: 5;'>Response</th></tr></thead><tbody>";
            while ($row = $preps4->fetch(PDO::FETCH_ASSOC)) {
                echo "<tr style='border:1px white; background-color:lightgrey; color:black; padding: 5; margin: 5;'><td style='border:1px white; vertical-align:top; padding: 5; margin: 5;'>{$row['starName']}</td>
                      <td style='border:1px white; padding: 5; margin: 5;'><div id='wrap'>
<textarea cols='85' rows='2' id='{$row['questionID']}' class='response textbox'>{$row['question']}</textarea>
YES: <input type='checkbox' name='yes[]' value='yes'>
NO: <input type='checkbox' name='no[]' value='no'>";
            }
            echo "</tbody></table>";
            echo "<button type='button' class='save_btn'>Save All</button><br>";

レンダリングされたhtml:

 <td style='border:1px white; padding: 5; margin: 5;'><div id='wrap'>
<textarea cols='85' rows='2' id='3792' class='response textbox'>Hello C!!

Where can I send you fan mail? :)
I want your autograph and I'm from the Philippines :)

God bless Cooper!</textarea>
    YES: <input type='checkbox' name='yes' value='yes'> &nbsp;&nbsp;&nbsp;
    NO: <input type='checkbox' name='no' value='no'>    </div></td></tr><tr style='border:1px white; background-color:lightgrey; color:black; padding: 5; margin: 5;'><td style='border:1px white; vertical-align:top; padding: 5; margin: 5;'>Gavin Casalegno</td>
                      <td style='border:1px white; padding: 5; margin: 5;'><div id='wrap'>
<textarea cols='85' rows='2' id='3793' class='response textbox'>What is your religion?
Do you believe in God?
How much you measure height?</textarea>
    YES: <input type='checkbox' name='yes' value='yes'> &nbsp;&nbsp;&nbsp;
    NO: <input type='checkbox' name='no' value='no'>    </div></td></tr></tbody></table><button type='button' class='save_btn' style='align:right'>Save All</button><br>

これを修正する方法についてのアイデアはありますか???

要求に応じて、レンダリングされた html を追加しました

4

2 に答える 2

2

id を持つ一意の要素があると仮定するとquestionID、この割り当てでは、属性を引用符で囲む必要があります。

var questionID = $("textarea[id='questionID']").val();

あなたは単に書くかもしれません

var questionID = $("#questionID").val();

ここでは、値属性によってテキストエリアをターゲットにしています。

var question = $("textarea[value=question]").val();

ただし、テキストエリアは value 属性を提供しません (詳細についてはMDNを参照してください)


最後に、POSTリクエストを実行する場合は ajax を使用する必要があります。(jQueryを使用しているため、$.postメソッドのドキュメントを参照してください)

于 2013-09-19T09:59:51.253 に答える
1

post メソッドを使用するには、次のようにします。

最初にフォーム要素でテーブルをラップしaction="response14.php"、送信ボタンを使用して、必要に応じて検証を行ってフォームを送信します。

または

ajaxを使用できます。

于 2013-09-19T10:05:55.553 に答える