提交按钮将值传递给数据库并显示值的出现(laravel)

时间:2017-09-18 11:09:40

标签: javascript php laravel submit-button find-occurrences

我是编程新手,特别是在laravel。我已经尝试了很多,现在我尝试制作laravel项目,但遇到了一些问题。

我想让提交按钮将数据传递到数据库,并找出单选按钮中值的出现。我设法将数据传递到数据库,但我仍然无法找到找到出现的解决方案。那么,如何在单击提交按钮时知道出现的情况?

这是刀片( question.blade.php

<table class="table" style="width: 40%">

<form action="storequestion" method="post">
<input type="hidden" name="_token" value="{{ csrf_token() }}">

<tr>
    <th>M</th>
    <th>Question 1</th>
    <th>L</th>
</tr>
<tr>
    <td><input type="radio" name="q1" value="S" data-col="1"></td>
    <td>1.Statement</td>
    <td><input type="radio" name="q2" value="S" data-col="1"></td>
</tr>
<tr>
    <td><input type="radio" name="q1" value="I" data-col="2"></td>
    <td>2.Statement</td>
    <td><input type="radio" name="q2" value="I" data-col="2"></td>
</tr>
<tr>
    <td><input type="radio" name="q1" value="B" data-col="3"></td>
    <td>3.Statement</td>
    <td><input type="radio" name="q2" value="D" data-col="3"></td>
</tr>
<tr>
    <td><input type="radio" name="q1" value="C" data-col="4"></td>
    <td>4.Statement</td>
    <td><input type="radio" name="q2" value="C" data-col="4"></td>
</tr>

        <tr>
            <th>M</th>
            <th>Question 2</th>
            <th>L</th>
        </tr>
        <tr>
            <td><input type="radio" name="q3" value="D" data-col="5"></td>
            <td>5.Statement</td>
            <td><input type="radio" name="q4" value="D" data-col="5"></td>
        </tr>
        <tr>
            <td><input type="radio" name="q3" value="C" data-col="6"></td>
            <td>6.Statement</td>
            <td><input type="radio" name="q4" value="C" data-col="6"></td>
        </tr>
        <tr>
            <td><input type="radio" name="q3" value="B" data-col="7"></td>
            <td>7.Statement</td>
            <td><input type="radio" name="q4" value="I" data-col="7"></td>
        </tr>
        <tr>
            <td><input type="radio" name="q3" value="B" data-col="8"></td>
            <td>8.Statement</td>
            <td><input type="radio" name="q4" value="S" data-col="8"></td>
        </tr>

<tr> <td> <br><br> <input type="submit" name="submit" value="submit"> </td></tr>

</form>
</table>

这是控制器( tanswercontroller.php

public function storequestion(Request $request)
{
    $tanswer = new tanswer;
    $tanswer->q1 = $request->q1;
    $tanswer->q2 = $request->q2;
    $tanswer->q3 = $request->q3;
    $tanswer->q4 = $request->q4;
    $tanswer->save();
    return 'data saved';
 }

这是路线( web.php

route::post('/storequestion', 'tanswercontroller@storequestion');

因此,当单击提交按钮时,它会显示已检查的单选按钮值的出现,这是一个字符串,因此它会给出类似这样的输出

//suppose we choose the radio button who has:
//in Question 1
//name="q1" value="S" data-col="1"
//name="q2" value="I" data-col="2"

//In Question 2
//name="q3" value="B" data-col="7"
//name="q4" value="S" data-col="8"

//The result will show
// S = 2 , I = 1 , B = 1

请帮我解决这个问题。如果您认为使用javascript更容易,请告诉我。感谢

2 个答案:

答案 0 :(得分:1)

据我了解你可以这样做。

首先你必须创建一个路线

route::get('/result', 'tanswercontroller@result'); 

然后在tanswercontroller.php

修改您的storequestion()方法并添加result()方法


<强> tanswercontroller.php

class tanswercontroller extends Controller
{

    /*
    * for storing data then redirected to result 
    * page with id you can make token for this 
    * if you prefer 
    */ 
    public function storequestion(Request $request)
    {
        // you must validate data like ---
        // $this->validate($request, ['q1' => 'required', ...]);

        $tanswer = new tanswer;
        $tanswer->q1 = $request->q1;
        $tanswer->q2 = $request->q2;
        $tanswer->q3 = $request->q3;
        $tanswer->q4 = $request->q4;
        $tanswer->save();

        // redirect to result page with id
        return redirect()->url('result/'.$tanswer->id); // added this line
    }


    public function result($id)
    {
        // pulling data of answer for calulation 
        $tanswer = tanswer::find($id);

        // do some calulation here the return data like 
        $result = //yourCalculation;

        /*
        * now calculation is stored in result variable then 
        * passing result in view so show result as you wish
        */
        return view('result', ['result' => $result]);
    }
}

答案 1 :(得分:0)

希望这是你需要的:

$value = $request->q1 - $request->q2;

这会将结果存储在变量$value