后端報(bào)TypeError:Cannot?read?properties?of?null?(reading?‘xxx‘)的錯(cuò)誤解決
1. 文章目錄
今天測(cè)試小姐姐,在測(cè)試某頁(yè)面時(shí),報(bào)出如下圖的錯(cuò)誤:

TypeError: Cannot read properties of null (reading 'type')
at w (http://...xxx.../assets/index.a9f96e7f.js:1052:191280)
at x (http://...xxx.../assets/index.a9f96e7f.js:952:39438)
at b (http://...xxx.../assets/index.a9f96e7f.js:952:36266)
at I (http://...xxx.../assets/index.a9f96e7f.js:986:59452)
at div
at div
at div
at div
at S (http://...xxx.../assets/index.a9f96e7f.js:1071:9994)
at x (http://...xxx.../assets/index.a9f96e7f.js:952:39438)
at b (http://...xxx.../assets/index.a9f96e7f.js:952:36266)
at I (http://...xxx.../assets/index.a9f96e7f.js:986:59452)
at w (http://...xxx.../assets/index.a9f96e7f.js:986:51920)
at r (http://...xxx.../assets/index.a9f96e7f.js:1052:16143)
at b (http://...xxx.../assets/index.a9f96e7f.js:967:8581)
at x (http://...xxx.../assets/index.a9f96e7f.js:967:10843)
at w (http://...xxx.../assets/index.a9f96e7f.js:986:66365)
at b (http://...xxx.../assets/index.a9f96e7f.js:952:36266)
at div
即TypeError: Cannot read properties of null (reading 'type')。
2. 分析問(wèn)題
正趕上最近ChatGPT比較火,可以借助它幫助我分析問(wèn)題,如下圖所示:

ChatGPT無(wú)法回答我的問(wèn)題,我只能自己分析此錯(cuò)誤了。
將TypeError: Cannot read properties of null (reading 'type')翻譯成中文,即類(lèi)型錯(cuò)誤:無(wú)法讀取 null 的屬性(讀取“類(lèi)型”)。
也就是說(shuō),json存在null值的對(duì)象。
因?yàn)椋岸耸褂?code>amis框架,后端需生成amis格式的json對(duì)象。
前端拿到amis格式的json對(duì)象后,在amis框架中渲染即可。
由于null對(duì)象的出現(xiàn),導(dǎo)致amis無(wú)法解析對(duì)應(yīng)的屬性。
于是,去定位出前端null對(duì)象的位置,如下圖所示:

實(shí)際上,headerToolbar的格式如下:
"headerToolbar": [
{
"actionType": "dialog",
"dialog": {
"body": {
"api": {
"method": "post",
"url": "http://xxx/common/2023030905235058401/enterprise/100/add"
},
"body": [
{
"name": "orgname2",
"id": "u:20230309052540720",
"label": "所在社區(qū)",
"type": "input-text"
},
......
{
"name": "ifdanger",
"id": "u:20230309052540725",
"label": "是否為危化企業(yè)",
"type": "input-text"
}
],
"type": "form"
},
"title": "新增"
},
"level": "primary",
"id": "u:20230309052540213",
"label": "新增",
"type": "button"
},
"bulkActions"
]如上代碼所示,正常情況下,headerToolbar存在type屬性。正因?yàn)樯鲜霾糠执a值為null,導(dǎo)致amis無(wú)法解析到type屬性,即報(bào)出TypeError: Cannot read properties of null (reading 'type')錯(cuò)誤。
接著,再去定位到后端生成null對(duì)象的代碼位置,如下圖所示:

因而,需要修改后端代碼。
3. 解決錯(cuò)誤
根據(jù)以上分析后得知,由于后端生成的null對(duì)象的值,導(dǎo)致amis無(wú)法解釋后端生成的對(duì)象,即可進(jìn)行如下修改:
...
if (isNull(addButton)) {
curdJsonVm = replace(curdJsonVm, "${headerToolbars},", "");
log.info("model page info:{}", JSONUtil.toJsonPrettyStr(curdJsonVm));
return curdJsonVm;
}
curdJsonVm = replace(curdJsonVm, "${headerToolbars}", JSONObject.toJSONString(addButton));
...
重新啟動(dòng)服務(wù),即可正常訪問(wèn),無(wú)報(bào)錯(cuò)信息:

4. 問(wèn)題總結(jié)
如果類(lèi)似TypeError: Cannot read properties of null (reading ‘xxx‘)不是后端造成的,一般是你的json對(duì)象存在null對(duì)象。
本來(lái)你正常的json對(duì)象,存在某個(gè)屬性,框架能夠解析該屬性。
但出現(xiàn)了null對(duì)象后,導(dǎo)致前端框架無(wú)法解析null對(duì)象的屬性。
總結(jié)
到此這篇關(guān)于后端報(bào)TypeError:Cannot read properties of null (reading ‘xxx‘)的錯(cuò)誤解決的文章就介紹到這了,更多相關(guān)TypeError:Cannot read properties of null內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- js控制臺(tái)報(bào)錯(cuò)Uncaught TypeError: Cannot read properties of undefined (reading ‘a(chǎn)ppendChild‘)的解決
- React/vue開(kāi)發(fā)報(bào)錯(cuò)TypeError:this.getOptions?is?not?a?function的解決
- 解決TypeError: Object of type xxx is not JSON serializable錯(cuò)誤問(wèn)題
- TypeError: Cannot set properties of undefined (setting ‘xx‘)的問(wèn)題及解決方法
相關(guān)文章
Spring Boot 對(duì)接深度求索接口實(shí)現(xiàn)知識(shí)問(wèn)答功能
本文詳細(xì)介紹了如何使用 Spring Boot 對(duì)接深度求索接口,實(shí)現(xiàn)知識(shí)問(wèn)答功能,通過(guò)整合深度求索 API,我們可以輕松地在 Spring Boot 項(xiàng)目中實(shí)現(xiàn)智能問(wèn)答功能,2025-02-02
深入淺析Java中Static Class及靜態(tài)內(nèi)部類(lèi)和非靜態(tài)內(nèi)部類(lèi)的不同
上次有朋友問(wèn)我,java中的類(lèi)可以是static嗎?我給他肯定的回答是可以的,在java中我們可以有靜態(tài)實(shí)例變量、靜態(tài)方法、靜態(tài)塊。當(dāng)然類(lèi)也可以是靜態(tài)的,下面小編整理了些關(guān)于java中的static class相關(guān)資料分享在腳本之家平臺(tái)供大家參考2015-11-11
MyBatis?if?test?判斷字符串相等不生效問(wèn)題
這篇文章主要介紹了MyBatis?if?test?判斷字符串相等不生效問(wèn)題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
spring NamedContextFactory實(shí)現(xiàn)服務(wù)隔離的示例詳解
假設(shè)我們有個(gè)場(chǎng)景,我們需要實(shí)現(xiàn)服務(wù)之間的數(shù)據(jù)隔離、配置隔離、依賴的spring bean之間隔離,大家會(huì)有什么實(shí)現(xiàn)思路?今天給大家介紹spring-cloud-context里面有個(gè)NamedContextFactory可以達(dá)到上面的效果,需要的朋友可以參考下2024-05-05
如何自定義hibernate validation注解示例代碼
Hibernate Validator 是 Bean Validation 的參考實(shí)現(xiàn) . Hibernate Validator 提供了 JSR 303 規(guī)范中所有內(nèi)置 constraint 的實(shí)現(xiàn),下面這篇文章主要給大家介紹了關(guān)于如何自定義hibernate validation注解的相關(guān)資料,需要的朋友可以參考下2018-04-04
2024年最新IntelliJ?IDEA常用的小技巧總結(jié)(JAVA新手上路必備)
這篇文章主要介紹了2024年最新IntelliJ?IDEA常用小技巧的相關(guān)資料,文中包括IntelliJ?IDEA的概述、下載與安裝、快速創(chuàng)建并運(yùn)行Java工程、詳細(xì)設(shè)置、快速開(kāi)發(fā)、多模塊的IDEA工程以及最新變化,需要的朋友可以參考下2025-01-01
使用Spring?Boot?2.x構(gòu)建Web服務(wù)的詳細(xì)代碼
這篇文章主要介紹了使用Spring?Boot?2.x構(gòu)建Web服務(wù)的詳細(xì)代碼,主要基于JWT的身份認(rèn)證,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-03-03

