|
6 лет назад | |
---|---|---|
.. | ||
README.md | 6 лет назад | |
index.md | 6 лет назад |
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 finestrayes
per mostrare i controlli di zoom del browser Android, impostata su no
per nasconderli. Valore predefinito è yes
.yes
per utilizzare il pulsante Indietro hardware per spostarsi all'indietro tra il InAppBrowser
di storia. Se esiste una pagina precedente, si chiuderà il InAppBrowser
. Il valore predefinito è yes
, quindi è necessario impostare a no
, se si desidera che il pulsante indietro per chiudere semplicemente il InAppBrowser.
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.yes
per creare il controllo browser senza un bordo attorno ad esso. Siete pregati di notare che se location=no viene specificato, non ci sarà nessun controllo presentato all'utente per chiudere la finestra IAB.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
.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;
}
Simile al comportamento visivo finestra di Firefox OS IAB può essere sottoposto a override tramite inAppBrowserWrap
/ classi CSSinAppBrowserWrapFullscreen
Plugin viene implementato tramite iframe,
Cronologia di navigazione (pulsantiindietro
e Avanti
in LocationBar) non è implementato.
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)
eventi onloadstart
e loaderror
non sono stati licenziati.
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
InAppBrowser
finestra.
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
InAppBrowser
finestra
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"});
});
A causa di documenti MSDN lo script richiamato può restituire solo i valori di stringa, altrimenti il parametro, passato al callback sarà [null]
.
Inietta CSS nella
InAppBrowser
finestra.
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"});
});