jQuery   发布时间:2022-03-30  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了jquery-ui – 在TypeScript中定义一个自定义的jQuery UI小部件大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我们目前正在将JavaScript项目翻译成TypeScript。@R_889_9616@程序严重依赖于定制开发的jQuery UI小部件。

在我们目前的代码库中,我们使用深层复制机制来继承窗口小部件定义,例如,我们可以声明一个通用的TableWidget以及定义更多特定功能的@R_618_6201@TableWidget。

因此,我想将我的小部件定义定义为TypeScript类,然后将这些类的实例绑定到jQuery。

例如

class MyWidget {
    options: WidgetOptions;
    _init(){
        // general initialization
    }
}

class MySecondWidget extends MyWidget {
    _init(){
        super._init();
        // specific initialization
    }
}

接着

$.widget("MyNameSpace.MyWidget",new MyWidget());
$.widget("MyNameSpace.MySeWidget",new MyWidget());

此外,我想将我的自定义小部件表示为jQuery UI的Widget定义的实现

class MyWidget implements Widget {
    options: WidgetOptions;
    _init(){
        // general initialization
    }
}

@R_200_9447@在TypeScript中使用以下语法:

$(SELEctor).MyWidget(options);

我知道我必须使用定义文件(从DefinitelyTyped),但是我还没有找到一个可靠的来源解释我如何在TypeScript中编写自定义的jQuery UI小部件。有没有人有这方面的经验?

任何帮助非常感谢,一如既往!

解决方法

我不知道你可以编写一个实现Widget界面的类,因为缺少重载的构造函数。您可以创建一个由Widget界面输入的变量。

一个标准的jQuery插件将代表几乎纯粹的JavaScript,不会使用模块或类,因为它最终被包装成jQuery的一部分,它本身不是模块或类。

这是一个名为plugin的空插件,看起来像任何标准的jQuery插件,但您可以看到它利用了TypeScript类型的系统,并扩展了JQuery接口以允许调用它。

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

interface JQuery {
    plugin(): JQuery;
    plugin(setTings: Object): JQuery;
}

(function ($) {

    function DoSomething(someParamater: String) : void {

    }

    $.fn.plugin = function (setTings) {

        var config = {
            setTingA: "Example",setTingB: 5
        };

        if (setTings) {
            $.extend(config,setTings);
        }

        return this.each(function () {

        });
    };

})(jQuery);

这将以正常的方式调用

$('#id').plugin();

所以真的,我的答案是 – 你不能真正做你想要的,因为你添加到声明的jQuery接口,而不是将它们作为模块。您可以将模块包装在一个模块中,例如可将jQuery方面与您的TypeScript中使用相提并论的适配器,或者您可以从插件调用您的类,但插件或小部件并不适用于模块或类。

大佬总结

以上是大佬教程为你收集整理的jquery-ui – 在TypeScript中定义一个自定义的jQuery UI小部件全部内容,希望文章能够帮你解决jquery-ui – 在TypeScript中定义一个自定义的jQuery UI小部件所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。