Cha*_*ell 6 jquery jquery-validate
我曾经使用过工作表单验证,包括远程检查用户名.我们已经在script.js文件中添加了很多其他的javascript,并且在最近的某个时候,它的远程部分已经破坏了.validate,new_name字段只检查一个表单字段.它是必需的(工作)并且必须可用(不起作用).
这是jQuery:
$('#nickname_form').validate({
rules: {
new_name: {
required: true,
remote: {
url: '/api/screenname_unique/',
type: 'post'
}
}
},
messages: {
new_name: {
required: 'Please choose a Forum Username.',
remote: 'That Username is already taken or contains invalid characters.'
}
}
});
Run Code Online (Sandbox Code Playgroud)
正如我所说,以上用于工作,没有任何变化.我已经检查了script.js文件的其余部分并且没有出现任何错误.此外,在网站中,我们没有在任何地方看到JS错误.如果我删除上述代码的远程部分,则所需的检查工作,并且当字段中有值时,表单将提交.
如果远程到位,表单将不会提交,并且远程调用的ajax响应是真还是假,则不会显示jQuery validate错误消息.这是remote调用的页面.就它给定给定值的响应而言,它工作得很好:
<?php
header('Content-type: application/json');
//get the post value
$screen_name = $_POST['new_name'];
//get their member_id
$member_id = $this->EE->session->userdata['member_id'];
//return false if no screen_name provided
if((!$screen_name) || (!$member_id)) {
echo json_encode(false);
exit;
} else { //there is a screen_name
//Regex Check for valid chars
$valid = !preg_match('/[^a-z0-9_ -]/i',trim($screen_name));
if (!$valid) {
echo json_encode(false);
exit;
}
//SQL
$results = $this->EE->db->query("SELECT member_id FROM exp_members WHERE screen_name = '$screen_name' and member_id <> '$member_id' limit 1");
if ($results->num_rows() > 0) {
echo json_encode(false);
} else {
echo json_encode(true);
}
}
Run Code Online (Sandbox Code Playgroud)
?>
我不确定从哪里开始.想法?