国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

前端復盤: Iframe跨頁通信和前端實現文件下載

開發 前端
本文介紹的主要還是基于javascript,不涉及任何框架方面的問題(如果想研究vue,react,angular方面的技術問題,可以移步我的其他文章),所以讓我們用原生javascript來解決我們上面提到的問題吧。

由于筆者2年前維護了幾個比較老的項目是用jquery全家桶開發的,其中有些需求是需要跨頁面交互和父子頁面通信,故借此總結一下。另一塊是前端實現文件下載功能,雖然方法很多,為了不用重復造輪子,在此還是總結一波,畢竟多頁面下的應用場景還是很多的。

[[416758]]

文章摘要

  • 實現頁面之間通信的方法
  • 實現父子頁面和子頁面與子頁面之間通信的方法
  • 前端實現文件下載功能

由于本文介紹的主要還是基于javascript,不涉及任何框架方面的問題(如果想研究vue,react,angular方面的技術問題,可以移步我的其他文章),所以讓我們用原生javascript來解決我們上面提到的問題吧。

正文

1. 實現頁面之間通信的方法

雖然我們使用postmessage也可以實現頁面通信,但這里我們主要使用window.opener這個API,MDN對它的解釋如下:

  • The Window interface's opener property returns a reference to the window that opened the window using open().

意思就是window提供的opener接口返回一個打開當前頁面的頁面的一個引用,換句話說,如果A頁面打開B,那么B頁面的opener將返回A。通過這種方式,我們可以在A頁面定義全局的方法掛載在window上,那么B頁面就可以通過opener拿到A頁面的方法從而控制A頁面的行為。

目前主流的瀏覽器對這個API支持的都比較好,所以我們在大部分場景下可以考慮使用這個API。

為了更方便的理解他的應用場景,我們這里實現一個小功能:我們定義兩個頁面,A,B,當A頁面打開B頁面的時候,用B頁面改變A頁面的背景色。代碼如下:

  1. // A頁面 
  2. <body> 
  3.     <h1>父頁面A</h1> 
  4.     <a href="./b.html" target="_blank">打開b頁面</a> 
  5.     <script> 
  6.         function changeColor(color) { 
  7.             document.body.style.background = color 
  8.         } 
  9.     </script> 
  10. </body> 
  11.  
  12. // B頁面 
  13. <body> 
  14.     <h1>父頁面B</h1> 
  15.     <script> 
  16.         window.opener.changeColor('blue'
  17.     </script> 
  18. </body> 

首先我們在A頁面里定義一個全局方法,當點擊a標簽跳轉到新開的B頁面時,B頁面就是通過opener,調用A定義的changeColor,并傳入參數給A頁面,從而改變A頁面的背景色。效果如下:

2.實現父子頁面和子頁面與子頁面之間通信的方法

父子頁面這里主要針對iframe而言,即iframe和父頁面以及iframe頁面之間的通信。比如下圖:

我們想實現父頁面A操控子頁面A,B,并且讓子頁面和父頁面交互,這里我們主要使用 iframe的

  • contentWindow
  • parent.window 通過contentWindow,我們可以拿到iframe內部的方法和dom元素,進而可以操控iframe頁面

首先我們來看看父頁面操控子頁面的場景:父頁面A調用子頁面的方法傳遞一條數據,并并顯示在子頁面中:

  1. // 父頁面 
  2. window.onload = function() { 
  3.     let iframe1 = $id('a1').contentWindow; 
  4.     // 控制子頁面dom 
  5.     iframe1.document.body.style.background = "#000" 
  6.     iframe1.loadData({a: '1'}) 
  7.  
  8. function $id(id) { 
  9.     return document.getElementById(id) 
  10.  
  11. // 子頁面 
  12. function loadData(data) { 
  13.     document.body.append(`父頁面的數據數據${data.a}`) 

由上可知,父頁面通過contentWindow拿到iframe的window對象從而向其傳遞數據并調用其方法。

同樣,子頁面也可以操控父頁面:

  1. // 父頁面 
  2. function $id(id) { 
  3.     return document.getElementById(id) 
  4. // 子頁面 
  5. parent.window.$id('bridge').innerHTML = '子頁面操控父頁面dom' 

從代碼可以看到,我們使用parent.window拿到父頁面的window,然后調用父頁面提供的$id方法來操作父頁面dom。

接下來我們來解決子頁面和子頁面通信的問題,其實方法在上面已經提到了,我們可以把父頁面作為一個橋梁,子頁面A通過parent.window拿到父頁面的window,進而可以獲取另一個子頁面B的dom,這樣我們就可以讓子頁面A操作子頁面B了,反之也是一樣的。

  1. // 子頁面A 
  2. let iframeBWin = parent.window.$id('a2').contentWindow 
  3. iframeBWin.onload = function() { 
  4.     iframeBWin.document.getElementById('show').innerHTML = "來自子頁面A的問候" 

由上面代碼我們可以知道,我們通過parent.window來拿到子頁面B進而實現和子頁面B通信的目的,通過這種方式,我們可以實現很多有意思的東西。

注意,我們所討論的這些方法都是基于同域下的,其實實現跨域的方法也有很多,比如使用中間iframe實現橋接,通過設置window.domain將window提高到頂層等等,不過實現起來還是有些坑的,不過大部分場景都能滿足。

4.前端實現文件下載功能

對于下載文件來說,大部分場景都是后端來實現,前端只需要請求接口就好了,但是有時候這種方式反而會占用多余的資源和帶寬,如果需要下載的是用戶自己生成的內容或者內容已經返回到客戶端了,這時候能不經過服務端而直接生成下載任務,能節省不少的資源和時間開銷。

一般來說前端實現的思路就是通過動態創建a標簽,設置其download屬性,最后刪除a就好了,對于不是圖片的文件一般都可以下載,但是如果是圖片,有些瀏覽器會自動打開圖片,所以我們需要手動把它轉化為data:URLs或blob:URLs,基于這個原理,我們可以用fileReader,也可以用fetch-URL.createObjectURL,這里經過大量測試我采用后者:

  1. function download(url, filename) { 
  2.     return fetch(url).then(res => res.blob().then(blob => { 
  3.         let a = document.createElement('a'); 
  4.         let url = window.URL.createObjectURL(blob); 
  5.         a.href = url; 
  6.         a.download = filename; 
  7.         a.click(); 
  8.         window.URL.revokeObjectURL(url); 
  9.     })) 

該方法傳入一個文件的地址和希望使用的文件名,這樣,我們就能優雅的使用它來實現下載了。

本文轉載自微信公眾號「 趣談前端」,可以通過以下二維碼關注。轉載本文請聯系 趣談前端公眾號。

 

責任編輯:姜華 來源: 趣談前端
相關推薦

2023-02-27 07:40:00

系統重構前端

2023-10-20 08:04:34

系統重構實踐

2021-04-06 09:26:17

js前端通信極簡

2020-11-09 09:10:31

javascript設

2022-04-05 13:56:48

設計模式javascript

2016-11-01 21:51:03

phpjavascript

2023-01-05 07:39:28

2023-09-28 08:00:53

2022-09-07 21:31:19

微前端架構iframe

2016-08-27 22:02:11

前端跨端全棧

2022-12-26 00:00:01

Go框架前端

2017-08-20 12:49:59

瀏覽器跨域服務器

2017-08-08 08:45:44

前端文件斷點續傳

2022-03-28 10:25:27

前端文件編譯器

2021-01-05 05:26:10

postMessage聊天機器人跨域技術

2017-05-25 09:45:35

2024-05-22 09:54:19

2021-06-06 13:05:15

前端跨域CORS

2010-10-08 10:35:21

2020-04-02 20:07:17

前端vuenote.js
點贊
收藏

51CTO技術棧公眾號

国产精品国产三级国产普通话99 | 精品99久久久久久| 青青在线免费观看视频| 樱桃成人精品视频在线播放| 亚洲国产一区二区三区网站| 黑人巨大精品欧美一区二区一视频| 在线一区日本视频| 欧美xxx在线观看| 国内外成人免费激情在线视频| 91九色美女在线视频| 好吊成人免视频| 1024手机看片国产| 91麻豆国产自产在线观看| 一区二区三区欧美成人| 夜夜精品视频| 91成人免费视频| 久操成人av| 色综合色综合久久综合频道88| caoporn-草棚在线视频最| 欧美在线观看18| 国产呻吟对白刺激无套视频在线| 亚洲国产精品99久久久久久久久| 特级西西444| 美洲天堂一区二卡三卡四卡视频| 国产麻豆一区二区三区在线观看| 日韩精品电影| 国产精品久久久久aaaa九色| 美女主播精品视频一二三四| 九色精品免费永久在线| 欧美一级免费| 少妇高潮久久77777| 精品3atv在线视频| 亚洲欧美中文日韩在线v日本| 成年网站在线视频网站| 欧美一区二区三区不卡| 日韩美女网站| 91精品黄色片免费大全| av大片在线播放| 欧美日韩在线精品一区二区三区激情| 九色蝌蚪在线| 欧美日韩一区二区三区四区五区| 国产免费av高清在线| 欧美伊人久久久久久午夜久久久久| 色资源网在线观看| 欧美性xxxx极品hd欧美风情| 日本啊v在线| 在线免费不卡电影| 尤物视频在线免费观看| 欧美一区二区黄| 欧美激情成人动漫| 精品性高朝久久久久久久| 欧美momandson| 国产日韩欧美精品电影三级在线| 狠狠噜天天噜日日噜| 成人污视频在线观看| www国产黄色| 中文字幕中文字幕在线一区| 国产毛片毛片| 色综合av在线| 在线观看电影av| 亚洲人精选亚洲人成在线| 国产福利亚洲| 色屁屁一区二区| 97电影在线看视频| 欧美videossexotv100| 亚洲最大成人| 精品久久久久久中文字幕| 伊人狠狠色丁香综合尤物| 精品在线观看免费| 日韩在线综合网| 中文字幕亚洲一区二区va在线| 亚洲精选av在线| 色香蕉久久蜜桃| a国产在线视频| 亚洲欧美制服另类日韩| 校园春色影音先锋| 色婷婷国产精品综合在线观看| 在线免费观看黄色av| 亚洲国产精品高清久久久| 人人精品久久| 国产精品人成电影| 亚洲欧美视频| heyzo国产| 狠狠爱在线视频一区| 97人人爽人人澡人人精品| 蜜月aⅴ免费一区二区三区| 香蕉av一区二区| 一二三四中文字幕| 亚洲一区电影777| 亚洲精品动漫| 国产精品视频大全| 激情五月婷婷综合网| 成视频免费在线看| 日韩av影视在线| 日韩美女一区二区三区在线观看| 中文字幕一区二区中文字幕| 亚洲一区二区三区中文字幕在线 | 天堂社区日本电影超碰| 6080国产精品一区二区| 亚洲成人偷拍| 精品国产电影| 成人直播在线观看| 国产三区精品| 欧美激情一区二区三区蜜桃视频| 麻豆网站在线观看| 国内精品小视频| 三级欧美韩日大片在线看| www.日本一区| 亚洲精品电影在线| 在线看片不卡| 免费看国产黄色片| 日韩免费电影网站| 99精品小视频| 欧美日韩在线观看不卡| 精品精品国产高清一毛片一天堂| 欧美极品在线观看| 韩日视频在线观看| 欧美精品tushy高清| 精品国产一区二区三区久久久蜜臀 | 久蕉在线视频| 欧美极品xxxx| 黑人精品欧美一区二区蜜桃 | 久久九九有精品国产23| 99在线|亚洲一区二区| 成人黄动漫网站| 精品精品国产国产自在线| 日本视频一区二区| 国产对白叫床清晰在线播放| 78色国产精品| 久久久亚洲午夜电影| 中文在线资源| 日韩视频在线播放| 色88888久久久久久影院按摩| 精品久久ai| 午夜精品在线视频| 韩国精品在线观看| av网址在线播放| 亚洲xxxxx电影| 亚洲东热激情| 免费人成短视频在线观看网站 | 精品午夜一区二区三区| 亚洲免费在线看| 亚洲91网站| 男人操女人免费软件| 亚洲天堂男人天堂女人天堂| 台湾佬中文娱乐久久久| 国产伦精品一区二区三区高清版| 一个色在线综合| 中日韩免费毛片| 人人澡人人澡人人看欧美| 久久精品一区二区三区不卡| 激情亚洲小说| 亚洲 高清 成人 动漫| www.xxxx精品| 91女厕偷拍女厕偷拍高清| 高清亚洲高清| 黄色av网址在线播放| www.亚洲免费视频| 国产·精品毛片| 日韩欧美2区| 国产成人av在线| 国产精品成人一区二区艾草| 日本久久伊人| 热久久精品免费视频| 97碰在线观看| 亚洲女爱视频在线| 久久国产影院| 成人亚洲性情网站www在线观看| 国产欧美一区二区三区不卡高清| 欧美日韩情趣电影| 日本最新不卡在线| 丁香婷婷久久| 污污视频网站免费观看| 午夜精品久久17c| 亚洲成av人片一区二区梦乃| 欧美日韩一区二区国产| 亚洲丝袜精品| 欧美一区二区色| 一区二区国产盗摄色噜噜| 亚洲色图88| 国内外激情在线| 亚洲精品一区二区三区四区五区 | 高清在线一区二区| 99热在线免费| 91色p视频在线| 欧美一级视频精品观看| 国产激情偷乱视频一区二区三区| 亚洲精品一区三区三区在线观看| 另类小说色综合| 99porn视频在线| 亚洲人在线观看| 国产精品视频在线看| 亚洲老妇激情| 欧美另类老肥妇| 婷婷亚洲天堂| 免费一区二区三区| 日韩中文字幕国产精品| 欧美日韩激情视频| 国产精品1区2区3区在线观看| 天堂资源在线亚洲|