亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

如何對異步結果對象執行對象操作?

如何對異步結果對象執行對象操作?

慕俠2389804 2023-04-01 15:08:58
我想知道如何從一個文件異步操作另一個文件中的 JS 對象。我對異步代碼原理并沒有太多經驗。情況:我有一個文件,app.js我在其中根據我的 HTML 動態創建“應用程序面板”。$("div.app-panel[data-panel]").each(function() {        // create panel objects for all html divs with class app-panel        var panel = {};        panel.div = $(this);        panel.name = $(this).attr("data-panel");        panel.isActive = ($(this).attr("data-active-panel") == "true" ? true : false);        panel.onActive = () => {            // default functionality to execute when activating an app panel            panel.isActive = true;            $(panel.div).attr("data-active-panel", true);        };        panel.onInactive = () => {            // default functionality to execute when deactivating an app panel            panel.isActive = false;            $(panel.div).attr("data-active-panel", false);        };        app.panels.push(panel);    });現在我希望能夠覆蓋我的另一個文件中的 onActive 方法,main.js但是我如何知道這段代碼是否已完成運行?我無法在 app.panels 上應用.filter()或應用.find(),它將返回未定義。我可以console.log(app.panels),它會將數組返回到我的控制臺......但我不能這樣做:panel = app.panels[0]這會給我未定義的。我試圖在 object 中創建一個函數app,它接受一個將使用 app.panels 作為參數的回調函數。然而,這給了我相同的結果......然后我嘗試用這種方式解決它:app.getPanels = async () => {    var promise = new Promise(function(resolve, reject) {        resolve(app.panels);    });    return promise;};var getPanels = async (callBack) => {    const appPanels = await Promise.all(app.getPanels());    console.log(appPanels);    callBack(appPanels);}這會引發錯誤“TypeError:對象不可迭代”。無論如何,我認為我的代碼很清楚我根本不熟悉承諾,我做錯了什么?
查看完整描述

1 回答

?
揚帆大魚

TA貢獻1799條經驗 獲得超9個贊

承諾者不是這里的解決方案。這一切都與協調從不同文件加載的代碼有關。

一個典型的策略是:

  • 除“main.js”之外的所有 .js 文件都包含類/函數,但不執行任何內容。

  • “main.js”通過創建類實例和調用函數/方法來協調一切。

  • 最后加載“main.js”。


查看完整回答
反對 回復 2023-04-01
  • 1 回答
  • 0 關注
  • 115 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號