中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

electron如何創建新窗口模態框并實現主進程傳值給子進程

發布時間:2023-02-16 09:34:28 來源:億速云 閱讀:186 作者:iii 欄目:開發技術

這篇文章主要介紹“electron如何創建新窗口模態框并實現主進程傳值給子進程”,在日常操作中,相信很多人在electron如何創建新窗口模態框并實現主進程傳值給子進程問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”electron如何創建新窗口模態框并實現主進程傳值給子進程”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

創建新窗口

主進程

在主進程中配置窗口信息,具體內容可以看文檔,以下是我的配置;配置中的參數都是可以根據自己的需求變化的;

注意: 在開發環境時,root_path的地址必須是你的ip地址,而不是localhost一類的。

let modal;
// 接收彈出模態框
ipcMain.on('open-modal',(event,path,title = '提示')=>{
    console.log(path);
    let root_path;
    if (process.env.WEBPACK_DEV_SERVER_URL) {
      root_path = "http://192.168.110.95:8080/";
      // root_path = "http://192.168.124.4:8080/";
    } else {
      // root_path = "app://./index.html/";
      root_path = `file://${__dirname}/index.html/`;
    };
    const minWidth = 1176;
    const minHeight = 600;
    const width = 1200;
    const height = 700;
    modal = new BrowserWindow({
      parent: BrowserWindow.getFocusedWindow() || undefined,
      modal: true,
    //   frame: false,
      width: width,
      height: height,
      minWidth: minWidth,
      minHeight: minHeight,
    //   autoHideMenuBar: true, // 是否顯示菜單欄
      // backgroundColor:'#000', // 背景
      hasShadow: true, // 陰影
      resizable: true, // 窗口是否可以放大
      webPreferences: {
        webviewTag: true,
        contextIsolation: false,
        nodeIntegration: true,
        enableRemoteModule: true,
        webSecurity: false,
      },
    });
    modal.loadURL(root_path + "#/" + path);
});

創建一個路由

{
    path:'/modal',
    name:'modal',
    component:() => import('@/views/db-file/text.vue'),
},

試試能不能啟動

在渲染進程中發送命令,參數需要和路由path一致即可打開窗口

ipcRenderer.send('open-modal','modal')

electron如何創建新窗口模態框并實現主進程傳值給子進程

啟動新窗口

當我們做到這的時候,我們的新窗口基本上就算是可以打開了;打開了以后呢!我們需要向他傳遞一些值,這個時候為了方便區分;如下:

主程序

渲染進程:A渲染進程 主進程:A主進程

子程序(模態框) 渲染進程:B渲染進程 主進程:B主進程

傳值

B渲染進程渲染完成以后(vue中的話是nextTick),發送命令通知B主進程

ipcRenderer.send('modal-accomplish')

當在B主進程中接收到消息以后,發送給A渲染進程

 // 通知模態框渲染完成
ipcMain.on('modal-accomplish',(event,msg)=>{
    // 發送給渲染進程
    win.webContents.send("modal-accomplish-state");
})

A渲染進程中接收

onMounted(()=>{
     ipcRenderer.on('modal-accomplish-state',()=>{
        console.log('偉大時代');
     })
})

A渲染進程接收到值以后在發送給A主進程

onMounted(()=>{
     ipcRenderer.on('modal-accomplish-state',()=>{
        console.log('偉大時代');
        ipcRenderer.send('modal-accomplish-end','傳值');
     })
})

A主進程接收到值以后發送給B渲染進程

ipcMain.on('modal-accomplish-end',(event,token)=>{
    modal.webContents.send('modal-accomplish-child-end',token);
})

B渲染進程接收值

ipcRenderer.on('modal-accomplish-child-end',(event,msg)=>{
    console.log(msg); // 傳值
})

以上五/六步就可以將值獲取到了;你學會了嗎?

electron如何創建新窗口模態框并實現主進程傳值給子進程

注意 如果你在寫了代碼以后沒有接收到值的話,可以重啟一下;可能是你寫了主進程代碼更新不及時導致的

到此,關于“electron如何創建新窗口模態框并實現主進程傳值給子進程”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

城市| 新郑市| 吉林省| 新竹县| 北碚区| 广安市| 扬中市| 慈利县| 江口县| 雅安市| 青浦区| 温宿县| 容城县| 新闻| 阿鲁科尔沁旗| 彝良县| 宣汉县| 韶关市| 遂溪县| 旬邑县| 瑞金市| 尼木县| 蓬溪县| 桂平市| 牟定县| 五常市| 萝北县| 余江县| 长海县| 鄂托克前旗| 建瓯市| 简阳市| 商水县| 文水县| 马公市| 元氏县| 库车县| 上虞市| 安新县| 从化市| 临安市|