繁体   English   中英

如何在jquery中传递函数变量?

[英]How can I pass a function variable in jquery?

这是我正在使用的html表单。

<label>Your Username:</label><input id="username" name="username" type="text" onchange="return ajax ('username');" />

这是我在php中的ajax检查文件。

if ($_REQUEST['username']) {

$q = $dbc -> prepare("SELECT username FROM accounts WHERE username = ?");
$q -> execute(array($_REQUEST['username']));

if (strlen($_REQUEST['username']) < 3) {
    echo '<div class="error">Has to be at least 3 characters</div>';
}   

elseif ($q -> rowCount() > 0) {
    echo '<div class="error">Username already taken</div>';
}
else {
    echo '<div class="success">Username available</div>';
}
}

我的jquery ajax请求......

function ajax (input) {

var val = $('#'+input).val();
$('.loading').fadeIn().delay(100);
$.post("ajax.php", {
    username: val,
}, 
function (response) {
    $('.error, .success').hide();
    setTimeout(function(){
        $('.loading').hide();
            finishAjax(input, response);
    }, 1000);
});
return false;
}

function finishAjax(id, response) {

$('#'+id).after(response).fadeIn(2000);
}

在我的表单上,我使用变量username调用ajax请求。

在我的ajax.php中,如果请求名为username,则会正确验证用户名。

我想在jquery代码中显示变量输入来代替用户名 ,所以我可以使用这个脚本进行其他验证,并将变量作为电子邮件或密码传递,脚本仍将运行,因为输入的将是它所需要的成为。

如果这是有道理的。

谢谢你的时间。

var data = {};
data[input] = $('#' + input).val();

$.post("ajax.php", data, function() {...

finishAjax(input, response);

你声明val是“输入”的值,但从不使用它。 用户名的所有用法都应该可以访问该变量val ,因此请使用它。 除非我误解了你的问题,否则这样的话(只改了一行):

function ajax(input) {
    var val = $('#' + input).val();
    $('.loading').fadeIn().delay(100);
    $.post("ajax.php", {
        username: val,
    }, function (response) {
        $('.error, .success').hide();
        setTimeout(function () {
            $('.loading').hide();
            finishAjax('username', response);
        }, 1000);
    });
    return false;
}

检查输入arg wat ll u get then then .....删除附近的分号

 {username: $('#' + input).val(),}

as ,{ username: $('#' + input).val()},

你会得到o / p

在调用$ .post之前,请创建一个空对象。

var data = {};

使用函数的参数作为对象的索引。

data[input] = val;

在$ .post调用中使用该对象而不是匿名对象文字。

$.post("ajax.php", data, function ...);

但是,如果按照描述的方式执行操作,则需要确保管理所有正确传递的参数。 您确定您的PHP脚本能够处理可能传递给ajax函数的所有不同值吗?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM