Javascript 使用jQuery非常慢的ajax调用
我在我的应用程序中使用knockout从表单注册/登录,但ajax调用的等待时间在第一轮非常缓慢(猜测它在第二轮时会缓存,因为第二轮非常快)-当我在线上传站点时,以及当我将其包装为iOS应用程序(HTML5应用程序)时,大约15秒登录完成登录需要60秒以上。为什么会发生这种情况?我错过什么了吗?它更可能是服务器端的吗?希望我能提供足够的信息,但不幸的是我是新手。我将在下面添加登录代码:Javascript 使用jQuery非常慢的ajax调用,javascript,jquery,ajax,knockout.js,Javascript,Jquery,Ajax,Knockout.js,我在我的应用程序中使用knockout从表单注册/登录,但ajax调用的等待时间在第一轮非常缓慢(猜测它在第二轮时会缓存,因为第二轮非常快)-当我在线上传站点时,以及当我将其包装为iOS应用程序(HTML5应用程序)时,大约15秒登录完成登录需要60秒以上。为什么会发生这种情况?我错过什么了吗?它更可能是服务器端的吗?希望我能提供足够的信息,但不幸的是我是新手。我将在下面添加登录代码: $(document).ready(function(){ function UserVie
$(document).ready(function(){
function UserViewModel() {
//Make the self as 'this' reference
var self = this;
var Domain = "http://example.com";
//Declare User observables which will be bind with UI
self.UserId = ko.observable();
self.Name = ko.observable();
self.Email = ko.observable();
self.Occupation = ko.observable();
self.Country = ko.observable();
self.RegistrationNumber = ko.observable();
//Create User object
var User = {
UserId: self.UserId,
Name: self.Name,
Email: self.Email,
Occupation: self.Occupation,
Country: self.Country,
RegistrationNumber: self.RegistrationNumber,
};
//Assign knockout observables to User/s objects
self.User = ko.observable(); //user
self.Users = ko.observableArray(); // list of users
//onload set status of user
UserStatus();
//Login handler
self.login = function () {
try {
if (User.Email() != "" && User.RegistrationNumber() != "") {
//try logging in
Login();
} else {
viewModel.UserId("Please login with the correct email and registration number.");
}
}
catch (err) {
viewModel.UserId("There was an error, please try again.");
}
};
//Login
function Login() {
$.ajax({
url: Domain + '/User/Login',
cache: false,
type: 'POST',
dataType: 'json',
contentType: 'application/json; charset=utf-8',
data: '{"Email":"' + User.Email() + '","RegistrationNumber":"' + User.RegistrationNumber() + '"}',
beforeSend: function () {
// setting a timeout
$('.splash').show();
},
success: function (data) {
$('.splash').hide();
if (data != 0) {
SetUserVars(data.UserId, data.Name, data.Email, data.Occupation, data.Country, data.RegistrationNumber);
viewModel.UserId(ActionToTake());
}
else {
viewModel.UserId("The supplied credentials are invalid, please try again.");
}
},
complete: function () {
//$('.splash').hide();
},
}).fail(
function (xhr, textStatus, err) {
console.log(xhr.statusText);
console.log(textStatus);
console.log(err);
viewModel.UserId("There was an error, please try again.");
});
}
function UserStatus() {
if (localStorage.getItem("UserId") === null) {
//not logged in
$("a.menu-status").text("Login").attr("href", "index.html#login-screen");
}
if (localStorage.getItem("UserId") != null) {
//logged in
$("a.menu-status").text("Logout").attr("href", "index.html#login-screen");
}
//allow user to logout and reset all user storage
$("a.menu-status").click(function () {
//show logged off status
$("a.menu-status").text("Login");
alert('You have logged off, please login if you wish to continue.');
self.reset();
//redirect
window.location.replace("index.html#login-screen");
location.reload();
viewModel.UserId("You have logged off.");
ResetUserLocalStorage();
});
}
我倾向于同意问题在于服务器端而不是客户端的评论 我最初采取的步骤是使用类似于postman的东西,并通过它点击API,验证它是否是缓慢的部分
如果这表明了问题所在,那么您是否可以使用服务器上运行的代码使自己处于调试状态?然后一步一步地检查代码,并尝试准确地指出发生了什么以及它的速度在哪里减慢。我怀疑这与您的客户端代码有任何关系。您可以使用调试器或类似Fiddler的侦听器来监视网络流量,并查看其挂起的位置at@QBM5在登录xhr请求时,流量被挂起-它说大小是580b,时间是9.88秒。你有权访问服务器吗。听起来好像服务器落后了,而不是服务器client@QBM5是的,我知道-你能建议一个行动方案来检查这一点吗?对不起,但我不知道我在这方面会有多大帮助。我不知道你在运行什么样的服务器。不知道您使用什么机制登录。如果您能够,我建议您一步一步地浏览服务器端代码,看看返回的函数是什么。然后调试该函数。除此之外,我没有足够的信息来帮助你