需要在 TypeScript 中使用 fabricjs.d.ts 的示例
Need example of using fabricjs.d.ts with TypeScript
我在尝试转换为使用 TypeScript 的项目中使用 fabricjs,但我不知道如何使用它。以前我会通过执行以下操作来创建自己的自定义对象:
my.namespace.Control = fabric.util.createClass(fabric.Object, {
id: "",
type: 'Control',
color: "#000000",
...
});
在我的新项目中,我已经从 here 安装了 TypeDefinition 文件,但我不知道应该如何使用它?
查看 .d.ts 文件,fabric.Object 似乎不是函数,因此不允许传递给 createClass,并且 createClass 本身 returns 无效,所以我无法将值分配给变量。
即使所有这些都有效,我应该如何格式化它才能使其以 TypeScript 方式工作?即,我要导出什么以便可以将其导入到需要控件 class 的其他地方?
任何人实际上有这样做的例子吗?
使用 fabricjs.d.ts 的旧方法位于文件顶部:
/// <reference path="path/to/your/fabricjs.d.ts" />
如果您使用 tsd 获取它,则必须引用您的 tsd.d.ts 捆绑文件
但现在使用 typescript 1.6.2 和 vscode 您只需要通过 tsd 下载参考文件即可在您的代码中获取定义。
在 d.ts 文件中,您可以找到 2 个方法签名:
createClass(parent: Function, properties?: any): void;
createClass(properties?: any): void;
因此您的代码似乎无效,因为 fabric.Object 作为接口 IObjectStatict 不能分配给类型 Function。您可以将 fabric.Object 转换为执行
的函数
my.namespace.Control = fabric.util.createClass(<Function>fabric.Object, {
id: '',
type: 'Control',
color: '#000000',
...
});
您可以只定义一个扩展结构 class 的打字稿 class。
export interface IMindObjectOptions {
item: IMindItem;
}
export interface IMindExpanderOptions extends IMindObjectOptions {
x: number;
y: number;
radius: number;
isExpanded: boolean;
}
export class MindExpander extends fabric.Circle implements IMindObjectOptions {
public constructor(options: IMindExpanderOptions) {
const circleOptions: ICircleOptions = {
originX: "center",
originY: "center",
left: options.x,
top: options.y,
radius: options.radius,
stroke: "#000000",
fill: options.isExpanded ? "#00FFFF": "#00FF00",
selectable: false
};
super(circleOptions);
this.item = options.item;
}
public readonly item: IMindItem;
}
!!!上面的代码在浏览器中运行良好,但在 nodejs 环境中运行不正常。
要在 nodejs 环境中工作,例如 运行 没有浏览器的单元测试,您需要:
import {assert} from "chai";
import * as f from 'fabric';
import {ITextOptions} from "fabric";
declare function require(s: string): any;
declare const __dirname: string;
const fabric = require("fabric").fabric;
interface ITextConstructor {
new(text: string, options: ITextOptions): f.Text;
}
function getTextConstructor(): ITextConstructor {
return fabric.Text;
}
describe("nodejs setup", function () {
it("fabric is imported correctly", function () {
const x = fabric.Text as f.Text;
assert.equal(typeof x, "function");
});
it("fabric class is extensible", function () {
class SubText extends getTextConstructor() {
public constructor(text: string, options: fabric.ITextOptions) {
super(text, options);
}
}
const c = new SubText("Hello", {left: 100, top: 100});
assert.equal(c.text, "Hello");
assert.isNotNull(c);
});
});
我在尝试转换为使用 TypeScript 的项目中使用 fabricjs,但我不知道如何使用它。以前我会通过执行以下操作来创建自己的自定义对象:
my.namespace.Control = fabric.util.createClass(fabric.Object, {
id: "",
type: 'Control',
color: "#000000",
...
});
在我的新项目中,我已经从 here 安装了 TypeDefinition 文件,但我不知道应该如何使用它?
查看 .d.ts 文件,fabric.Object 似乎不是函数,因此不允许传递给 createClass,并且 createClass 本身 returns 无效,所以我无法将值分配给变量。
即使所有这些都有效,我应该如何格式化它才能使其以 TypeScript 方式工作?即,我要导出什么以便可以将其导入到需要控件 class 的其他地方?
任何人实际上有这样做的例子吗?
使用 fabricjs.d.ts 的旧方法位于文件顶部:
/// <reference path="path/to/your/fabricjs.d.ts" />
如果您使用 tsd 获取它,则必须引用您的 tsd.d.ts 捆绑文件
但现在使用 typescript 1.6.2 和 vscode 您只需要通过 tsd 下载参考文件即可在您的代码中获取定义。
在 d.ts 文件中,您可以找到 2 个方法签名:
createClass(parent: Function, properties?: any): void;
createClass(properties?: any): void;
因此您的代码似乎无效,因为 fabric.Object 作为接口 IObjectStatict 不能分配给类型 Function。您可以将 fabric.Object 转换为执行
的函数my.namespace.Control = fabric.util.createClass(<Function>fabric.Object, {
id: '',
type: 'Control',
color: '#000000',
...
});
您可以只定义一个扩展结构 class 的打字稿 class。
export interface IMindObjectOptions {
item: IMindItem;
}
export interface IMindExpanderOptions extends IMindObjectOptions {
x: number;
y: number;
radius: number;
isExpanded: boolean;
}
export class MindExpander extends fabric.Circle implements IMindObjectOptions {
public constructor(options: IMindExpanderOptions) {
const circleOptions: ICircleOptions = {
originX: "center",
originY: "center",
left: options.x,
top: options.y,
radius: options.radius,
stroke: "#000000",
fill: options.isExpanded ? "#00FFFF": "#00FF00",
selectable: false
};
super(circleOptions);
this.item = options.item;
}
public readonly item: IMindItem;
}
!!!上面的代码在浏览器中运行良好,但在 nodejs 环境中运行不正常。
要在 nodejs 环境中工作,例如 运行 没有浏览器的单元测试,您需要:
import {assert} from "chai";
import * as f from 'fabric';
import {ITextOptions} from "fabric";
declare function require(s: string): any;
declare const __dirname: string;
const fabric = require("fabric").fabric;
interface ITextConstructor {
new(text: string, options: ITextOptions): f.Text;
}
function getTextConstructor(): ITextConstructor {
return fabric.Text;
}
describe("nodejs setup", function () {
it("fabric is imported correctly", function () {
const x = fabric.Text as f.Text;
assert.equal(typeof x, "function");
});
it("fabric class is extensible", function () {
class SubText extends getTextConstructor() {
public constructor(text: string, options: fabric.ITextOptions) {
super(text, options);
}
}
const c = new SubText("Hello", {left: 100, top: 100});
assert.equal(c.text, "Hello");
assert.isNotNull(c);
});
});