JQuery widget:在子 widget 中设置上下文

JQuery widget: setting context in sub-widget

本文关键字:widget 设置 上下文 在子 JQuery      更新时间:2023-09-26

我有一个小部件,它基本上在元素上创建一个JQuery日期选择器,然后处理从Web服务检索数据以及根据返回的数据启用/禁用日期。

小部件的定义是这样的 - 几个简单的默认选项:

$.widget("XXXX.CalendarBooking", {
    options: {
    minDaysInAdvance: 0,
    maxDaysInAdvance: 0,
    productNumber: '',
    url: '',
    numberOfDays: 40
},
...

构造函数如下所示,它在元素上创建日期选取器,然后设置用于检索数据和处理(启用)日期的函数:

_create: function () {
    this.element.datepicker({
        dateFormat: 'dd MM yy',
        firstDay: 1,
        minDate: this.options.minDaysInAdvance,
        maxDate: this.options.maxDaysInAdvance,
        beforeShowDay: this._processDate,
        onChangeMonthYear: this._changeMonthYear
    });
    ...

处理日期函数如下所示:

_processDate: function (date) {
    // get availability
    if (!this._availability) {
    $.ajax({
        async: false,
        type: "POST",
        contentType: "application/json; charset=utf-8",
        url: this.options.url,
        data: '{ productNumber: "' + this.options.productNumber + '", startDate: "' + date.toJSON() + '", numberOfDays: ' + numberOfDays + ' }',
        dataType: "json",
        success: function (msg) {
            _setAvailability(msg.d);
        },
        error: function (xhr, ajaxOptions, thrownError) {
            _setAvailability('error');
        }
    });
}

但是,当调用 processdate 时,上下文不在小部件中,因此我无法访问这些选项。我这样做是否正确,或者有没有办法重载 processdate 函数,以便在为 beforeShowDay 设置回调时,我可以传入选项,并且它不会覆盖 JQuery 将传递给该函数的日期值?

可以使用 $.proxy 来设置应在其中调用函数的上下文。 试试这个:

beforeShowDay: $.proxy(this._processDate, this),

现在,在您的_processDate函数中,this关键字将引用您的小部件。您可以使用 this.element 访问引发事件的元素。