首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >laravel ajax响应返回html元素

laravel ajax响应返回html元素
EN

Stack Overflow用户
提问于 2018-08-04 23:04:41
回答 3查看 4.7K关注 0票数 2

我以前使用过利用ajax,但没有考虑到这种问题。

这是我的表格

代码语言:javascript
复制
<form action="" method="post" enctype="multipart/form-data" class="m-form m-form--fit m-form--label-align-right" id="basicinfoform">
                                                {{ csrf_field() }}
                                                <input type="hidden" value="{{ $studentinfo->id }}" name="studentformid">
                                                <div class="form-group m-form__group row">
                                                            <center><label for="sphoto">
                                                                        <?php 
                                                                            $photo = "student.png";
                                                                            if($studentinfo->photo !== ""){
                                                                                $photo = $studentinfo->id.'.'.$studentinfo->photo;
                                                                            }
                                                                        ?>
                                                            <img style="width:180px;height:180px;cursor:pointer;border:2px solid lightblue" id="schoollogo" src="<?php echo asset('images/passports/'.$photo) ?>"  alt="">
                                                        </label>
                                                        <input onchange="getPhoto.call(this);showsavebuttonforviewstudentedit();" type="file" class="form-control m-input newb" style="display:none" value="" id="sphoto" name="sphoto" aria-describedby="emailHelp" >
                                                        <br>
                                                            <span class="m-form__help text-accent">
                                                                <b>Click the image to change it</b>
                                                            </span>
                                                        </center>
                                                        <input type="hidden" value="" id="studentid" name="studentid">

                                                </div>

                                                <div class="form-group m-form__group row">
                                                    <div class="col-md-4">
                                                    <label for="exampleInputPassword1">
                                                        Admission No:
                                                    </label>
                                                    <input type="text" disabled="disabled" class="form-control m-input m-input--square"  value="{{ $studentinfo->admissionid }}">
                                                    </div>
                                                    <div class="col-md-4">
                                                    <label for="exampleInputEmail1">
                                                        Full name
                                                    </label>
                                                    <input type="text" name="fullname" class="form-control m-input m-input--square newb" value="{{ $studentinfo->fullname }}" onchange="showsavebuttonforviewstudentedit()">

                                                    </div>

                                                    <div class="col-md-4">
                                                    <label for="exampleInputPassword1">
                                                        Gender
                                                    </label>
                                                    <!-- <input type="password" class="form-control m-input m-input--square" id="exampleInputPassword1" placeholder="Password"> -->
                                                        <select name="gender" id="gender" class="form-control m-input m-input--square newb" onchange="showsavebuttonforviewstudentedit()">
                                                            <option value="1" {{($studentinfo->gender == "1") ? "selected" : ""}}>Male</option>
                                                            <option value="2" {{($studentinfo->gender == "2") ? "selected" : ""}}>Female</option>
                                                        </select>
                                                    </div>                                                        
                                                </div>

                                                <div class="form-group m-form__group row">
                                                    <div class="col-md-4">
                                                    <label for="exampleInputEmail1">
                                                        Class
                                                    </label>
                                                    <!-- <input type="text" class="form-control m-input m-input--square" id="exampleInputEmail1" aria-describedby="emailHelp" placeholder="Enter email"> -->
                                                    <select name="class" id="theclass" class="form-control m-input m-input--square newb" onchange="showsavebuttonforviewstudentedit();getArms();">
                                                        @foreach($allclasses as $list)
                                                            <option value="{{$list->id}}" {{ ($studentinfo->class == $list->id) ? "selected" : ""}}>{{ $list->classname }}</option>
                                                        @endforeach
                                                    </select>
                                                    </div>

                                                    <div class="col-md-4">
                                                    <label for="exampleInputPassword1">
                                                        Arm
                                                    </label>
                                                    <select name="arm" id="thearm" class="form-control m-input m-input--square newb" onchange="showsavebuttonforviewstudentedit()">
                                                        @foreach($allarms as $list)
                                                            <option value="{{$list->id}}" {{ ($studentinfo->arm_id == $list->id) ? "selected" : ""}}>{{ $list->arm }}</option>
                                                        @endforeach
                                                    </select>
                                                    </div>

                                                    <div class="col-md-4">
                                                    <label for="exampleInputPassword1">
                                                        House:
                                                    </label>
                                                    <select name="house" id="house" class="form-control m-input m-input--square newb" onchange="showsavebuttonforviewstudentedit()">
                                                        @foreach($allhouses as $list)
                                                            <option value="{{$list->id}}" {{ ($studentinfo->house == $list->id) ? "selected" : ""}}>{{ $list->house }}</option>
                                                        @endforeach
                                                    </select>
                                                    </div>
                                                </div>

                                                <div class="form-group m-form__group row">
                                                    <div class="col-md-4">
                                                    <label for="exampleInputEmail1">
                                                        Date of Birth
                                                    </label>
                                                    <input type="text" class="form-control m-input m-input--square newb" name=""dob id="dob10" value="{{ $studentinfo->dob}}" onchange="showsavebuttonforviewstudentedit()">
                                                    </div>

                                                    <div class="col-md-4">
                                                    <label for="exampleInputPassword1">
                                                        State
                                                    </label>
                                                    <select name="state" id="stateid" class="form-control m-input m-input--square newb" onchange="getLGA();showsavebuttonforviewstudentedit()">
                                                        @foreach($allstates as $list)
                                                            <option value="{{$list->StateID}}" {{ ($studentinfo->s_of_o == $list->StateID) ? "selected" : ""}}>{{ $list->State }}</option>
                                                        @endforeach
                                                    </select>
                                                    </div>

                                                    <div class="col-md-4">
                                                    <label for="exampleInputPassword1">
                                                        Local Govt.
                                                    </label>
                                                    <select name="lga" id="lgafield" class="form-control m-input m-input--square newb" onchange="showsavebuttonforviewstudentedit()">
                                                        @foreach($alllga as $list)
                                                            <option value="{{$list->lgaId}}" {{ ($studentinfo->lga == $list->lgaId) ? "selected" : ""}}>{{ $list->lga }}</option>
                                                        @endforeach
                                                    </select>
                                                    </div>
                                                </div>


                                                <div class="form-group m-form__group row">
                                                    <div class="col-md-4">
                                                    <!-- <input type="text" class="form-control m-input m-input--square" id="exampleInputEmail1" aria-describedby="emailHelp" placeholder="Enter email"> -->
                                                    <button type="submit" id="basicbtn" onclick="return submitStudentDetailInViewStudentPage();" disabled="disabled" class="btn btn-brand">&nbsp&nbsp Save <i class="fa fa-spinner fa-spin" style="display:none"></i>&nbsp&nbsp</button>
                                                    </div>

                                                </div>
                                            </div>

                                            </form>

单击保存按钮,ajax是firedup,这是ajax

代码语言:javascript
复制
form = document.getElementById('basicinfoform');

formdata = new FormData(form);

console.log(formdata)
$.ajax({
    url : "/ajax/post/studentinfo",
    data: formdata,
    method: 'post',
    processData: false,
    contentType: false,
    success : function (res){
        if(res){
            console.log(res)

        }
    }
   });
return false;

这是我的控制器

代码语言:javascript
复制
public function viewStudent(Request $request, $studentid = null)
{


    if(!Auth::check()){
        return redirect('/');
    }

    if($request){
          echo 'yes';
    }
    if(!is_null($studentid)){

        $data['allstates']  = DB::table('tblstates')->get();
        $data['alllga'] = DB::table('tbl_lga')->get();
        $data['studentinfo'] = DB::table('tblstudents')
                                ->where('id', $studentid)
                                ->first();

        return view('Students.viewstudents', $data);
    }
    return redirect('/all/students');
}

在这个控制器中,我设置了一个条件来检查是否已经发出了进行编辑的请求,所以为了测试和这个问题,我只是简单地回显了“是”。这意味着我的ajax响应只是假定为'Yes‘字符串文字,但下面是我在as响应中得到的内容

代码语言:javascript
复制
 <!DOCTYPE html>

代码语言:javascript
复制
<!-- Required meta tags -->

--begin::Base Styles -->  

    <!--begin::Page Vendors -->

    <link href="http://127.0.0.1:8000/assets/vendors/custom/fullcalendar/fullcalendar.bundle.css" rel="stylesheet" type="text/css" />

    <!--end::Page Vendors -->

    <link href="http://127.0.0.1:8000/assets/vendors/base/vendors.bundle.css" rel="stylesheet" type="text/css" />

    <link href="http://127.0.0.1:8000/assets/demo/default/base/style.bundle.css" rel="stylesheet" type="text/css" />

<!-- <link rel="stylesheet" type="text/css" href="//netdna.bootstrapcdn.com/bootstrap/3.1.1/css/bootstrap.min.css"> -->

    <!--end::Base Styles -->

    <link rel="shortcut icon" href="http://127.0.0.1:8000/assets/demo/default/media/img/logo/favicon.ico" />

<link rel="stylesheet" type="text/css" href="http://127.0.0.1:8000/DataTables/datatables.min.css"/>

    <link rel="stylesheet" type="text/css" href="http://127.0.0.1:8000/css/bootstrap.css"/>
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2018-08-04 23:19:59

我认为它应该看起来像这样

代码语言:javascript
复制
public function viewStudent(Request $request, $studentid = null)
{
    if(!Auth::check())
    {
        return redirect('/');
    }

    if($request)
    {
          // echo outputs to the server, but you should really return something
          // for the requester, thus we will return "YES" to the response
          // and since we are returning, it will return and no further executions will made.
          return 'yes';
    }

    if(!is_null($studentid))
    {

        $data['allstates']  = DB::table('tblstates')->get();
        $data['alllga'] = DB::table('tbl_lga')->get();
        $data['studentinfo'] = DB::table('tblstudents')
                                ->where('id', $studentid)
                                ->first();

        return view('Students.viewstudents', $data);
    }

    return redirect('/all/students');
}
票数 2
EN

Stack Overflow用户

发布于 2018-08-05 01:40:35

您可以使用return json将数据返回给ajax请求,如下所示

代码语言:javascript
复制
return response()->json(['success' => 'yes']);

不要对ajax响应的返回值使用echo

票数 2
EN

Stack Overflow用户

发布于 2020-03-03 17:57:04

在ajax调用中根据您的需求执行一些功能。我正在使用搜索输入过滤表数据。

代码语言:javascript
复制
                $.ajax({
                headers: {'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')},
                type    :"POST",
                url     :"{{route('filter')}}",
                dataType:"JSON",
                data    :{keyword:keyword,'_token':'{!!csrf_token()!!}'},
                success :function(response)
                {
                    if (response.status=='success') 
                    {
                        $('#table_body').html(response.data); 
                    } 
                }
            });

现在在我的控制器上,在使用查询获取表数据后,我在另一个刀片视图上发送数据,我希望返回响应,我的代码如下所示:

代码语言:javascript
复制
public function filter(Request $r)
{ 
    $keyword=$r->keyword;
    $orders=DB::table('orders')->where('print_orders.address','like','%' .$keyword. '%')->paginate(50);

    $html=view('orders',compact('orders'))->render();

    if ($this->check_count($orders)>0) 
    {
        return response::json(['status'=>'success','data'=>$html]);
    } 
    else 
    {
        return response::json(['status'=>'fail','Nothing Found!!']);
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51686838

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档