通过jquery更改超链接单击事件中的文本

本文关键字:事件 文本 单击 超链接 jquery 通过 | 更新日期: 2023-09-27 18:23:56

我有一个动态生成的超链接列表,我正在使用jquery绑定点击事件,一切都很好,只有一件事我不能做,那就是更改它的文本

 **this.value = s;**

这就是我试图做的,但没有成功。

我的完整代码:

$(document).ready(function () {
    $('[id*="lnkStatus_"]').bind('click', SaveRequirmentStatus);
});
function SaveRequirmentStatus(event) {
    var itemID = $(event.currentTarget).attr('id');
    var intProjectId = $('[id$="hdnProjectId"]').val();
    var idRequirment = itemID.split('_')[1];
    var idRequirementPhase = itemID.split('_')[2];
    var idPhaseStatus = $(event.currentTarget).val();
    if (intProjectId != '0' && idRequirment != '0' && idRequirementPhase != '0') {
        $.getJSON('handler/RequirementLifecycleHandler.ashx?     FuncName=SaveRequirment&idRequirment=' + idRequirment + "&idRequirementPhase=" + idRequirementPhase + "&idProject=" + intProjectId + "&idPhaseStatus=" + idPhaseStatus, function (ValueStatus) {
            var s = ValueStatus;
            alert(this);
            this.value = s;
        });
    }
}    

通过jquery更改超链接单击事件中的文本

this在您使用它的上下文中没有引用链接,所以在内部函数之外保存对它的引用并使用它。此外,链接没有值,可以使用jQuery文本函数设置文本。

将你的代码更改为这个应该可以做你想做的事情:

function SaveRequirmentStatus(event) {
    var $this = this; // save reference to the clicked link
    var itemID=$(event.currentTarget).attr('id');
    var intProjectId=$('[id$="hdnProjectId"]').val();
    var idRequirment=itemID.split('_')[1];
    var idRequirementPhase=itemID.split('_')[2];
    var idPhaseStatus = $(event.currentTarget).val();
    if (intProjectId != '0' && idRequirment != '0' && idRequirementPhase != '0') {
        $.getJSON('handler/RequirementLifecycleHandler.ashx?FuncName=SaveRequirment&idRequirment=' + idRequirment + "&idRequirementPhase=" + idRequirementPhase + "&idProject=" + intProjectId + "&idPhaseStatus=" + idPhaseStatus, function(ValueStatus) {
            $this.text(ValueStatus); // set the text of the link to ValueStatus
        });
    }
}

这应该做

$(function() {
$('[id*="lnkStatus_"]').bind('click', SaveRequirmentStatus); 
});
function SaveRequirmentStatus(event) {
 $(this).text(ValueStatus);
}