Questo plugin fornisce una vista di browser web che viene visualizzato quando si chiama di cordova.InAppBrowser.open().
var ref = cordova.InAppBrowser.open('http://apache.org', '_blank', 'location=yes');
Il cordova.InAppBrowser.open() funzione è definita per essere un rimpiazzo per la funzione window.open. Esistenti chiamate Window possono utilizzare la finestra di InAppBrowser, sostituendo window.open():
window.open = cordova.InAppBrowser.open;
La finestra di InAppBrowser si comporta come un browser web standard e non può accedere a Cordova APIs. Per questo motivo, è consigliabile la InAppBrowser se è necessario caricare il contenuto (non attendibile) di terze parti, invece di caricamento che in webview Cordova principale. Il InAppBrowser non è soggetto alla whitelist, né sta aprendo il link nel browser di sistema.
La InAppBrowser fornisce di default propri controlli GUI per l'utente (indietro, avanti, fatto).
Per indietro la compatibilità, questo plugin ganci anche window.open. Tuttavia, il plugin installato gancio di window.open può avere effetti collaterali indesiderati (soprattutto se questo plugin è incluso solo come dipendenza di un altro plugin). Il gancio di window. open verrà rimosso in una futura release principale. Fino a quando il gancio è rimosso dal plugin, apps può ripristinare manualmente il comportamento predefinito:
delete window.open // Reverts the call back to it's prototype's default
Sebbene window.open sia in ambito globale, InAppBrowser non è disponibile fino a dopo l'evento deviceready.
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
console.log("window.open works well");
}
cordova plugin add cordova-plugin-inappbrowser
Se si desidera che tutti i carichi di pagina nell'app di passare attraverso il InAppBrowser, si può semplicemente collegare window.open durante l'inizializzazione. Per esempio:
document.addEventListener("deviceready", onDeviceReady, false);
function onDeviceReady() {
window.open = cordova.InAppBrowser.open;
}
Apre un URL in una nuova istanza di InAppBrowser, l'istanza corrente del browser o il browser di sistema.
var ref = cordova.InAppBrowser.open(url, target, options);
ref: fare riferimento alla InAppBrowser finestra. (InAppBrowser)
url: l'URL da caricare (String). Chiamare encodeURI() su questo, se l'URL contiene caratteri Unicode.
target: la destinazione in cui caricare l'URL, un parametro facoltativo che il valore predefinito è _self . (String)
_self: Si apre in Cordova WebView se l'URL è nella lista bianca, altrimenti si apre nellaInAppBrowser._blank: Apre ilInAppBrowser._system: Si apre nel browser web del sistema.options: opzioni per il InAppBrowser . Opzionale, inadempiente a: location=yes . (String)
Il options stringa non deve contenere alcun spazio vuoto, e coppie nome/valore ogni funzionalità devono essere separate da una virgola. Caratteristica nomi sono tra maiuscole e minuscole. Tutte le piattaforme supportano il valore riportato di seguito:
yes o no per trasformare il InAppBrowser di barra di posizione on o off.
Solo su Android:
yes per creare il browser e caricare la pagina, ma non mostrarlo. L'evento loadstop viene generato quando il caricamento è completato. Omettere o impostata su no (impostazione predefinita) per avere il browser aperto e caricare normalmente.yes per avere il browser cache cookie ha lasciata prima dell'apertura della nuova finestrayes per avere la cache cookie di sessione cancellata prima dell'apertura della nuova finestra
solo iOS:
yes o no (default è no ). Attiva/disattiva la proprietà UIWebViewBounce.yes per creare il browser e caricare la pagina, ma non mostrarlo. L'evento loadstop viene generato quando il caricamento è completato. Omettere o impostata su no (impostazione predefinita) per avere il browser aperto e caricare normalmente.yes per avere il browser cache cookie ha lasciata prima dell'apertura della nuova finestrayes per avere la cache cookie di sessione cancellata prima dell'apertura della nuova finestrayes o no per attivare la barra degli strumenti o disattivare per il InAppBrowser (defaultyes)yes o no per impedire la viewport ridimensionamento tramite un tag meta (defaultno).yes o no per impedire HTML5 audio o video da AutoPlay (defaultno).yes o no per consentire la riproduzione dei supporti HTML5 in linea, visualizzare all'interno della finestra del browser, piuttosto che un'interfaccia specifica del dispositivo di riproduzione. L'HTML video elemento deve includere anche il webkit-playsinline (default di attributono)yes o no per aprire la tastiera quando elementi form ricevano lo stato attivo tramite di JavaScript focus() chiamata (defaultyes).yes o no aspettare fino a quando tutti i nuovi contenuti di vista viene ricevuto prima il rendering (defaultno).pagesheet , formsheet o fullscreen per impostare lo stile di presentazione (defaultfullscreen).fliphorizontal , crossdissolve o coververtical per impostare lo stile di transizione (defaultcoververtical).top o bottom (default è bottom ). Provoca la barra degli strumenti sia nella parte superiore o inferiore della finestra.
Solo per Windows:
yes per creare il browser e caricare la pagina, ma non mostrarlo. L'evento loadstop viene generato quando il caricamento è completato. Omettere o impostata su no (impostazione predefinita) per avere il browser aperto e caricare normalmente.var ref = cordova.InAppBrowser.open('http://apache.org', '_blank', 'location=yes');
var ref2 = cordova.InAppBrowser.open(encodeURI('http://ja.m.wikipedia.org/wiki/ハングル'), '_blank', 'location=yes');
Come plugin non imporre alcun disegno c'è bisogno di aggiungere alcune regole CSS se aperto con target='_blank'. Le regole potrebbero apparire come questi
css
.inAppBrowserWrap {
background-color: rgba(0,0,0,0.75);
color: rgba(235,235,235,1.0);
}
.inAppBrowserWrap menu {
overflow: auto;
list-style-type: none;
padding-left: 0;
}
.inAppBrowserWrap menu li {
font-size: 25px;
height: 25px;
float: left;
margin: 0 10px;
padding: 3px 10px;
text-decoration: none;
color: #ccc;
display: block;
background: rgba(30,30,30,0.50);
}
.inAppBrowserWrap menu li.disabled {
color: #777;
}
L'oggetto restituito da una chiamata a di cordova.InAppBrowser.open.
Aggiunge un listener per un evento dal
InAppBrowser.
ref.addEventListener(eventname, callback);
Rif: fare riferimento alla InAppBrowser finestra (InAppBrowser)
EventName: l'evento per l'ascolto (String)
InAppBrowser comincia a caricare un URL.InAppBrowser termina il caricamento di un URL.InAppBrowser rileva un errore durante il caricamento di un URL.InAppBrowser finestra è chiusa.richiamata: la funzione che viene eseguito quando viene generato l'evento. La funzione viene passata un InAppBrowserEvent oggetto come parametro.
tipo: il eventname, o loadstart , loadstop , loaderror , o exit . (String)
URL: l'URL che è stato caricato. (String)
codice: il codice di errore, solo nel caso di loaderror . (Numero)
messaggio: il messaggio di errore, solo nel caso di loaderror . (String)
var ref = cordova.InAppBrowser.open('http://apache.org', '_blank', 'location=yes');
ref.addEventListener('loadstart', function(event) { alert(event.url); });
Rimuove un listener per un evento dal
InAppBrowser.
ref.removeEventListener(eventname, callback);
Rif: fare riferimento alla InAppBrowser finestra. (InAppBrowser)
EventName: interrompere l'attesa per l'evento. (String)
InAppBrowser comincia a caricare un URL.InAppBrowser termina il caricamento di un URL.InAppBrowser rileva un errore di caricamento di un URL.InAppBrowser finestra è chiusa.richiamata: la funzione da eseguire quando viene generato l'evento. La funzione viene passata un InAppBrowserEvent oggetto.
var ref = cordova.InAppBrowser.open('http://apache.org', '_blank', 'location=yes');
var myCallback = function(event) { alert(event.url); }
ref.addEventListener('loadstart', myCallback);
ref.removeEventListener('loadstart', myCallback);
Chiude la
InAppBrowserfinestra.
ref.close();
InAppBrowser finestra (InAppBrowser)var ref = cordova.InAppBrowser.open('http://apache.org', '_blank', 'location=yes');
ref.close();
Visualizza una finestra di InAppBrowser che è stato aperto nascosta. Questa chiamata non ha effetto se la InAppBrowser era già visibile.
ref.show();
InAppBrowser)var ref = cordova.InAppBrowser.open('http://apache.org', '_blank', 'hidden=yes');
// some time later...
ref.show();
Inserisce il codice JavaScript nella
InAppBrowserfinestra
ref.executeScript(details, callback);
Rif: fare riferimento alla InAppBrowser finestra. (InAppBrowser)
injectDetails: dettagli dello script da eseguire, specificando un file o code chiave. (Oggetto)
richiamata: la funzione che viene eseguito dopo che il codice JavaScript viene iniettato.
code , il callback viene eseguita con un singolo parametro, che è il valore restituito del copione, avvolto in un Array . Per gli script multi-linea, questo è il valore restituito dell'ultima istruzione, o l'ultima espressione valutata.var ref = cordova.InAppBrowser.open('http://apache.org', '_blank', 'location=yes');
ref.addEventListener('loadstop', function() {
ref.executeScript({file: "myscript.js"});
});
Inietta CSS nella
InAppBrowserfinestra.
ref.insertCSS(details, callback);
Rif: fare riferimento alla InAppBrowser finestra (InAppBrowser)
injectDetails: dettagli dello script da eseguire, specificando un file o code chiave. (Oggetto)
richiamata: la funzione che viene eseguito dopo che il CSS viene iniettato.
var ref = cordova.InAppBrowser.open('http://apache.org', '_blank', 'location=yes');
ref.addEventListener('loadstop', function() {
ref.insertCSS({file: "mystyles.css"});
});