zoukankan      html  css  js  c++  java
  • CocosCreator循环引用Bug

    Level.ts

    import Enemy1Character from "./Enemy1Character";
    
    const{ccclass,property}=cc._decorator;
    
    @ccclass
    export default class Level extends cc.Component{
    	private _enemy1Prefab:cc.Node;
    	
    	protected onLoad():void{
    		let inst=cc.instantiate(this._enemy1Prefab);
    		let enemy1Character=inst.getComponent(Enemy1Character);
    	}
    	
    }
    

    BaseEnemyCharacter.ts

    import Level from "./Level";
    const{ccclass,property}=cc._decorator;
    
    @ccclass
    export default abstract class BaseEnemyCharacter extends cc.Component{
    	//@property({type:Level,visible:true}) //会导致转换后的js生成require("./Level")出现循环引用错误:load script [./Enemy1Character] failed : TypeError: Object prototype may only be an Object or null: undefined
    	protected _level:Level=null;
    	
    	protected test(val:Level):void{
    		this._level=this.node.parent.getComponent(Level); //会导致转换后的js生成require("./Level")出现循环引用错误:load script [./Enemy1Character] failed : TypeError: Object prototype may only be an Object or null: undefined
    	}
    	
    }
    

    Enemy1Character.ts

    import BaseEnemyCharacter from "./BaseEnemyCharacter";
    
    const{ccclass,property}=cc._decorator;
    
    @ccclass
    export default class Enemy1Character extends BaseEnemyCharacter{
        
    }
    

    Enemy1Character 不继承 BaseEnemyCharacter 时

    import Level from "./Level";
    
    const{ccclass,property}=cc._decorator;
    
    @ccclass
    export default class Enemy1Character extends cc.Component{
        @property({type:Level,visible:true}) //无法序列化显示(循环引用导致)
    	protected _level:Level=null;
    	
    	protected test(val:Level):void{
    		this._level=this.node.parent.getComponent(Level);//不继承可以通过编译
    	}
    }
    
  • 相关阅读:
    Codeforces 469D Two Sets
    Codeforces1249D2 Too Many Segments (hard version)
    Codeforces 796D Police Stations
    Codeforces 617E XOR and Favorite Number
    Codeforces 900D Unusual Sequences
    Python底层(一):列表
    最短路径笔记(一):Floyd
    竞赛题笔记(二):剪邮票
    图论题笔记(三):最少中转次数
    图论题笔记(二):城市地图
  • 原文地址:https://www.cnblogs.com/kingBook/p/13568077.html
Copyright © 2011-2022 走看看