- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我将 TypeORM 与 Babel 7 和 Typescript 一起使用,元数据似乎不存在于编译后的代码中。可以做些什么吗?还是这是使用 Babel 的限制?
错误
ColumnTypeUndefinedError: Column type for Photo#isPublished is not defined and cannot be guessed. Make sure you have turned on an "emitDecoratorMetadata": true option in tsconfig.json. Also make sure you have imported "reflect-metadata" on top of the main entry file in your application (before any entity imported).If you are using JavaScript instead of TypeScript you must explicitly provide a column type. at new ColumnTypeUndefinedError
Photo.js
import { Column, Entity, PrimaryGeneratedColumn } from 'typeorm'
@Entity()
export class Photo {
@PrimaryGeneratedColumn()
id: number
@Column()
isPublished: boolean
}
订单代码
import 'reflect-metadata'
import {createConnection} from 'typeorm'
import {Photo} from './entities/Photo'
createConnection({
type: 'postgres',
host: 'localhost',
port: 5432,
username: 'postgres',
password: 'root',
database: 'test',
entities: [
Photo
],
synchronize: true,
logging: false
}).then(connection => {
// here you can start to work with your entities
}).catch(error => console.log(error))
package.json
{
"name": "typescript-babel-node",
"version": "0.1.0",
"description": "",
"main": "index.js",
"scripts": {
"dev": "run-p -r dev:run type-check:watch",
"dev:run": "nodemon --exec babel-node --extensions '.ts,.js' src/index.js",
"build": "babel src -d build --extensions '.ts,.js' src/index.js",
"start": "node build/index.js",
"type-check:watch": "tsc --watch",
"test": "jest --watch"
},
"author": "",
"license": "ISC",
"dependencies": {
"@types/node": "^10.12.0",
"express": "^4.16.4",
"pg": "^7.6.0",
"ramda": "^0.25.0",
"reflect-metadata": "^0.1.12",
"typeorm": "^0.2.8"
},
"devDependencies": {
"@babel/cli": "^7.1.2",
"@babel/core": "^7.1.2",
"@babel/node": "^7.0.0",
"@babel/plugin-proposal-class-properties": "^7.1.0",
"@babel/plugin-proposal-decorators": "^7.1.2",
"@babel/plugin-proposal-object-rest-spread": "^7.0.0",
"@babel/plugin-syntax-import-meta": "^7.0.0",
"@babel/preset-env": "^7.1.0",
"@babel/preset-typescript": "^7.1.0",
"@types/express": "^4.16.0",
"@types/jest": "^23.3.7",
"@types/ramda": "^0.25.39",
"babel-core": "^7.0.0-bridge.0",
"babel-jest": "^23.6.0",
"babel-plugin-module-resolver": "^3.1.1",
"dot-env": "0.0.1",
"eslint": "^5.7.0",
"eslint-config-standard": "^12.0.0",
"eslint-plugin-import": "^2.14.0",
"eslint-plugin-node": "^7.0.1",
"eslint-plugin-promise": "^4.0.1",
"eslint-plugin-standard": "^4.0.0",
"jest": "^23.6.0",
"nodemon": "^1.18.5",
"npm-run-all": "^4.1.3",
"regenerator-runtime": "^0.12.1",
"source-map-loader": "^0.2.4",
"ts-jest": "^23.10.4",
"typescript": "^3.1.3",
"webpack": "^4.23.0",
"webpack-cli": "^3.1.2"
}
}
编辑:过了一会儿我找到了另一个 Babel 插件来解决这个问题,除了接受的答案中提到的那个: babel-plugin-transform-typescript-metadata似乎在使用 TypeORM 和 Nest。
最佳答案
开箱即用,如另一个答案中所述,这是不支持的。然而,我们可以编写一个 babel 插件来让它工作。
写代码不是很复杂,问题出在我们babel里面的信息有限。 Babel 不对 typescript 执行类型检查。这意味着我们没有任何语义信息,我们只有类型注释以及我们可以从中获得的信息。这意味着我们的解决方案必然非常有限
限制:
undefined
,为了避免undefined,我们可以type ||如果类型没有关联的运行时值,对象
默认为对象Number
或String
。由于我们将类型名称写入元数据,这意味着您最终将在元数据中获得枚举的容器对象。 类型序列化可以从 typescript 编译器本身复制,只需很少的改动(它实际上只是两个函数 serializeTypeNode
和 serializeTypeList
,大约 150 行代码)。
对于这个示例类,我们得到的结果是:
declare var decorator: any;
interface ISampleInterface {
}
enum Flags { One }
class OtherClass {}
type ArrayAlias = number[]
class Test {
@decorator
untypedProp; // no design:type
@decorator
nrProp: number // Number as expected
@decorator
strProp: string // String as expected
@decorator
boolProp: boolean // Boolean as expected
@decorator
nrPropUndefined: number | undefined // Number as expected
@decorator
strPropUndefined: string | undefined // String as expected
@decorator
boolPropUndefined: boolean | undefined // Boolean as expected
@decorator
arrayProp: number[]
// Type references
@decorator
classRefProp: OtherClass; // OtherClass || Object = Object since OtherClass is still a class at runtime
@decorator
interfaceRefProp: ISampleInterface; // ISampleInterface || Object = Object since ISampleInterface is undefined at runtime
@decorator
enumRefProp: Flags; // Flags || Object = Flags since Flags exists as a value at runtime, here TS would have written Number/String
@decorator
typeAliasProp: ArrayAlias; // ArrayAlias || Object = Object since ArrayAlias does not exist t runtime and in Babel swe have no idea ArrayAlias is actually an array
@decorator
selfClassRefProp: Test; // Test || Object = Object since Babel puts decorators instantiation before class definition, this is a quirk, this may be fixable
}
实际的插件代码不是很大(减去从 TS 版本复制过来的方法):
export default declare((api: typeof import('@babel/core'), { jsxPragma = "React" }): PluginObj => {
api.assertVersion(7);
return {
name: "transform-typescript-decorator-metadata",
inherits: syntaxTypeScript,
visitor: {
ClassDeclaration(path) {
var node = path.node;
for (const field of node.body.body) {
if (field.type !== "ClassProperty") continue;
if (field.typeAnnotation && field.typeAnnotation.type === "TSTypeAnnotation" && field.decorators && field.decorators.length > 0) {
const key = field.key as t.Identifier;
const serializedType = serializeTypeNode(field.typeAnnotation.typeAnnotation);
field.decorators.push(decorator(
t.callExpression(
t.memberExpression(t.identifier("Reflect"), t.identifier("metadata")), [
t.stringLiteral("design:type"),
t.logicalExpression("||", serializedType, createIdentifier("Object"))
])
))
}
}
},
}
};
});
您可以找到完整的插件代码和工作示例 here
另一方面,插件顺序很重要,如果 @babel/plugin-proposal-class-properties
出现在我们的插件之前,它将删除所有属性,我们的插件将没有信息不再发射装饰器。这是我测试过的 .babelrc
并且它可以工作,我没有使用任何其他配置(但我不能说我已经尽力了)
{
"env": {},
"ignore": [],
"plugins": [
"../plugin/plugin.js",
["@babel/plugin-proposal-decorators", { "legacy": true }],
["@babel/plugin-proposal-class-properties", { "loose": true }],
"babel-plugin-transform-es2015-modules-commonjs"
],
"presets": [
"@babel/preset-typescript"
]
}
关于typescript - 使用 Typescript、Babel 7、装饰器保留元数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53015862/
最终目标:我想要由 Git 跟踪的文件,但让这些文件对于所有分支都是相同的版本。如果您使用 gitignore 文件,则所有分支的文件都是相同的,但不幸的是不会被跟踪。当我跑 git push或类似的
我想从 PDF 文件中删除元数据。我已经尝试使用“exiftool”、“pdftk”和“qpdf”来删除元数据(建议的方法 - https://gist.github.com/hubgit/60783
AWS EC2 元数据从 EC2 提供了有关其自身的必要信息(废话!) - 是否有任何与 lambda 等效的信息。 我了解与 EC2 不同的 lambda 函数的 Multi-Tenancy 和短期
我正在使用 libavformat(即 C 库)将 MPEG4/H264 编码为 mp4 文件,我想在 MP4 文件中添加一些元数据,例如日期/时间。有人可以告诉我如何做到这一点吗? 谢谢。 最佳答案
有谁知道任何允许从 .jpg 图像中提取 java 元数据的类?或者可能是一些有用的代码? 谢谢! 最佳答案 我维护着一个库,正是这样做的。 https://github.com/drewnoakes
我尝试找出如何从媒体获取元数据有一段时间了,但到目前为止没有任何效果。我有类 Song,其中有 SimpleStringProperties,如标题、艺术家等。我尝试在类构造函数中为它们设置值: pr
我已经多次遇到这个问题,并且从不喜欢所选择的解决方案。假设您在数据库中有一个状态列表(作为一个简单的示例)。在您的代码隐藏中,您希望能够通过 ID 引用状态并通过 Intellisense 获得状态列
我在我的应用程序中使用 google 登录并从 google 获取用户个人资料信息。 我已经测试过,它在我这边工作正常,但苹果拒绝了它。我没有发现任何错误。 苹果拒绝原因:“Verify is you
我正在开发一个基于 MySQL 数据库的 Web 应用程序。我需要收集和分析使用情况和性能统计数据。统计数据将针对非技术人员。 如何实现此功能?您应该将我的问题视为编程问题,但如果您知道合适的工具或扩
我对如何保存表格行的元数据有疑问。 例如,我有一个表,其中包含有关图像 items_images 的数据。编号,整数(20)标题,VARCHAR(255)添加日期,DATETIME... 现在我想添加
我不明白为什么我必须在 list 中使用两个元数据元素才能开始运行我的 Google Maps API v2 项目。这些标签的用途是什么? 最佳答案 元数据是指有关数据的数据。 关于java -
如何获取 SharePoint 文档库中项目的内容类型列或元数据? 此链接提供了我不需要的文件属性 http://msdn.microsoft.com/en-us/library/microsoft.
我很确定这是可能的,只是不确定它的术语是什么以及如何去做。基本上,如果您右键单击任何文件并转到属性,然后转到摘要,您可以向文件添加评论等。 我想知道的是,您将如何从 C# 中有问题地执行此操作。此外,
在我的应用程序中,我正在从 Assets 库中检索 UIImage,该图像具有元数据。然后,该应用程序会调整图像大小并旋转图像,从而创建新图像。新图像没有预期的原始元数据,但如何在上传前将元数据添加回
Java 通过JDBC获得连接以后,得到一个Connection 对象,可以从这个对象获得有关数据库管理系统的各种信息,包括数据库中的各个表,表中的各个列,数据类型,触发器,存储过程等各方面的信息。
想知道是否有人知道扩展或配置 Breeze 以便服务器返回实体元数据中的附加信息的任何方法?我想使用这些附加数据来协助验证。 假设我有一个应用了一些数据注释的实体模型: public class Pe
我正在寻找将 MEF 用于我正在构建的应用程序的插件系统。我希望每个组件在(GUID)上都有一个我希望能够查找的标识符。但是,此 ID 在处理导出部件时也很有用。 有没有一种方法可以让我在导出的部分上
我对不完整的视频有疑问。例如上传失败的视频。如果您使用 ffmpeg -i 检查其元数据您将获得 1 小时的持续时间,但实际上只有 10mb 已上传到服务器,实际持续时间约为 7 分钟。查找这些视频
我在使用 FFmpeg 覆盖视频文件上的元数据时遇到了一些问题,这些文件之前已经添加了元数据(FFmpeg 也添加了以前的元数据)。 所以我使用ffmpeg -i path/to/video file
我有两个项目组想要加入: A B 使用常规连接会给我一个包含 4 个项目的集合: ServerA with Metadata A; ServerB with Metad
我是一名优秀的程序员,十分优秀!