当前位置: 首页 > 知识库问答 >
问题:

UnhandledPromiseRejectionWarning TypeError:无法读取未定义的属性“property”

宿丰
2023-03-14

我有下面的代码,它尝试读取一个txt,将它转换为一个数组,然后转换为json,将它保存在一个db中,但是当调用控制器时,我尝试运行SaveReferences函数,它向我发送了这个错误:UnhandledPromiseRejectionWarning:TypeError:无法读取未定义的属性'service'

另外,请发送以下信息:Promise{TypeError:无法读取ReferenceController.Saved处GettingInfo.SavereFerences处GettingInfo.ReadFile处未定义的属性“service”

  export interface Dataconf{
        service:number;
        name:string;
        ref:string
    }
    
    export class GettingInfo {
    
        constructor(private referenceService: ReferenceService) {
        }
    
        Readfile = () => {
    
            const file = path.resolve(__dirname, '../../../dist/entity/PRUEBA.txt')
            try {
                const data = fs.readFileSync(file, 'utf-8');
                const lines = data.split("\n")
                let values = []
                let bi = []
                lines.forEach(line => {
                    line.trim()
                    values = line.split("\|", 6).map(a => a.trim());
                    bi.push(values)
                    console.log(bi)
     })
                const convert = this.ConditionData(bi)
                console.log(convert)
                const save = this.SaveReferences(convert)
                console.log(save)
    
            } catch (err) {
                console.error(err), "something has happened to the file";
            }
        }
    
        ConditionData(values): Array<Dataconf> {
            let resultado = [];
            values.forEach(arreglo => {
                let ref = 'ref';
                for (let i = 3; i < arreglo.length; i++) {
                    if (arreglo[i].length > 0) {
                        let obj = {
                            service: parseInt(arreglo[0]),
                            name: arreglo[1]
                        }
                        obj[ref] = arreglo[i];
                        resultado.push(obj);
                    }
                }
            });
            console.log("resultado funcionConditionData", resultado)
            return resultado;
        }

async SaveReferences(data: Array<Dataconf>) {
        console.log("array", data)
        let i
        let orderField = 0;
        let helper = data[i].service;
        for (i = 0; i <= data.length; i++) {
            if (data[i].service != helper) {
                helper = data[i].service;
                orderField = 0
                try {
                    let res = await this.referenceService.createReference({
                        service: data[i].service,
                        name: `ref${i}`,
                        label: data[i].ref,
                        longitud: 0,
                        order: orderField
                    });
                } catch (e) {
                    console.error(e);
                }
            }
        }
        return data;
    }

共有1个答案

夏侯彬郁
2023-03-14

在SaveReferences中,第4行i未定义

let helper = data[i].service;

应该是

let helper;

在for循环内部分配helper时

 类似资料:
  • 为什么我得到这个错误不能读取未定义的触摸属性? 为什么它不能读取,但它可以读取 当我们使用

  • 问题内容: 我正在制作非常简单的react应用。但是,当我尝试通过onChange事件调用父(实际上是祖父母)组件的方法时,我一直在获取。 这是触发事件的组件/表单(因此,在绑定的父组件上调用方法…是的,因为我通过道具将其从父组件传递下来,所以在方法上使用了.bound(this)。) 这是我如何通过大多数父(祖父母)组件中的props传递该方法的方法。 这是我作为父项(方法所有者和方法调用程序之

  • 我正在测试发送电子邮件与流星js和nodemailer插件: 流星添加捷运:流星NodeEmailer 当页面加载时,我在导航器的控制台上看到错误:无法读取未定义的属性“创建运输”。 那么问题是什么呢? 代码如下: /////////////////////////////////////////// ///////////////

  • 我知道这方面还有很多类似的问题,但没有一个答案是有效的。在我的例子中,我有下面的代码,我正在尝试按分数降序排列记录数组。 最后一个函数是什么给我的问题.如果用户运行以下: var web=[{url:“www.southanpton.ac.uk”,内容:“南安普敦大学提供学位课程和世界一流的研究测试。”,{url:“www.xyz.ac.uk”,内容:“另一种大学考试”},{url:“www”,内

  • 我一直试图让firebase与react一起工作,但出现了此错误 未经处理的拒绝(TypeError):无法读取未定义的fetch D:/Peti/Programming/node/coursewebpage/src/components/coursePage.js:12 9 | const db=firebase.firestore()10 | const myAuthLevel=(fireba

  • 这是我的猫鼬模式: 这是使用Express的Node.js服务器。它具有路由,如果触发该路由,它将使用请求中传递的信息更新用户的购物车。正文: 我打印到终端userCart,正如您在代码中看到的,它返回给我的是: 当服务器执行时,它返回以下错误: 如果我已经在Mongoose中定义了的结构,为什么不定义它?

  • 请注意,我在react ProductScreen.js中呈现动态数据时有问题 注意,...数据在product.js中呈现得很好,但相同的数据在productscreen.js中不会呈现,因为productscreen.js链接是通过“id”呈现的。 谢谢app.js 导入“./homescreen.css”;从'../Components/Product'导入产品从'React'导入{useE

  • 我正在使用webpack,浏览器中出现以下错误: 编译时没有错误或警告。 validator.js的第15行如下所示: