我正在为我的学校制作一个学校系统,我遇到了这个问题,我被困了好几天。在我的应用程序中,我有类型为 admin
、teacher
和 student
的用户。管理员创建所有用户和所有其他信息。现在,我正在制作教师面板,教师可以在其中为学生添加分数,稍后它们将显示在学生面板中。
因此,首先,当老师进入他们的帐户时,他将能够选择他教授的课程和他教授的科目,在这种情况下,我有表格 - class_subjects
我在其中保存teacher_id
,subject_id
和class_id
从管理面板。我在这里,在我的老师小组中称之为,它似乎工作得很好,因为我看到了我需要的确切课程和科目。之后,我需要对从老师那里挑选的这些进行后期查询,作为回报,从选择的班级 + 选择的主题中获得所有学生,这也完全符合我想要的方式。所以我返回的是一个新的刀片,其中包含来自表class_subject
信息的数组,教师需要从这个返回的数组中选择信息,并且在文本字段中,他必须为他选择的学生添加他的标记。之后,我需要将选取的信息保存在名为 student_marks
的新表中,其中包含字段 student_id
、subject_id
、mark_type_id
、mark
。
我的问题是如何将这些信息(老师选择的)保存在新表(student_marks
)中?
我正在发布控制器:
class AccountController extends Controller
{
public function getIndex() {
$user = Auth::user();
$classStudent = ClassSubject::where('teacher_id','=',$user->id)->get()->lists('class_id');
$userSubject = ClassSubject::where('teacher_id','=',$user->id)->get()->lists('subject_id');
return view('educator.account.account',[
'user' => $user,
'userTeacher'=> $classStudent,
'userSubject'=> $userSubject,
]);
}
public function postIndex(Request $request) {
ClassSubject::where(
'subject_id','=',$request->get('userSubject'),
'class_id','=',$request->get('userClass')
);
$user = Auth::user();
$markType = MarkType::lists('type');
$sub = Subject::where('id','=',$request->get('userSubject'))->get()->lists('name');
$stu = User::where('class_id','=',$request->get('userClass'))
->orderBy('first_name', 'asc')->get()->lists('full_name');
return view('educator.account.input', [
'user' => $user,
'studentss'=> $stu,
'markType' => $markType ,
'sub'=> $sub,
}
我知道这有点扭曲,但我真的被困在这里,如果有人最终能帮助我解决这个问题,我将不胜感激。如果有什么不清楚的地方,请询问。
教育者.帐户.帐户(第一个刀片)
@extends('teacher-app')
@section('teacher-content')
<div class="col-md-6">
{!! Form::open(['method' => 'post', 'class' => 'form-horizontal']) !!}
<div class="form-group">
{!! Form::label('profile_id','Избери клас:', ['class' => 'control-label col-md-4']) !!}
<div class="col-md-3">
{!! Form::select('userClass', $userTeacher, null, ['class'=>'form-control']) !!}
</div>
</div>
<br>
<div class="form-group">
{!! Form::label('profile_id','Избери предмет:', ['class' => 'control-label col-md-4']) !!}
<div class="col-md-3">
{!! Form::select('userSubject', $userSubject, null, ['class'=>'form-control']) !!}
</div>
</div>
<div align="center">
{!! Form::submit('Избери', ['class' => 'btn btn-default']) !!}
</div>
{!! Form::close() !!}
@stop
</div>
教育者.帐户.输入(第二个刀片)
@extends('teacher-app')
@section('teacher-content')
<div class="col-md-8">
{!! Form::open(['method' => 'post', 'class' => 'form-horizontal']) !!}
<div class="form-group">
{!! Form::label('profile_id','Ученик:', ['class' => 'control-label col-md-4']) !!}
<div class="col-md-3">
{!! Form::select('userStu', $studentss, null, ['class'=>'form-control']) !!}
</div>
</div>
<div class="form-group">
{!! Form::label('profile_id','Оценка:', ['class' => 'control-label col-md-4']) !!}
<div class="col-md-2">
{!! Form::text('mark',null, ['class'=>'form-control']) !!}
</div>
</div>
<div class="form-group">
{!! Form::label('profile_id','Тип оценка:', ['class' => 'control-label col-md-4']) !!}
<div class="col-md-3">
{!! Form::select('markType', $markType, null, ['class'=>'form-control']) !!}
</div>
</div>
<div class="form-group">
{!! Form::label('profile_id','Предмет:', ['class' => 'control-label col-md-4']) !!}
<div class="col-md-3">
{!! Form::select('stuSub', $sub, null, ['class'=>'form-control']) !!}
</div>
</div>
<br>
<div align="center">
<a href="{{url('educator/account')}}"><button type="button" class="btn btn-default">Назад</button></a>
{!! Form::submit('Запиши', ['class' => 'btn btn-default']) !!}
</div>
{!! Form::close() !!}
</div>
@stop
当他们提交学生评分表单时,您将有一条类似于以下内容的路线发布到:
class AccountController extends Controller {
public function markStudent(Request $request)
{
// get request data
$mark = $request->input('mark');
$subject_id = $request->input('stuSub');
$mark_type = $request->input('markType');
$student_id = $request->input('userStu');
// get the existing record or create a new, empty record
$student_mark = StudentMark::firstOrNew(compact('student_id', 'subject_id'));
// add the updated data to the model
$student_mark->fill(compact('mark_type', 'mark'));
// persist to database
$student_mark->save();
// redirect or do whatever you want after request completion...
}
}
上面的代码假设你只需要每个学生,每个科目一个条目(即这两个列上都有一个唯一的索引)。
我还建议您在插入数据之前对其进行验证,方法是在StudentMark::firstOrNew()
之前执行此操作,或者通过创建具有验证的自定义请求对象。