欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

【JavaScript】關于父窗口獲取跨域iframe子窗口中的元素

admin
2023年5月25日 14:52 本文熱度 640

這幾天在項目中遇到一個難點,就是需要異步加載一個pdf插件,同時又需要獲取這個插件中的點擊事件來生成用戶的下載記錄。剛開始也是想了很多方法,網上搜的:

格式1:$("#iframe的ID").contents().find("#iframe中的控件ID").click();
 
格式2:$("#iframe中的控件ID",document.frames("frame的name").document).click();

發現在跨域環境下并沒有用,看到有些人說這個無解,需要走后臺,我當時也是涼涼感覺。后來自己也是想了辦法,在插件頁面中給按鈕綁定事件,然后通過給插件帶參數時在url中加上幾個參數,一起提交。剛開始我也是做得風生水起,結果,后來發現要帶的參數太多了,而插件又是以iframe引入, 很是麻煩。結果無意中找到了html5有一個頁面通訊方法,一實驗果然有效?,F在做個記錄,以備不時之需。 

子頁面iframe中的代碼:

<script type="text/javascript">
        $("#secondaryDownload").click(function(){
            var fun="click";
            window.parent.postMessage(fun,'*');
        })
</script>

那個fun參數沒有實際意義,我只是為了加個小校驗,當然也可以傳入自己想傳的參數。

父頁面代碼:

window.addEventListener('message',function(e){
        console.log(e);
        var fun=e.data;
        if(fun=="click"){
                alert("aaa");
                };
            }
        },false);

這樣,在我們點擊子頁面的下載按鈕時,會給父頁面發一個消息,而父頁面的事件監聽器會接收到從而觸發相應的事件。

當然,我也是剛了解這個postMessage()方法,里面的參數細節請參考相關文檔。


該文章在 2023/5/25 14:54:54 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved