iframe高度自適應(同域)

来源:http://www.cnblogs.com/yezi-dream/archive/2016/11/19/6067752.html
-Advertisement-
Play Games

今天解決了iframe高度自適應的問題,不過這隻是同域下的頁面嵌入,以下是代碼: function SetCwinHeight(){ var iframeid = document.getElementById("frame"); //frame是iframe的id if (document.get ...


       今天解決了iframe高度自適應的問題,不過這隻是同域下的頁面嵌入,以下是代碼:

function SetCwinHeight(){

          var iframeid = document.getElementById("frame");   //frame是iframe的id

          if (document.getElementById) {
            if (iframeid && !window.opera) {
               if (iframeid.contentDocument && iframeid.contentDocument.body.offsetHeight) {

                  iframeid.height = iframeid.contentDocument.body.offsetHeight;

               }else if (iframeid.Document && iframeid.Document.body.scrollHeight) {
                  
                  iframeid.height = iframeid.Document.body.scrollHeight;
                  
               }
            }
          } 
View Code

        iframe嵌入頁面時需要等待它完全載入完後才可以調用SetCwinHeight(),所以當修改iframe里的src值時,也需要等待修改的頁面完全嵌入後才可以調用SetCwinHeight(),這樣才有效果,那麼該怎麼放置SetCwinHeight(),我的解決方法是在iframe標簽里直接調用,即這樣寫 <iframe onload = "SetCwinHeight();"></iframe>,但是這樣的的話會污染了html環境,可是在js中一般只用一次window.onload = function(){},如果使用多次,後面的會覆蓋前面的,所以目前為止我能想到的解決方法就這一個,如果園友有更好的方法,請在評論區回覆,大家一起學習。

      當嵌入頁面修改時,iframe的高度也需要調整,當我在js文件直接這樣window.onload = function(){SetCwinHeight();}調用SetCwinHeight()時,只有刷新整個頁面才可以自適應高度,如果修改了iframe的src,iframe的高度還是前一個頁面的高度,當前頁面的高度無法自適應,一開始我以為是SetCwinHeight()寫錯了,但是當刷新整個頁面時,當前頁面又可以自適應了,在遇到這個問題之後,我的焦急毛病又出現了,總是沒有分析問題就急急忙忙的去查找有關於問題的解決方法,然後查出來的又文不對題,這樣反反覆復,不僅浪費了時間,還使得自己的心情特別煩躁,這樣的話工作就無法再進展下去。通過了這次的工作明白了自己的毛病,在休息了一會後,重新靜下心來整理思路,然後分析出現的問題,程式如何運行,點擊後程式運行的步驟又是什麼,分析完後再看看是哪一步出錯了,為什麼會出錯,像這次出現的錯誤,並不是程式寫錯了,而是程式運行的步驟出錯了,整個頁面刷新後就可以實現效果,但是修改src後又沒有效果了,而window.onload = function(){}這一步是等待頁面完全載入完後才執行,那麼應該就是載入的問題了,所以需要等待頁面載入完後才可以調用SetCwinHeight(),通過這樣的分析,最後終於將問題解決了,經過這次,我一定要改掉急躁這個毛病,應該在遇到問題後,先分析問題和思考解決方法,如果自己解決不了再去查找相應的解決方法。這樣就不會浪費時間和精力了。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 今天來回顧鞏固“韓信點兵” 首先:我們來看下其來源:在一千多年前的《孫子算經》中,有這樣一道算術題:“今有物不知其數,三三數之剩二,五五數之剩三,七七數之剩二,問物幾何?”按照今天的話來說:一個數除以3餘2,除以5餘3,除以7餘2,求這個數。這樣的問題,也有人稱為“韓信點兵”。 本人因是學java出 ...
  • 最近遇到一個問題, 執行腳本,腳本調用 一個命令,命令(deamon)是一個守護進程,為了調試,取消了守護進程模式。導致命令後邊的其他命令(echo "456")都無法執行。 deamon -d 是以守護進程模式啟動;deamon -x 是以非守護進程模式啟動(監控進程,死迴圈),stdout和st ...
  • spider RPC 特性介紹 spider RPC 性能測試 spider RPC 入門指南 spider RPC 配置文件參考 spider RPC需求來源 spider RPC的需求源於作者所在公司佈局證券金融服務行業某細分領域2B saas服務平臺的需要,以儘可能達到高可靠性、最小化單點影響 ...
  • 本部分將介紹使用spider RPC開發分散式應用的客戶端和服務端。 spider RPC中間件基於J2SE 8開發,因此需要確保伺服器上安裝了JDK 8及以上版本,不依賴於任何額外需要獨立安裝和配置的依賴程式。 註:spider RPC 1.0.1版本之前基於JDK 1.7開發,最後改為了使用JD ...
  • JS中的event 對象詳解 JS的event對象 Event屬性和方法:1. type:事件的類型,如onlick中的click;2. srcElement/target:事件源,就是發生事件的元素;3. button:聲明被按下的滑鼠鍵,整數,1代表左鍵,2代表右鍵,4代表中鍵,如果按下多個鍵, ...
  • 左右定寬,中間自適應,實現三列佈局 今天想說的是一個左右定寬,中間自適應,實現三列佈局,我也總結了以下,主要有以下幾種: 廢話不多說,直接上代碼: 第一種:float 第二種:BFC 第三種:雙飛翼佈局 第四種:flex ...
  • 好久沒有更新博客了,自從大學畢業整個人好像剛從監獄放出來似的,被外面的花花世界迷暈了,整天都是上班,再也沒有熬夜敲代碼,好久沒有對自己的學習進行總結了,趁著周末的時光總結一下這5個月來自己在前端路上裸奔的這段日子。原本大學畢業打算找個JAVA方向的或Android開發的工作,真是歲月弄人,最後來到了 ...
  • html部分 <html> <head> <meta charset="UTF-8"> <title></title> <link rel="stylesheet" type="text/css" href="css/reset.css"/> <link rel="stylesheet" href= ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...