Как показать выбранные параметры и показать ошибки проверки при отправке формы
:) Я использую CodeIgniter. У меня радио 3 кнопки - при выборе одной из них показываются разные выпадающие списки. Во-первых, эти выпадающие списки скрыты, при выборе радиокнопки они показываются один за другим. Я хочу, чтобы когда пользователь нажимал кнопку "Отправить" и возникали ошибки проверки, эти ошибки отображались и выпадающие списки показывались с выбранными значениями. Я попытался с помощью следующего кода, теперь раскрывающиеся списки не скрыты и отображаются выбранные значения, но нет ошибок проверки, потому что я использовал e.preventDefault();
, Пожалуйста, скажите мне, как я мог это сделать? Заранее спасибо!:) Моё мнение таково:
$(document).ready(function(){
$(":radio").click(function(){
$('#region').val('Choose region');
$('#school').val('Chose region');
$('#teacher').val('Choose school');
$('#class').val('Choose class');
$('#class_divisions').val('Choose class division');
});
});
$(document).ready(function(){
$('#reg').click(function(e) {
if(document.getElementById("radio1").checked===true){
$(" .toggle, .school, .teacher_school, .teacher, .class, .teacher_class").show();
}
else if(document.getElementById("radio2").checked===true){
$(" .toggle, .school, .teacher_school, .class, .teacher_class").show();
}
else if(document.getElementById("radio5").checked===true){
$(".all_teachers_show").show();
}
e.preventDefault();
});
});
Весь мой взгляд таков:
$(document).ready(function(){
$(":radio").click(function(){
$('#region').val('Choose region');
$('#school').val('Choose region');
$('#teacher').val('Choose school');
$('#class').val('Choose class');
$('#class_divisions').val('Choose class division');
});
});
$(document).ready(function(){
$('#reg').click(function(e) {
if(document.getElementById("radio1").checked===true){
$(" .toggle, .school, .teacher_school, .teacher, .class, .teacher_class").show();
}
else if(document.getElementById("radio2").checked===true){
$(" .toggle, .school, .teacher_school, .class, .teacher_class").show();
}
else if(document.getElementById("radio5").checked===true){
$(".all_teachers_show").show();
}
e.preventDefault();
});
});
function showHide(self, show){
$(".all_teachers_show, .toggle, .school, .teacher_school, .teacher, .class, .teacher_class").hide();
if (show)
$('.toggle').show();
else
$('.toggle').hide();
$(":radio").prop('checked',false);
$(self).prop('checked',true);
}
function show(yes, no){
if (no)
$('.school').show();
else
$('.school').hide();
$("region").prop('checked',false);
$(yes).prop('checked',true);
}
function school_show(yes, no){
if(document.getElementById("radio1").checked===true){
document.getElementById('class_label').innerHTML = 'Class:*';
if (no)
$('.teacher').show();
else
$('.teacher').hide();
$("school").prop('checked',false);
$(yes).prop('checked',true);
}
if(document.getElementById("radio2").checked===true){
document.getElementById('class_label').innerHTML = 'Class teacher:*';
if (no)
$('.class').show();
else
$('.class').hide();
$("school").prop('checked',false);
$(yes).prop('checked',true);
}
}
function class_show(yes, no){
if (no)
$('.class').show();
else
$('.class').hide();
$("teacher").prop('checked',false);
$(yes).prop('checked',true);
}
function teachers_show(yes, no){
$(".toggle, .all_teachers_show, .school, .teacher_school, .teacher, .class, .teacher_class").hide();
if (no)
$('.all_teachers_show').show();
else
$('.all_teachers_show').hide();
$(":radio").prop('checked',false);
$(yes).prop('checked',true);
}
</script>
<script>
$(document).ready(function() {
$('#region').change(function() {
var url = "<?= base_url() ?>index.php/home/get_schools";
var postdata = {region: $('#region').val()};
$.post(url, postdata, function(result) {
var $school_sel = $('#school');
$school_sel.empty();
$school_sel.append("<option>Choose region</option>");
var schools_obj = JSON.parse(result);
$.each(schools_obj, function(key, val) {
var option = '<option value="' + val.school_id + '">' + val.school_name + '</option>';
$school_sel.append(option);
});
});
});
});
</script>
<script>
$(document).ready(function() {
$('#school').change(function() {
var url = "<?= base_url() ?>index.php/home/get_teachers";
var postdata = {school: $('#school').val()};
$.post(url, postdata, function(result) {
var $teacher_sel = $('#teacher');
$teacher_sel.empty();
$teacher_sel.append("<option>Choose school</option>");
var teachers_obj = JSON.parse(result);
$.each(teachers_obj, function(key, val) {
var option = '<option value="' + val.user_id + '">' + val.username + '</option>';
$teacher_sel.append(option);
});
});
});
});
<?php
echo validation_errors();
echo "<div class='container'>";
echo form_open('home/register');
echo "<h3>Регистрация:</h3><br/>";
echo "<table border = '0' >";
echo "<tr><td><label> Username:* </label></td><td>";
$data=array(
'name' => 'username',
'class' => form_error('username') ? 'error' : '',
'value' => set_value('username')
);
echo form_input($data);
echo "</td></tr>";
echo "<tr><td><label> Password:* </label></td><td>";
$data=array(
'name' => 'password',
'class' => form_error('password') ? 'error' : ''
);
echo form_password($data);
echo "<tr><td><label> Choose role:* </label> </td><td>";
$data=array(
'name' => 'role_id',
'value' => set_value('role_id', '1'),
'id' => 'radio1',
'onclick' => 'showHide(this, true)'
);
echo form_radio($data);
$data=array(
'name' => 'role_id',
'value' => set_value('role_id', '2'),
'id' => 'radio2',
'onclick' => 'showHide(this, true)'
);
echo form_radio($data);
$data=array(
'name' => 'role_id',
'value' => set_value('role_id', '5'),
'id' => 'radio5',
'onclick' => 'teachers_show(this, true)'
);
echo form_radio($data);
echo "<tr class='toggle' style='display:none;' ><td><label> Region:* </label></td><td>";
?>
<select name='region' id='region' onChange='show(this, true)'>
<option value="<?php echo set_select('region'); ?>" >Choose region</option>
<?php foreach ($regions as $row) { ?>
<option name='region' value= "<?= $row->region ?>"
<?php echo 'region' == $row->region ? 'selected="selected"' :
'' ?>><?= $row->region ?></option>
<?php } ?>
</select>
<?php
echo "</td></tr>";
echo "<tr class='school' style='display:none;' ><td><label> School:*
</label></td><td>";
?>
<select id="school" name="school[]" onChange='school_show(this, true)'>
<option value="<?php echo set_select('school[]'); ?>">Choose region</option>
</select>
<?php echo "</td></tr>";
echo "<tr class='teacher' style='display:none;' onChange='class_show(this, true)'><td><label> Teacher:*
</label> </td><td>";
echo '<select id="teacher" name="teacher[]">';
?>
<option value="<?php echo set_select('teacher'); ?>">Choose school</option>
</select>
</td></tr>
<?php
echo "<tr class='class' style='display:none;'><td> <label id='class_label'> Class:* </label> </td><td>";
?>
<select name='class[]' id='class'>
<option value="<?php echo set_select('class[]'); ?>">Choose class</option>
<?php foreach ($classes as $row) { ?>
<option value= "<?= $row->id ?>"><?= $row->class_id ?></option>
<?php } ?>
</select>
<select name='class_divisions[]' id='class_divisions'>
<option value="<?php echo set_select('class_divisions[]'); ?>">Choose division</option>
<?php foreach ($class_divisions as $row) { ?>
<option value= "<?= $row->id ?>"><?= $row->division ?></option>
<?php } ?>
</select>
</td></tr>
Мой контроллер это:
public function register()
{
if ($this->input->post('role_id') == 1 OR $this->input->post('role_id') == 2){
$this->form_validation->set_rules('first_name', 'First name', 'trim|required');
$this->form_validation->set_rules('last_name', 'Last name', 'trim|required');
$this->form_validation->set_rules('username', 'Username', 'trim|required|min_length[6]|max_length[12]|is_unique[users.username]');
$this->form_validation->set_rules('password', 'Password', 'trim|required|min_length[6]');
$this->form_validation->set_rules('password2', 'Confirm password', 'trim|required|matches[password]');
$this->form_validation->set_rules('email', 'Email', 'trim|required|valid_email|is_unique[users.email]');
$this->form_validation->set_rules('location', 'Location', 'trim|required');
$this->form_validation->set_rules('school[]', 'School', 'required');
$this->form_validation->set_rules('class[]', 'Class', 'required');
$this->form_validation->set_rules('role_id[]', 'Role', 'required');
$this->form_validation->set_rules('class_divisions[]', 'Class division', 'required');
$this->form_validation->set_rules('region', 'Region', 'required');
}
if ($this->input->post('role_id') == 1){
$this->form_validation->set_rules('teacher[]', 'Teacher', 'required');
}
else if ($this->input->post('role_id') == 5 ){
$this->form_validation->set_rules('all_teachers_show', 'All teachers', 'required');
}
if ($this->form_validation->run()==FALSE)
{
$this->signup();
}
else
{
if( $this->user_model->register())
{
$data['dynamic_view'] = 'success_reg';
$this->load->view('templates/main',$data);
}
else
{
$this->load->model('user_model');
$data['dynamic_view'] = 'register_form';
$data['regions'] = $this->user_model->regions_show();
$data['classes'] = $this->user_model->classes_show();
$data['school_show'] = $this->user_model->school_show();
$data['class_divisions'] = $this->user_model->class_divisions_show();
$data['all_teachers_show'] = $this->user_model->all_teachers_show();
$this->load->view('templates/main',$data);
}
}
}
public function signup()
{
$data['menu']=$this->menu_model->get_menu();
$data['dynamic_view'] = 'register_form';
$data['classes'] = $this->user_model->classes_show();
$data['class_divisions'] = $this->user_model->class_divisions_show();
$data['all_teachers_show'] = $this->user_model->all_teachers_show();
$data['school_show'] = $this->user_model->school_show();
$data['regions'] = $this->user_model->regions_show();
$this->load->view('templates/main',$data);
}