關(guān)于H5頁面在iphone手機(jī)safari瀏覽器window.open部分位置失效的問題

場景

最新在做一個(gè)H5功能程储,做附件下載瓤檐。
適用場景: 新窗口打開一個(gè)連接。

思路

根據(jù)附件id查詢出附件地址之后排截,利用 window.open(failUrl) 打開新窗口來下載附件嫌蚤。

現(xiàn)象

安卓手機(jī)所測試的常用瀏覽器基本上都沒問題,唯獨(dú)iphone手機(jī)自帶的safari瀏覽器不生效断傲。

解決辦法

對safari瀏覽器做特殊判斷脱吱。

  • 判斷safari瀏覽器的方法
/* 判斷是否是ios手機(jī)safari瀏覽器打開的 */
export const isIosSafari = () => {
  const ua = navigator.userAgent.toLowerCase();
  if (
    ua.indexOf('applewebkit') > -1 &&
    ua.indexOf('mobile') > -1 &&
    ua.indexOf('safari') > -1 &&
    !(ua.indexOf('android') > -1) &&
    !(ua.indexOf('linux') > -1) &&
    !(ua.indexOf('crios') > -1) && 
    !(ua.indexOf('chrome') > -1) && 
    !(ua.indexOf('browser') > -1) && 
    !(ua.indexOf('ios') > -1)
  ) {
    return true;
  }
  return false;
};

方案一 (推薦)

先打開一個(gè)空白窗口,然后再給窗口賦值地址认罩。

// 按鈕
<span onClick={() => this.handleDownload(item)}>下載文件</span>

/* 下載文件方法 */
handleDownload = (item) => {
  const { dispatch } = this.props;
  // 要先定義打開新窗口箱蝠,否則也會被攔截  不生效
  const winRef = window.open("about:blank","_blank");
  dispatch({
    type: 'common/downloadFile',
    payload: { fileId: item.fileId },
    callback: (data) => {
      // 后臺接口返回回來的地址  fileUrl1
      const fileUrl1 = data.fileUrl;
      winRef.location = fileUrl1;
    }
  });
};

如果const winRef = window.open("about:blank","_blank");放在異步回調(diào)函數(shù)中,恭喜你垦垂,不會生效宦搬,會被攔截喲~

方案二

當(dāng)時(shí)safari瀏覽器的時(shí)候,我們通過超鏈接點(diǎn)擊來跳轉(zhuǎn)劫拗。
創(chuàng)建的標(biāo)簽间校,執(zhí)行TagA.click()方法,在safari上也是不生效的页慷,有老鐵說safari下的A標(biāo)簽?zāi)J(rèn)是沒有綁定事件憔足,那么我們就可以手動(dòng)綁定一個(gè)事件胁附,然后觸發(fā)即可。

 /* 利用a標(biāo)簽下載附件 */
  downloadFileByTagA = (fileUrl) => {
    const TagA = document.createElement('a');
    TagA.href = fileUrl;
    // TagA.target = '__blank';
    document.body.appendChild(aSpan);
    TagA.className = 'oInput';
    TagA.style.display = 'none';

    // 兼容ios safari瀏覽器
    const e = document.createEvent('MouseEvent');     
    e.initEvent('click', false, false);     
    TagA.dispatchEvent(e);
  }

上訴??代碼我注釋掉了TagA.target = '__blank'; 應(yīng)為我加上去之后就不生效了滓彰,被safari安全機(jī)制攔截了控妻。

當(dāng)然這個(gè)可以通過 蘋果系統(tǒng)設(shè)置,偏好設(shè)置->安全性找蜜,去掉阻止彈窗的復(fù)選框 來解決~~~饼暑。

方案三

生成一個(gè)a標(biāo)簽,讓用戶自己去點(diǎn)擊洗做。這個(gè)無論如何都不會被攔截弓叛。
不過這樣也不好,會使用戶多一步操作诚纸。

方案四

蘋果系統(tǒng)設(shè)置撰筷,偏好設(shè)置->安全性,去掉阻止彈窗的復(fù)選框畦徘,如上所述毕籽。不太推薦,改變了用戶的主觀意愿

復(fù)盤分析

首先連接是無論如何不會被攔截的井辆,可以生成一個(gè)連接讓用戶去點(diǎn)擊关筒,這樣不太友好~~~

<a id="file-download-a"  target="__blank">
  我是一個(gè)連接呀
</a>

為什么會被攔擊呢?
當(dāng)然是window.open被廣告商濫用杯缺,嚴(yán)重影響用戶的使用蒸播。
當(dāng)然也不是所有的window.open都會被攔截,我們只需要找準(zhǔn)時(shí)機(jī)去觸發(fā)即可萍肆。
避免在回調(diào)函數(shù)中去執(zhí)行window.open方法袍榆。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市塘揣,隨后出現(xiàn)的幾起案子包雀,更是在濱河造成了極大的恐慌,老刑警劉巖亲铡,帶你破解...
    沈念sama閱讀 216,324評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件才写,死亡現(xiàn)場離奇詭異,居然都是意外死亡奖蔓,警方通過查閱死者的電腦和手機(jī)赞草,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,356評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來锭硼,“玉大人房资,你說我怎么就攤上這事√赐罚” “怎么了轰异?”我有些...
    開封第一講書人閱讀 162,328評論 0 353
  • 文/不壞的土叔 我叫張陵岖沛,是天一觀的道長。 經(jīng)常有香客問我搭独,道長婴削,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,147評論 1 292
  • 正文 為了忘掉前任牙肝,我火速辦了婚禮唉俗,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘配椭。我一直安慰自己虫溜,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,160評論 6 388
  • 文/花漫 我一把揭開白布股缸。 她就那樣靜靜地躺著衡楞,像睡著了一般。 火紅的嫁衣襯著肌膚如雪敦姻。 梳的紋絲不亂的頭發(fā)上瘾境,一...
    開封第一講書人閱讀 51,115評論 1 296
  • 那天,我揣著相機(jī)與錄音镰惦,去河邊找鬼迷守。 笑死,一個(gè)胖子當(dāng)著我的面吹牛旺入,可吹牛的內(nèi)容都是我干的兑凿。 我是一名探鬼主播,決...
    沈念sama閱讀 40,025評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼眨业,長吁一口氣:“原來是場噩夢啊……” “哼急膀!你這毒婦竟也來了沮协?” 一聲冷哼從身側(cè)響起龄捡,我...
    開封第一講書人閱讀 38,867評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎慷暂,沒想到半個(gè)月后聘殖,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,307評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡行瑞,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,528評論 2 332
  • 正文 我和宋清朗相戀三年奸腺,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片血久。...
    茶點(diǎn)故事閱讀 39,688評論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡突照,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出氧吐,到底是詐尸還是另有隱情讹蘑,我是刑警寧澤末盔,帶...
    沈念sama閱讀 35,409評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站座慰,受9級特大地震影響陨舱,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜版仔,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,001評論 3 325
  • 文/蒙蒙 一游盲、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧蛮粮,春花似錦益缎、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,657評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至又沾,卻和暖如春弊仪,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背杖刷。 一陣腳步聲響...
    開封第一講書人閱讀 32,811評論 1 268
  • 我被黑心中介騙來泰國打工励饵, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人滑燃。 一個(gè)月前我還...
    沈念sama閱讀 47,685評論 2 368
  • 正文 我出身青樓役听,卻偏偏與公主長得像,于是被迫代替她去往敵國和親表窘。 傳聞我的和親對象是個(gè)殘疾皇子典予,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,573評論 2 353

推薦閱讀更多精彩內(nèi)容