TypeScript расширяет JQuery в пространстве имен

Я пытаюсь расширить интерфейс JQuery по умолчанию и объект jQuery по умолчанию с помощью функции в TypeScript.

Код

/// <reference path="jquery.d.ts" />

namespace MyNameSpace {
    var $ = jQuery;
    export interface JQuery {
        test(options: Object): JQuery;
    }
    $.fn.test = function(options: Object): JQuery {
        if (this.length === 0) {
            console.log('Error!');
            return this;
        }
        console.log(options);
        return this;
    }
    export var testBody = function() {
        jQuery('body').test({ 'HELLO': 'TEST' });
    }
}

Проблема

Теперь я запускаю следующий код в своей консоли: tsc -m amd -t ES5 Test.ts -d

Я получаю эту ошибку: Test.ts(17,19): error TS2339: Property 'test' does not exist on type 'JQuery'.

Любое решение для этого?


person Jason Schilling    schedule 22.10.2015    source источник


Ответы (1)


Это работает для меня:

/// <reference path="typings/jquery/jquery.d.ts" />

interface JQuery {
    test(options: Object): JQuery;
}

namespace MyNameSpace {
    var $ = jQuery;

    $.fn.test = function(options: Object): JQuery {
        if (this.length === 0) {
            console.log('Error!');
            return this;
        }
        console.log(options);
        return this;
    };
    export var testBody = function() {
        jQuery('body').test({ 'HELLO': 'TEST' });
    }
}

EDIT: второе решение

/// <reference path="typings/jquery/jquery.d.ts" />

namespace MyNameSpace {

    interface JQueryX extends JQuery {
        test(options: Object): JQuery;
    }

    $.fn.test = function(options: Object): JQuery {
        if (this.length === 0) {
            console.log('Error!');
            return this;
        }
        console.log(options);
        return this;
    };

    export var testBody = function() {
        let a:JQueryX = <JQueryX>$('body');
        a.test({ 'HELLO': 'TEST' });
        // OR
        (<JQueryX>$('body')).test({ 'HELLO': 'TEST' });
    }
}

Вы можете сделать testBody более красивым с помощью некоторого рефакторинга.

person Martin Vseticka    schedule 22.10.2015