Egret动态加载JS执行TS接口

问题

Egret使用TypeScript开发过程中,希望可以不重新运行游戏就能执行某些TS的接口,方面随时修改指令进行模拟操作。

代码如下

Main.ts

var button = new eui.Button();
button.addEventListener(egret.TouchEvent.TOUCH_TAP, e=> {

    //一键运行指令
    let filePath = 'resource/run.js';
    if (RES.hasRes(filePath)) {
        RES.destroyRes(filePath, true);
    }

    RES.getResByUrl(filePath, (data, url) => {
        //演示调用js
        var obj: Object = eval(data);
        console.log("run_ts");
    }, this, RES.ResourceItem.TYPE_TEXT);

}, this);

TestClassA.ts

class TestClassA{
    public id:number = 0;
    public run():any{
        console.log("TestClassA.run", this.id);
    }
}

resource/run.js


Object({
    name: "哇哈哈",
    size: 1024,
    arr: ['a', 'bb', 'ccc'],
    say: function () {
        alert('我的名字叫:' + this.name);
    }
});

console.log("run js");

var a = new TestClassA();
a.id = 3;
a.run();
console.log(a);

注意

  • var obj: Object = eval(data);这句通过eval()将RES.ResourceItem获得的字符串转换为Object格式,但是微信小游戏不支持eval等方法动态调用js脚本,所以这里也就基本只能是开发期间调使用了。

  • if (RES.hasRes(filePath)) { RES.destroyRes(filePath, true); } 如果已经加载,先强行删掉。

参考

发布了41 篇原创文章 · 获赞 27 · 访问量 5万+
展开阅读全文

没有更多推荐了,返回首页

©️2019 CSDN 皮肤主题: 技术黑板 设计师: CSDN官方博客

分享到微信朋友圈

×

扫一扫,手机浏览