这是我在这里找到的一个脚本,我将它从 .live 更改为 .on
我有一个附加了类登录的锚,注销将使用 jquery 打开一个表单,并将当前锚的文本和类更改为注销。
<li><a href="javascript:void(0)" class="login">Login</a></li>
单击它时一切正常,一切都改变了,但是当我再次单击该锚点时,它不会激活注销功能。我知道它与 jquery 或 dom 需要刷新自己有关,但我不知道如何使它工作?
function onSignOutClicked() {
// Convert the clicked button into a sign-in button
$(this)
.attr('class', 'login')
.attr('title', 'Login')
.text('Sign in');
}
function onSignInClicked() {
// Convert the clicked button into a sign-out button
$(this)
.attr('class', 'logout')
.attr('title', 'Logout')
.text('Sign out');
}
$('.logout').on("click", onSignOutClicked);
$('.login').on("click", onSignInClicked);
我还在下面写了我自己的,这是一种替代方法,但这里的问题是旧类在更改后仍在工作。
$(".sendLoginForm").click(function(){
$("#loginErr").html("");
$(".sendLoginForm").css({"color":"#ff3019"});
$(".sendLoginForm").spin("small", "#FFF");
$.ajax({
type: "POST",
url: "../_/login.php",
data: $("#loginForm").serialize(),
dataType: "json",
success: function(data){
if (data.err){
$("#loginErr").html(data.err);
}else{
//$(".openLoginForm").closest('li').remove();
//$(".ulNavigator").append('<li><a href="javascript:void(0)" class="logout">Logout</a></li>');
//$('.openLoginForm').toggleClass('.logout')
//$(".openLoginForm").removeClass('.openLoginForm').addClass('logout');
$(".openLoginForm").toggleClass('openLoginForm logout');
$('.login').fadeOut("fast");
$(".success").html(data.success);
$('.success').fadeIn("fast");
$('#loginForm')[0].reset();
setTimeout(function() {
$('.success').fadeOut("fast");
}, 3000);
}
$(".sendLoginForm").spin(false);
$(".sendLoginForm").css({"color":"#FFF"});
}
});
return false;
});
$(document).on("click", ".logout", function(){
$.ajax({
type: "POST",
url: "../_/logout.php",
data: {logout : "kick"},
dataType: "json",
success: function(data){
if (data.success){
$(".success").html(data.success);
$(".success").fadeIn("fast");
setTimeout(function() {
$('.success').fadeOut("fast");
}, 3000);
}
}
});
});
任何有关以太方法的帮助将不胜感激,谢谢。