为什么我在这个可选链中得到 "Object is possibly 'undefined'"?
Why am I getting "Object is possibly 'undefined'" in this optional chain?
我到了这里:
buyTicketData?.pricingOptions
这个错误:
[tsl] ERROR in /Applications/MAMP/htdocs/wp-content/plugins/tikex/tikexModule/components/BuyTicket/PricingOptionInvoiceItemsFormFieldsCheckboxes.tsx(280,25)
TS2532: Object is possibly 'undefined'.
如果 ?
的左侧未定义,?
包裹它,为什么重要?
以下是类型:
buyTicketData?: BuyTicketData;
export type BuyTicketData = {
pricingOptions?: PricingOptions;
}
export type PricingOptions = {
[optionId: string]: PricingOptionType;
};
export type PricingOptionType = {
invoiceItems?: InvoiceItems;
};
export type InvoiceItems = {
[invoiceItemId: string]: InvoiceItemData;
};
export type InvoiceItemData = {
defaultValue?: number;
};
这就是整个表达式
<select
value={
startPaymentIn?.invoiceItems?.[key] != undefined
? startPaymentIn?.invoiceItems?.[key] == 1
? "Igen"
: "Nem"
: startPaymentIn?.pricingOptionId &&
buyTicketData?.pricingOptions?.[ // <-- here
startPaymentIn!.pricingOptionId!
].invoiceItems[key]?.defaultValue != undefined
? startPaymentIn?.pricingOptionId &&
buyTicketData?.pricingOptions?.[
startPaymentIn!.pricingOptionId!
].invoiceItems[key]?.defaultValue == 1
? "Igen"
: "Nem"
: undefined
}
好的,找到解决方案:
value={
startPaymentIn?.invoiceItems?.[key] != undefined
? startPaymentIn?.invoiceItems?.[key] == 1
? "Igen"
: "Nem"
: buyTicketData?.pricingOptions?.[
startPaymentIn?.pricingOptionId ?? ""
]?.invoiceItems?.[key]?.defaultValue != undefined
? buyTicketData?.pricingOptions?.[
startPaymentIn?.pricingOptionId ?? ""
]?.invoiceItems?.[key]?.defaultValue == 1
? "Igen"
: "Nem"
: undefined
}
我只是不知道为什么需要这种丑陋的?? ""
条件。
如果 a
是 undefined
,a.b
抛出异常,而 a?.b
解析为 undefined
。您仍然需要处理 undefined
.
buyTicketData?.pricingOptions?.[startPaymentIn?.pricingOptionId]
解析为
buyTicketData?.pricingOptions?.[undefined]
如果 startPaymentIn
是 undefined
。这会引发错误,因为 undefined
不能是键。
如果这个变量是必需的,更好的方法是在一切之前做空检查,这样你就根本不需要 ?.
。
if(startPaymentIn)
{
//no need to use ?. on startPayment
}
您错过了一个可能未定义的 invoiceItems
的可选链接运算符。 defaultValue
查找应该是这样的:
buyTicketData?.pricingOptions?.[startPaymentIn!.pricingOptionId!]
.invoiceItems?.[key]?.defaultValue
下面minimal reproducible example illustrates this. Try it in Playground看错误。
export type BuyTicketData = {
pricingOptions?: PricingOptions;
}
export type PricingOptions = {
[optionId: string]: PricingOptionType;
};
export type PricingOptionType = {
invoiceItems?: InvoiceItems
}
export type InvoiceItems = {
[invoiceItemId: string]: InvoiceItemData
}
export type InvoiceItemData = {
defaultValue?: number
}
let startPaymentIn: PricingOptionType & { pricingOptionId?: string } = {}
function testContext (key: string, buyTicketData?: BuyTicketData) {
// incrementally testing your expression until we isolate the actual error
let w = buyTicketData?.pricingOptions
let x = buyTicketData?.pricingOptions?.[startPaymentIn!.pricingOptionId!]
let y = buyTicketData?.pricingOptions?.[startPaymentIn!.pricingOptionId!].invoiceItems
let z = buyTicketData?.pricingOptions?.[startPaymentIn!.pricingOptionId!].invoiceItems[key]
// ^^^ error on this last line
// the correct expression to get the `defaultValue`
const defaultValue =
buyTicketData?.pricingOptions?.[startPaymentIn!.pricingOptionId!].invoiceItems?.[key]?.defaultValue
return startPaymentIn?.invoiceItems?.[key] != undefined
? startPaymentIn?.invoiceItems?.[key] == 1
? "Igen"
: "Nem"
: startPaymentIn?.pricingOptionId &&
buyTicketData?.pricingOptions?.[
startPaymentIn!.pricingOptionId!
].invoiceItems?.[key]?.defaultValue != undefined
? startPaymentIn?.pricingOptionId &&
buyTicketData?.pricingOptions?.[
startPaymentIn!.pricingOptionId!
].invoiceItems?.[key]?.defaultValue == 1
? "Igen"
: "Nem"
: undefined
}
我到了这里:
buyTicketData?.pricingOptions
这个错误:
[tsl] ERROR in /Applications/MAMP/htdocs/wp-content/plugins/tikex/tikexModule/components/BuyTicket/PricingOptionInvoiceItemsFormFieldsCheckboxes.tsx(280,25)
TS2532: Object is possibly 'undefined'.
如果 ?
的左侧未定义,?
包裹它,为什么重要?
以下是类型:
buyTicketData?: BuyTicketData;
export type BuyTicketData = {
pricingOptions?: PricingOptions;
}
export type PricingOptions = {
[optionId: string]: PricingOptionType;
};
export type PricingOptionType = {
invoiceItems?: InvoiceItems;
};
export type InvoiceItems = {
[invoiceItemId: string]: InvoiceItemData;
};
export type InvoiceItemData = {
defaultValue?: number;
};
这就是整个表达式
<select
value={
startPaymentIn?.invoiceItems?.[key] != undefined
? startPaymentIn?.invoiceItems?.[key] == 1
? "Igen"
: "Nem"
: startPaymentIn?.pricingOptionId &&
buyTicketData?.pricingOptions?.[ // <-- here
startPaymentIn!.pricingOptionId!
].invoiceItems[key]?.defaultValue != undefined
? startPaymentIn?.pricingOptionId &&
buyTicketData?.pricingOptions?.[
startPaymentIn!.pricingOptionId!
].invoiceItems[key]?.defaultValue == 1
? "Igen"
: "Nem"
: undefined
}
好的,找到解决方案:
value={
startPaymentIn?.invoiceItems?.[key] != undefined
? startPaymentIn?.invoiceItems?.[key] == 1
? "Igen"
: "Nem"
: buyTicketData?.pricingOptions?.[
startPaymentIn?.pricingOptionId ?? ""
]?.invoiceItems?.[key]?.defaultValue != undefined
? buyTicketData?.pricingOptions?.[
startPaymentIn?.pricingOptionId ?? ""
]?.invoiceItems?.[key]?.defaultValue == 1
? "Igen"
: "Nem"
: undefined
}
我只是不知道为什么需要这种丑陋的?? ""
条件。
如果 a
是 undefined
,a.b
抛出异常,而 a?.b
解析为 undefined
。您仍然需要处理 undefined
.
buyTicketData?.pricingOptions?.[startPaymentIn?.pricingOptionId]
解析为
buyTicketData?.pricingOptions?.[undefined]
如果 startPaymentIn
是 undefined
。这会引发错误,因为 undefined
不能是键。
如果这个变量是必需的,更好的方法是在一切之前做空检查,这样你就根本不需要 ?.
。
if(startPaymentIn)
{
//no need to use ?. on startPayment
}
您错过了一个可能未定义的 invoiceItems
的可选链接运算符。 defaultValue
查找应该是这样的:
buyTicketData?.pricingOptions?.[startPaymentIn!.pricingOptionId!]
.invoiceItems?.[key]?.defaultValue
下面minimal reproducible example illustrates this. Try it in Playground看错误。
export type BuyTicketData = {
pricingOptions?: PricingOptions;
}
export type PricingOptions = {
[optionId: string]: PricingOptionType;
};
export type PricingOptionType = {
invoiceItems?: InvoiceItems
}
export type InvoiceItems = {
[invoiceItemId: string]: InvoiceItemData
}
export type InvoiceItemData = {
defaultValue?: number
}
let startPaymentIn: PricingOptionType & { pricingOptionId?: string } = {}
function testContext (key: string, buyTicketData?: BuyTicketData) {
// incrementally testing your expression until we isolate the actual error
let w = buyTicketData?.pricingOptions
let x = buyTicketData?.pricingOptions?.[startPaymentIn!.pricingOptionId!]
let y = buyTicketData?.pricingOptions?.[startPaymentIn!.pricingOptionId!].invoiceItems
let z = buyTicketData?.pricingOptions?.[startPaymentIn!.pricingOptionId!].invoiceItems[key]
// ^^^ error on this last line
// the correct expression to get the `defaultValue`
const defaultValue =
buyTicketData?.pricingOptions?.[startPaymentIn!.pricingOptionId!].invoiceItems?.[key]?.defaultValue
return startPaymentIn?.invoiceItems?.[key] != undefined
? startPaymentIn?.invoiceItems?.[key] == 1
? "Igen"
: "Nem"
: startPaymentIn?.pricingOptionId &&
buyTicketData?.pricingOptions?.[
startPaymentIn!.pricingOptionId!
].invoiceItems?.[key]?.defaultValue != undefined
? startPaymentIn?.pricingOptionId &&
buyTicketData?.pricingOptions?.[
startPaymentIn!.pricingOptionId!
].invoiceItems?.[key]?.defaultValue == 1
? "Igen"
: "Nem"
: undefined
}