【问题标题】:Jquery Validation check username with remoteJquery Validation用远程检查用户名
【发布时间】:2014-07-29 02:48:57
【问题描述】:

我正在使用验证插件和 Laravel 4.2。 我尝试通过 ajax 检查用户名,但无法正常工作。 用户名总是可以使用的,不管是否存在。

我的第二个问题是,如果我使用远程验证规则,我无法提交表单。

有人知道我做错了什么吗?因为在 chrome 日志中一切正常,请求已发送,我可以看到调试消息。

php

<?php 
use App\Models\User;
class ValidationController extends BaseController {

public function getCheckUsername() 
{
    if(Request::ajax()) {
        $user = User::where('username', Input::get('username'))->get();
        if($user->count()) {
            return Response::json(array('msg' => 'true'));
        }
        return Response::json(array('msg' => 'false'));

    }

}


}

JS

$(document).ready(function()
{
$("form").validate({

rules: {
        username: {
                required: true,
                     rangelength:[3,255],
        remote: {
                url:"http://"+location.host+"/validation/checkusername",
                type: "get",
                success: function(msg){
                 if(msg.msg == 'true') {
                  console.log('exists');
                  return true;
                 }
                 console.log('doesnt exists');
                  return false;
                }

                },


                },
  messages: {
            username: {
                required: "Please Enter Username!",
                remote: "Username already in use!"
            }
        }
});
});

我也尝试通过 $.validator.addMethod() 创建自己的规则,但这也不起作用。

【问题讨论】:

  • 这是一个跨域ajax请求吗?
  • 不,不是。与您看到的域相同。

标签: javascript jquery ajax validation laravel


【解决方案1】:

看起来您不是在发送数据。尝试这个。请注意发布请求。另外我相信 dataFilter 方法应该返回'true'

更新我刚刚也意识到如果用户存在,您的 php 中的逻辑将返回 true,因此 javascript 中的逻辑应该是这样的:

remote: {
    url: "http://"+location.host+"/validation/checkusername",
    type: "post",
    data: {
        username: function () {
            return $("input[name='username']").val();
        }
    },
    dataFilter: function (data) {
        var json = JSON.parse(data);
        if (json.msg == "true") {
            return "\"" + "That username is taken" + "\"";
        } else {
            return 'true';
        }
    }
}

【讨论】:

  • 数据正在通过get发送。您解决了一个问题,现在我可以发送有效的表格。但是远程功能仍然不起作用。
  • 在您的开发人员工具控制台网络选项卡中对 ajax 调用的响应说明了什么?
  • 我刚刚更新了,我意识到由于你的 msg 也是 true,所以两者都可能返回 true。
  • 200。所以没关系。我尝试了您更新的解决方案,但仍然是同样的问题。
猜你喜欢
  • 1970-01-01
  • 2016-10-21
  • 2010-11-17
  • 1970-01-01
  • 2013-05-10
相关资源
最近更新 更多