- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以下包含 getter/setter 的 TypeScript 类:
export class KitSection {
uid: string;
order: number;
set layout(layout: KitLayout) {
this._layout = new KitLayout(layout);
}
get layout() {
return this._layout;
}
private _layout: KitLayout;
constructor(init?: Partial<KitSection>) {
Object.assign(this, init);
}
}
// I can create an instance like so:
const section = new KitSection(data);
我需要将此实例作为 JSON 对象POST
到我的服务器,以存储在类型为 JSON
的 MySQL 数据库列中,所以我想我可以执行以下操作:
const jsonSection = JSON.parse(JSON.stringify(section))
这创建了一个 JSON
对象,但是当我在控制台中检查时,我看到我的私有(private) getter/setter 变量而不是对象中的公共(public)变量:
console.log(jsonSection);
///IN CONSOLE///
uid: "a"
order: 0
_layout: {_rows: Array(2), columns: 12}
我不想在我的数据库中存储私有(private)变量 _layout
,我需要存储在 getter/setter 中定义的公共(public)变量:layout
。
接下来,我查看了此处提供的答案:https://stackoverflow.com/a/44237286/6480913它建议添加以下方法以转换为 JSON
:
public toJSON(): string {
let obj = Object.assign(this);
let keys = Object.keys(this.constructor.prototype);
obj.toJSON = undefined;
return JSON.stringify(obj, keys);
}
但是,这会返回一个空对象。经检查,当我 console.log()
this.constructor.prototype
时,我看到了对象的所有属性,但每个对象都是灰色的,所以当我们使用 Object.keys()
时,我收到一个空数组。为什么这些构造函数属性是灰色的?
最佳答案
JSON.stringify
将仅 迭代自己的可枚举属性。在这里,由于 layout
是 prototype 对象的属性,而不是实例本身,当您尝试对实例进行字符串化时,不会调用 getter。 (但由于_layout
是自己的可枚举属性,它包含在结果中)
类似地,下面的字符串化对象是空的:
const obj = Object.create({
get prop() {
return 'val';
}
});
console.log(JSON.stringify(obj));
您可以通过将 getter 直接放在实例上并使 _layout
不可枚举来修复它。这样,当字符串化时,将调用 getter,但不会包含 _layout
:
export class KitSection {
uid: string;
order: number;
private _layout: KitLayout;
constructor(init?: Partial<KitSection>) {
Object.defineProperty(
this,
'layout',
{
enumerable: true,
get() {
return this._layout;
},
set(newVal) {
this._layout = new KitLayout(newVal);
}
}
);
Object.defineProperty(
this,
'_layout',
{
enumerable: false,
value: undefined,
}
);
Object.assign(this, init);
}
}
const section = new KitSection(data);
如果改用私有(private)类字段语法,它会看起来更清晰一些:
export class KitSection {
#layout: KitLayout | undefined;
constructor(init?: Partial<KitSection>) {
Object.defineProperty(
this,
'layout',
{
enumerable: true,
get() {
return this.#layout;
},
set: (newVal) => {
this.#layout = new KitLayout(newVal);
}
}
);
Object.assign(this, init);
}
}
您也可以手动调用 getter。
如果 KitLayout
本质上是可序列化的,要将序列化对象变回 KitSection 实例,KitLayout
或其辅助方法之一需要能够将序列化对象KitLayout
到一个实例中。要么再次通过构造函数传递它(只需调用 new KitSection
,它将它交给 KitLayout
),要么将 layout
与反序列化对象分开,然后在 KitSection
上有一个单独的方法调用 KitLayout
的辅助方法并分配私有(private)属性,可能是这样的:
integrateLayout(layoutInfo) {
this.#layout = KitLayout.makeKitLayoutFromLayoutInfo(layoutInfo)
}
其中 layoutInfo
是普通对象。
关于javascript - 如何将带有 getter/setter 的 TypeScript 类实例转换为 JSON 以存储在 MySQL 数据库中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61166669/
因此,我需要获取在为其赋值时调用的 setter 的名称。像这样: var b = {}; var a = { set hey(value) { b[] = value; } } 我希望 se
我是 Android 编程的新手(~ 2 个月)有必要为几十个不同的变量设置 getter 吗? 例如—— //Yes I realise that this isn't 'dozens' publi
import Control.Lens import Control.Lens.TH data Foo = Foo { _bar, _baz :: Int } makeLenses ''
我有点困惑:我可以覆盖 setter/getter 但仍然使用 super setter/getter 吗?如果是 - 怎么办? 用例: class A { void set value(num
我有一个接收消息的应用程序。消息中存在可编辑的字段。当字段更改时,应将其保存到数据库中。不幸的是,setter 仅在 setter 的范围内更改给定字段的值。知道为什么会发生这种情况吗?这是 gett
C# 中有没有一种方法可以让 setter 从“某物”继承,这样每次为特定基类及其继承者调用 setter 时,我都可以运行一些代码? 我想做的是在我的基类上有一个名为 IsValid 的 bool
可能是一个我无法解决的非常简单的问题 - 我从 C# 开始,需要使用 getter/setter 方法向数组添加值,例如: public partial class Form1 : Form {
这两个属性实现有什么区别? public override string A { get { return "s"; } set { } } public override strin
是否可以使用 abc.abstractproperty 创建一个具体的 getter 但将 setter 抽象为每个继承类的不同。我为每个子类处理不同的 val 设置。 例如。 @abstractpr
我在某处看到类似下面的内容,想知道它是什么意思。我知道他们是getter和setter,但是想知道为什么字符串Type是这样定义的。谢谢你帮助我。 public string Type { get;
Public class Example { private int number; public Example(int number){ this.number =
假设我有这样的代码: public response MyMethod(Request req) { String id = req.getFirst().geId(); } 我已经模拟了主对
允许这样做: public int Age { get; set; } 但是应用程序是否为变量创建/分配空间?我经常这样做 private int age = 0; public int Age {
我有一个条件,我构造字符串 (finalValue) 的方式是基于我在输入中获得的非空值的数量。所以我想知道是否可以用一个不同的参数为字符串 (finalValue) 重载 setter 方法并根据我
例如,在这段代码中 var o = { set a(value) {this.b = value}, get a() {return this.b} } 是否有可能获得对 o.a 的 sett
我一直在努力了解 getter 和 setter,但没有深入了解。我读过 JavaScript Getters and Setters和 Defining Getters and Setters只是没
我想在我的类中添加一个 getter 和 setter。然而,setter 应该接收一个 querySelector,但 getter 返回一个新类型 pageSections。 我的问题是 gett
使用有什么好处: private var _someProp:String; public function set someProp(value:String):void { _somePr
当从域类调用它时,我想在我的 setter 中执行一些操作,而不是从 hibernate 中调用它时。此外,我正在使用 session 工厂,因此我无法使用 @PostLoad 来触发标志! 有人对此
人员类别: public class Person { private String firstName; private String lastName; public Pe
我是一名优秀的程序员,十分优秀!