微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Javascript:从ajax成功设置类属性

我有一个名为Spotlight的“类”/函数.我正在尝试通过ajax检索一些信息并将其分配给Spotlight的属性.这是我的Spotlight类:
function Spotlight (mId,mName) {
    this.area = new Array();

    /**
     * Get all area information
     */
    this.getArea = function () {

        $.ajax({
            url: base_url +'spotlight/aGetArea',type: 'POST',success: function (data) {
                this.area = data;
            }
        });
    }
}

我已经将对象分配给一个数组,并且很难从Spotlight中获取它,所以我希望使用’this’访问所有内容.虽然成功函数在类之外,但我不知道如何在类中创建它.

有没有办法使用this.area而不是Spotlight.area将数据导入类属性

解决方法

其值取决于每个函数调用方式.我看到了解决这个问题的3种方法

1.为此创建别名

var that = this;
this.getArea = function () {
    $.ajax({
        url: base_url +'spotlight/aGetArea',success: function (data) {
            that.area = data;
        }
    });
};

2.使用jQuery .ajax context选项

this.getArea = function () {
    $.ajax({
        url: base_url +'spotlight/aGetArea',context : this,success: function (data) {
            this.area = data;
        }
    });
};

3.使用绑定函数作为回调

this.getAreaSuccess = function (data) {
    this.area = data;
};
this.getArea = function () {
    $.ajax({
        url: base_url +'spotlight/aGetArea',success: this.getAreaSuccess.bind(this)
    });
};

原文地址:https://www.jb51.cc/ajax/155483.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐