去除ios移動端alert/confirm的網址(url)

來源:互聯網
上載者:User

標籤:child   splay   asc   ext   function   否則   details   chrome   text   

在移動端使用原生的alert/confirm總是會顯示網址(url),介面看起來很醜,搜尋半天也找不到解決辦法,在絕望的時候看到一篇文章寫的很好,在此感謝http://ifindever.com/archives/260.html,還希望能協助到大家。

最近在做小小創客 webapp,碰到一個問題,以前的版本,ios 和Android都可以通過重寫webview的alert等彈窗事件來隱藏掉彈窗的標題,但是ios7之後,api被禁用了,導致ios無法重寫隱藏標題:

1.通過js調用ios原生代碼來實現,即:window.alert = function(str){window.local.href = " xx://str/" +str}

2.js+html+css類比,但是為了實現alert等的阻塞執行,需要把後面的代碼放入回呼函數中執行

但是還是感覺這兩種方式實現不太優雅,都需要對現有代碼做比較大的改動,不死心,於是繼續google,終於發現個好辦法:

 

 

[javascript] view plain copy 
  1. <span style="font-size:10px;">     <script>  
  2.         window.alert = function(name){  
  3.              var iframe = document.createElement("IFRAME");  
  4.             iframe.style.display="none";  
  5.             iframe.setAttribute("src", ‘data:text/plain,‘);  
  6.             document.documentElement.appendChild(iframe);  
  7.             window.frames[0].window.alert(name);  
  8.             iframe.parentNode.removeChild(iframe);  
  9.         }  
  10.               
  11.         alert(‘xxx‘);  
  12.         </script></span>  


這個方法在於重寫了alert方法(confirm方法同理),不需要改動現有代碼,並且解決了彈窗標題出現網址的問題。不過需要注意的是,每次在架構中執行完一個alert/confirm後,需要將架構移除,下次再重新載入,否則在chrome中會引發跨域執行,從而被chrome攔截。

 

這裡還有confirm,重寫window.confirm之後,確認和取消點擊的事件都是執行取消,這時需要這樣寫:

confirm需要return子架構的結果:

 

[javascript] view plain copy 
    1. var result = window.frames[0].window.confirm(name);  
    2.     iframe.parentNode.removeChild(iframe);  
    3.     return result;  

 

 

地址:http://blog.csdn.net/hx_lei/article/details/51212336

去除ios移動端alert/confirm的網址(url)

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.