成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JS夸頁面通信極簡方案&純前端實現文件下載

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

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

[[391326]]

文章摘要

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

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

正文

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

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

  1. 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的問候" 
  5. }復制代碼 

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


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

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

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

一般來說前端實現的思路就是通過動態創建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.     })) 

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

 

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

2021-08-11 08:23:07

前端技術 iframe

2024-02-01 09:41:01

AI算法

2023-06-13 18:24:26

TypeScriptJSDoc開發

2021-10-28 16:04:04

以太全光網銳捷網絡

2025-05-22 06:39:08

2017-09-18 16:13:59

前端圖像處理人臉識別

2016-10-18 11:28:21

2010-05-14 10:08:48

統一通信系統

2016-12-06 10:07:01

銳捷網絡

2014-05-04 13:47:39

銳捷網絡極簡網絡

2016-12-28 10:00:03

銳捷網絡

2013-10-14 10:41:41

分配器buddy syste

2023-10-26 07:06:19

前端文件系統

2023-09-12 14:44:12

github前端

2022-07-11 14:23:09

加密貨幣比特幣以太坊

2023-01-03 08:32:38

2021-07-01 15:25:32

前端水印代碼

2022-05-01 21:49:06

Python

2011-12-16 16:19:58

移動Web

2021-11-14 23:05:28

GoCast語言
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成人免费观看男女羞羞视频 | 国产在线1区 | 少妇淫片aaaaa毛片叫床爽 | 狠狠的日| 欧美性受xxx | 成人a网 | 91性高湖久久久久久久久_久久99 | 国产日韩欧美一区二区 | 久久久久久久久国产成人免费 | 欧美久久精品 | 婷婷丁香激情 | 日本精品视频在线 | 欧美区日韩区 | 国产精品免费一区二区三区 | 久久亚洲欧美日韩精品专区 | 国产色婷婷精品综合在线手机播放 | 日韩精品在线一区 | 国产在线1 | 91av在线电影 | 亚洲欧美精品国产一级在线 | 在线观看视频91 | 久久手机在线视频 | 91视频一区二区三区 | 成人在线电影网站 | 欧美成人免费在线 | 精品精品 | 毛片免费观看视频 | 九九热在线免费视频 | 久久久久国产一区二区三区四区 | 鲁一鲁资源影视 | 黄网站免费入口 | 欧美精品网站 | 91中文字幕在线观看 | 婷婷色在线 | 欧洲视频一区二区 | 亚洲成人中文字幕 | 日韩免费视频 | 久久久新视频 | 久久久久一区二区三区 | 欧美老妇交乱视频 | 亚洲成av人影片在线观看 |