Este documento apresenta as propriedades e métodos públicos para o React Native WebView.
source
automaticallyAdjustContentInsets
automaticallyAdjustsScrollIndicatorInsets
injectedJavaScript
injectedJavaScriptBeforeContentLoaded
injectedJavaScriptForMainFrameOnly
injectedJavaScriptBeforeContentLoadedForMainFrameOnly
mediaPlaybackRequiresUserAction
nativeConfig
onError
onRenderProcessGone
onLoad
onLoadEnd
onLoadStart
onLoadProgress
onHttpError
onMessage
onNavigationStateChange
onContentProcessDidTerminate
onScroll
originWhitelist
renderError
renderLoading
scalesPageToFit
onShouldStartLoadWithRequest
startInLoadingState
style
containerStyle
decelerationRate
domStorageEnabled
javaScriptEnabled
javaScriptCanOpenWindowsAutomatically
androidLayerType
mixedContentMode
thirdPartyCookiesEnabled
userAgent
applicationNameForUserAgent
allowsFullscreenVideo
allowsInlineMediaPlayback
allowsAirPlayForMediaPlayback
bounces
overScrollMode
contentInset
contentInsetAdjustmentBehavior
contentMode
dataDetectorTypes
scrollEnabled
nestedScrollEnabled
setBuiltInZoomControls
setDisplayZoomControls
directionalLockEnabled
geolocationEnabled
allowFileAccessFromFileURLs
allowUniversalAccessFromFileURLs
allowingReadAccessToURL
keyboardDisplayRequiresUserAction
hideKeyboardAccessoryView
allowsBackForwardNavigationGestures
incognito
allowFileAccess
saveFormDataDisabled
cacheEnabled
cacheMode
pagingEnabled
allowsLinkPreview
sharedCookiesEnabled
textZoom
pullToRefreshEnabled
ignoreSilentHardwareSwitch
onFileDownload
limitsNavigationsToAppBoundDomains
textInteractionEnabled
mediaCapturePermissionGrantType
autoManageStatusBarEnabled
setSupportMultipleWindows
basicAuthCredential
enableApplePay
forceDarkOn
minimumFontSize
goForward
goBack
reload
stopLoading
injectJavaScript
clearFormData
clearCache
clearHistory
requestFocus
postMessage
source
⬆
Carrega HTML estático ou um URI (com cabeçalhos opcionais) na WebView. Observe que o HTML estático exigirá a configuração de originWhitelist
como ["*"]
.
O objeto passado para source
pode ter uma das seguintes formas:
Carregar uri
uri
(string) - O URI a ser carregada naWebView
. Pode ser um arquivo local ou remoto e pode ser alterado com o estado React ou props para navegar para uma nova página.method
(string) - O método HTTP é o usado. O padrão é GET se não for especificado. No Android e no Windows, os únicos métodos suportados são GET e POST.headers
(object) - Cabeçalhos HTTP adicionais para enviar com a solicitação. No Android, isso só pode ser usado com solicitações GET. Consulte o Guia para obter mais informações sobre a configuração de cabeçalhos personalizados.body
(string) - O corpo HTTP a ser enviado com a solicitação. Esta deve ser uma string UTF-8 válida e será enviada exatamente conforme especificado, sem codificação adicional (por exemplo, escape de URL ou base64) aplicada. No Android e no Windows, isso só pode ser usado com solicitações POST.
HTML Estático
Observe que usar HTML estático requer a propriedade WebView originWhiteList ['*']
. Para alguns conteúdos, como incorporações de vídeo (por exemplo, postagens no Twitter ou Facebook com vídeo), o baseUrl precisa ser definido para que a reprodução do vídeo funcione
html
(string) - Uma página HTML estática para exibir na WebView.baseUrl
(string) - A URL base a ser usada para quaisquer links relativos no HTML. Isso também é usado para o cabeçalho de origem com solicitações CORS feitas a partir da WebView. Ver Documentação do Android WebView
Tipo | Requerido |
---|---|
object | Falso |
automaticallyAdjustContentInsets
⬆
Controla se a inserção de conteúdo deve ser ajustada para exibições da Web que são colocadas atrás de uma barra de navegação, barra de guias ou barra de ferramentas. O valor padrão é true
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Falso | iOS |
automaticallyAdjustsScrollIndicatorInsets
⬆
Controla se a inserção do indicador de rolagem deve ser ajustada para exibições da Web que são colocadas atrás de uma barra de navegação, barra de guias ou barra de ferramentas. O valor padrão falso
. (iOS 13+)
Tipo | Requerido | Plataforma |
---|---|---|
bool | Falso | iOS(13+) |
injectedJavaScript
⬆
Defina isso para fornecer ao JavaScript que será injetado na página da Web depois que o documento terminar de carregar, mas antes que outros sub-recursos terminem de carregar.
Certifique-se de que a string seja avaliada como um tipo válido (true
) e não lance uma exceção.
No iOS, consulte WKUserScriptInjectionTimeAtDocumentEnd
. Tenha certeza
para definir um manipulador onMessage
, mesmo que seja um operação vazia, ou o código não será executado.
Tipo | Requerido | Plataforma |
---|---|---|
string | Falso | iOS, Android, macOS, Windows |
Para saber mais, leia o guia Comunicação entre JS e Native.
Observação: o Windows não tem suporte nativo para alertas , como tal, quaisquer scripts para mostrar um alerta não funcionarão.
Exemplo:
Post envia um objeto JSON de window.location
para ser tratado por onMessage
const INJECTED_JAVASCRIPT = `(function() {
window.ReactNativeWebView.postMessage(JSON.stringify(window.location));
})();`;
<WebView
source={{ uri: 'https://reactnative.dev' }}
injectedJavaScript={INJECTED_JAVASCRIPT}
onMessage={this.onMessage}
/>;
injectedJavaScriptBeforeContentLoaded
⬆
Defina isso para fornecer JavaScript que será injetado na página da Web depois que o elemento do documento for criado, mas antes que outros sub-recursos terminem de carregar.
Certifique-se de que a string seja avaliada como um tipo válido (true
funciona) e não lance uma exceção.
No iOS, consulte WKUserScriptInjectionTimeAtDocumentStart
Tipo | Requerido | Plataforma |
---|---|---|
string | Não | iOS, macOS |
Para saber mais, leia o guia Comunicação entre JS e Native.
Exemplo:
Post message um objeto JSON de window.location
para ser tratado por onMessage
. window.ReactNativeWebView.postMessage
estará disponível neste momento.
const INJECTED_JAVASCRIPT = `(function() {
window.ReactNativeWebView.postMessage(JSON.stringify(window.location));
})();`;
<WebView
source={{ uri: 'https://reactnative.dev' }}
injectedJavaScriptBeforeContentLoaded={INJECTED_JAVASCRIPT}
onMessage={this.onMessage}
/>;
injectedJavaScriptForMainFrameOnly
⬆
Se true
(padrão; obrigatório para Android), carrega o injectedJavaScript
apenas no quadro principal.
Se false
, (suportado apenas em iOS e macOS), carrega-o em todos os quadros (por exemplo, iframes).
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS e macOS (true somente suportado no Android) |
injectedJavaScriptBeforeContentLoadedForMainFrameOnly
⬆
Se true
(padrão; obrigatório para Android), carrega o injectedJavaScriptBeforeContentLoaded
apenas no quadro principal.
Se false
, (suportado apenas em iOS e macOS), carrega-o em todos os quadros (por exemplo, iframes).
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS e macOS (true somente suportado para Android) |
mediaPlaybackRequiresUserAction
⬆
Valor boleano que determina se o áudio e o vídeo HTML5 exigem que o usuário toque neles antes de iniciar a reprodução. O valor padrão é true
. (API Android versão mínima 17).
NOTA: o valor padrão true
pode fazer com que alguns vídeos travem o carregamento no iOS. Defini-lo como false
pode corrigir esse problema.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS, Android, macOS |
nativeConfig
⬆
Substitua o componente nativo usado para renderizar a WebView. Habilita uma WebView nativo personalizado que usa o mesmo JavaScript que a WebView original.
O prop nativeConfig
espera um objeto com as seguintes chaves:
component
(any)props
(object)viewManager
(object)
Tipo | Requerido | Plataforma |
---|---|---|
object | Não | iOS, Android, macOS |
onError
⬆
Função que é invocada quando o carregamento da WebView
falha.
Tipo | Requerido |
---|---|
function | Não |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
onError={(syntheticEvent) => {
const { nativeEvent } = syntheticEvent;
console.warn('WebView error: ', nativeEvent);
}}
/>
A função passada para onError
é chamada com um SyntheticEvent envolvendo um nativeEvent com estas propriedades:
canGoBack
canGoForward
code
description
didFailProvisionalNavigation
domain
loading
target
title
url
Observação O domínio é usado apenas no iOS
O syntheticEvent
pode ser interrompido fazendo sua ação padrão chamando syntheticEvent.preventDefault()
.
onLoad
⬆
Função que é invocada quando a WebView
termina de carregar.
Tipo | Requerido |
---|---|
function | Não |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
onLoad={(syntheticEvent) => {
const { nativeEvent } = syntheticEvent;
this.url = nativeEvent.url;
}}
/>
A função passada para onLoad
é chamada com um SyntheticEvent envolvendo um nativeEvent com estas propriedades:
canGoBack
canGoForward
loading
target
title
url
onLoadEnd
⬆
Função que é invocada quando o carregamento da WebView
é bem-sucedido ou falha.
Tipo | Requerido |
---|---|
function | Não |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
onLoadEnd={(syntheticEvent) => {
// componente de atualização para estar ciente do status de carregamento
const { nativeEvent } = syntheticEvent;
this.isLoading = nativeEvent.loading;
}}
/>
A função passada para onLoadEnd
é chamada com um SyntheticEvent envolvendo um nativeEvent com estas propriedades:
canGoBack
canGoForward
loading
target
title
url
onLoadStart
⬆
Função que é invocada quando a WebView
começa a carregar.
Tipo | Requerido |
---|---|
function | Não |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev/=' }}
onLoadStart={(syntheticEvent) => {
// atualiza o componente para estar ciente do status de carregamento
const { nativeEvent } = syntheticEvent;
this.isLoading = nativeEvent.loading;
}}
/>
A função passada para onLoadStart
é chamada com um SyntheticEvent envolvendo um nativeEvent com estas propriedades:
canGoBack
canGoForward
loading
target
title
url
onLoadProgress
⬆
Função que é invocada quando a WebView
está carregando.
Tipo | Requerido | Plataforma |
---|---|---|
function | Não | iOS, Android, macOS |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
onLoadProgress={({ nativeEvent }) => {
this.loadingProgress = nativeEvent.progress;
}}
/>
A função passada para onLoadProgress
é chamada com um SyntheticEvent envolvendo um nativeEvent com estas propriedades:
canGoBack
canGoForward
loading
progress
target
title
url
onHttpError
⬆
Função que é invocada quando a WebView
recebe um erro http.
Observação API Android nível mínimo 23.
Tipo | Requerido |
---|---|
function | Não |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
onHttpError={(syntheticEvent) => {
const { nativeEvent } = syntheticEvent;
console.warn(
'Código de status de erro recebido da WebView: ',
nativeEvent.statusCode,
);
}}
/>
A função passada para onHttpError
é chamada com um SyntheticEvent envolvendo um nativeEvent com estas propriedades:
canGoBack
canGoForward
description
loading
statusCode
target
title
url
Observação A descrição é usada apenas no Android
onRenderProcessGone
⬆
Função que é invocada quando o processo da WebView
falha ou é morto pelo sistema operacional no Android.
Observação API do Android nível mínimo 26. Somente Android
Tipo | Requerido |
---|---|
function | Não |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
onRenderProcessGone={syntheticEvent => {
const { nativeEvent } = syntheticEvent;
console.warn(
'WebView falhou: ',
nativeEvent.didCrash,
);
}}
/>
A função passada para onRenderProcessGone
é chamada com um SyntheticEvent envolvendo um nativeEvent com estas propriedades:
didCrash
onMessage
⬆
Função que é invocada quando a webview chama window.ReactNativeWebView.postMessage
. Definir essa propriedade injetará esse global em sua visualização da web.
window.ReactNativeWebView.postMessage
aceita um argumento, data
, que estará disponível no objeto de evento, event.nativeEvent.data
. data
deve ser uma string.
Tipo | Requerido |
---|---|
function | Não |
Para saber mais, leia o guia Comunicação entre JS e Native.
onNavigationStateChange
⬆
Função que é invocada quando o carregamento da WebView
começa ou termina.
Tipo | Requerido |
---|---|
function | Não |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
onNavigationStateChange={(navState) => {
// Acompanhe a navegação de volta no componente
this.canGoBack = navState.canGoBack;
}}
/>
O objeto navState
inclui estas propriedades:
canGoBack
canGoForward
loading
navigationType (iOS only)
target
title
url
onContentProcessDidTerminate
⬆
Função que é invocada quando o processo de conteúdo da WebView
é encerrado.
Tipo | Requerido | Plataforma |
---|---|---|
function | Não | iOS e macOS WKWebView |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
onContentProcessDidTerminate={(syntheticEvent) => {
const { nativeEvent } = syntheticEvent;
console.warn('Processo de conteúdo encerrado, recarregando', nativeEvent);
this.refs.webview.reload();
}}
/>
A função passada para onContentProcessDidTerminate é chamada com um SyntheticEvent envolvendo um nativeEvent com estas propriedades:
canGoBack
canGoForward
loading
target
title
url
onScroll
⬆
Função que é invocada quando o evento scroll é acionado na WebView
.
Tipo | Requerido | Plataforma |
---|---|---|
function | Não | iOS, macOS, Android, Windows |
Exemplo:
<Webview
source={{ uri: 'https://reactnative.dev' }}
onScroll={syntheticEvent => {
const { contentOffset } = syntheticEvent.nativeEvent
console.table(contentOffset)
}}
/>
A função passada para onScroll
é chamada com um SyntheticEvent envolvendo um nativeEvent com estas propriedades:
contentInset
contentOffset
contentSize
layoutMeasurement
velocity
zoomScale
originWhitelist
⬆
Lista de strings de origem para permitir a navegação. As strings permitem curingas e são correspondidas com __somente a origem (não o URL completo). Se o usuário tocar para navegar para uma nova página, mas a nova página não estiver nesta lista de permissões, a URL será tratada pelo sistema operacional. As origens padrão da lista de permissões são "http://" e "https://".
Tipo | Requerido | Plataforma |
---|---|---|
array of strings | Não | iOS, Android, macOS |
Exemplo:
// permitir apenas URIs que comecem com https:// ou git://
<WebView
source={{ uri: 'https://reactnative.dev' }}
originWhitelist={['https://*', 'git://*']}
/>
renderError
⬆
Função que retorna uma view para mostrar se há um erro.
Tipo | Requerido | Plataforma |
---|---|---|
function | Não | iOS, Android, macOS |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
renderError={(errorName) => <Error name={errorName} />}
/>
A função passada para renderError
será chamada com o nome do erro.
renderLoading
⬆
Função que retorna um indicador de carregamento. A prop startInLoadingState deve ser definida como true para usar essa prop.
Tipo | Requerido | Plataforma |
---|---|---|
function | Não | iOS, Android, macOS |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
startInLoadingState={true}
renderLoading={() => <Loading />}
/>
scalesPageToFit
⬆
Booleano que controla se o conteúdo da Web é dimensionado para caber na exibição e permite que o usuário altere a escala. O valor padrão é true
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | Android |
onShouldStartLoadWithRequest
⬆
Função que permite o tratamento personalizado de qualquer solicitação de visualização da web. Retorne true
da função para continuar carregando a solicitação e false
para interromper o carregamento.
No Android, não é chamado no primeiro carregamento.
Tipo | Requerido | Plataforma |
---|---|---|
function | Não | iOS, Android, macOS |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
onShouldStartLoadWithRequest={(request) => {
// Permitir apenas navegar neste site
return request.url.startsWith('https://reactnative.dev');
}}
/>
O objeto request
inclui estas propriedades:
title
url
loading
target
canGoBack
canGoForward
lockIdentifier
mainDocumentURL (iOS only)
navigationType (iOS only)
isTopFrame (iOS only)
startInLoadingState
⬆
Valor booleano que força a WebView
mostrar a visualização de carregamento no primeiro carregamento. Esta prop deve ser definida como true
para que a prop renderLoading
funcione.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS, Android, macOS |
style
⬆
Um objeto de estilo que permite personalizar o estilo da WebView
. Observe que existem estilos padrão (exemplo: você precisa adicionar flex: 0
ao estilo se quiser usar a propriedade height
).
Tipo | Requerido |
---|---|
style | Não |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
style={{ marginTop: 20 }}
/>
containerStyle
⬆
Um objeto de estilo que permite personalizar o estilo do contêiner da WebView
. Observe que existem estilos padrão (exemplo: você precisa adicionar flex: 0
ao estilo se quiser usar a propriedade height
).
Tipo | Requerido |
---|---|
style | Não |
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
containerStyle={{ marginTop: 20 }}
/>
decelerationRate
⬆
Um número de ponto flutuante que determina a rapidez com que a visualização de rolagem desacelera depois que o usuário levanta o dedo. Você também pode usar os atalhos de string "normal"
e "fast"
que correspondem às configurações subjacentes do iOS para UIScrollViewDecelerationRateNormal
e UIScrollViewDecelerationRateFast
respectivamente:
- normal: 0,998
- rápido: 0,99 (o padrão para visualização na web do iOS)
Tipo | Requerido | Plataforma |
---|---|---|
number | Não | iOS |
domStorageEnabled
⬆
Valor booleano para controlar se o DOM Storage está habilitado. Usado apenas no Android.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | Android |
javaScriptEnabled
⬆
Valor booleano para habilitar JavaScript na WebView
. O valor padrão é true
.
Tipo | Requerido |
---|---|
bool | Não |
javaScriptCanOpenWindowsAutomatically
⬆
Um valor booleano que indica se o JavaScript pode abrir janelas sem interação do usuário. O valor padrão é falso
.
Tipo | Requerido |
---|---|
bool | Não |
androidLayerType
⬆
Especifica o tipo de camada.
Os valores possíveis para androidLayerType
são:
none
(padrão) - A visualização não possui uma camada.software
- A visão tem uma camada de software. Uma camada de software é apoiada por um bitmap e faz com que a exibição seja renderizada usando o pipeline de renderização de software do Android, mesmo se a aceleração de hardware estiver habilitada.hardware
- A visualização tem uma camada de hardware. Uma camada de hardware é apoiada por uma textura específica de hardware e faz com que a exibição seja renderizada usando o pipeline de renderização de hardware do Android, mas somente se a aceleração de hardware estiver ativada para a hierarquia de exibição.
Tipo | Requerido | Plataforma |
---|---|---|
string | Não | Android |
mixedContentMode
⬆
Especifica o modo de conteúdo misto. ou seja, a WebView permitirá que uma origem segura carregue conteúdo de qualquer outra origem.
Os valores possíveis para mixedContentMode
são:
never
(padrão) - WebView não permitirá que uma origem segura carregue conteúdo de uma origem insegura.always
- A WebView permitirá que uma origem segura carregue conteúdo de qualquer outra origem, mesmo que essa origem seja insegura.compatibility
- WebView tentará ser compatível com a abordagem de um navegador web moderno em relação ao conteúdo misto.
Tipo | Requerido | Plataforma |
---|---|---|
string | Não | Android |
thirdPartyCookiesEnabled
⬆
Valor booleano para habilitar cookies de terceiros na WebView
. Usado no Android Lollipop e acima apenas porque os cookies de terceiros são ativados por padrão no Android Kitkat e abaixo e no iOS. O valor padrão é true
. Para saber mais sobre cookies, leia o Guia
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | Android |
userAgent
⬆
Define o agente do usuário para a WebView
.
Tipo | Requerido | Plataforma |
---|---|---|
string | Não | iOS, Android, macOS |
applicationNameForUserAgent
⬆
Anexar ao agente de usuário existente. Definir userAgent
substituirá isso.
Tipo | Requerido | Plataforma |
---|---|---|
string | Não | iOS, Android, macOS |
<WebView
source={{ uri: 'https://reactnative.dev' }}
applicationNameForUserAgent={'DemoApp/1.1.0'}
/>
// O User-Agent resultante será semelhante a:
// Mozilla/5.0 (Linux; Android 8.1.0; Android SDK built for x86 Build/OSM1.180201.021; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/61.0.3163.98 Mobile Safari/537.36 DemoApp/1.1.0
// Mozilla/5.0 (iPhone; CPU iPhone OS 12_2 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) Mobile/15E148 DemoApp/1.1.0
allowsFullscreenVideo
⬆
Booleano que determina se os vídeos podem ser reproduzidos em tela cheia. O valor padrão é falso
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | Android |
allowsInlineMediaPlayback
⬆
Booleano que determina se os vídeos HTML5 são reproduzidos inline ou usam o controlador de tela cheia nativo. O valor padrão é falso
.
NOTA
Para que o vídeo seja reproduzido inline, não apenas esta propriedade precisa ser definida como
true
, mas o elemento de vídeo no documento HTML também deve incluir o atributowebkit-playsinline
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS |
allowsAirPlayForMediaPlayback
⬆
Um valor booleano que indica se o AirPlay é permitido. O valor padrão é falso
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS e macOS |
bounces
⬆
Valor booleano que determina se a visualização da Web é rejeitada quando atinge a borda do conteúdo. O valor padrão é true
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS |
overScrollMode
⬆
Especifica o modo de sobrerolagem.
Os valores possíveis para overScrollMode
são:
always
(padrão) - Sempre permite que um usuário sobrescreva esta visualização, desde que seja uma visualização que possa rolar.content
- Permitir que um usuário sobrescreva esta visualização somente se o conteúdo for grande o suficiente para rolar significativamente, desde que seja uma visualização que possa rolar.never
- Nunca permita que um usuário sobrescreva esta visualização.
Tipo | Requerido | Plataforma |
---|---|---|
string | Não | Android |
contentInset
⬆
A quantidade pela qual o conteúdo da visualização da web é inserido a partir das bordas da visualização de rolagem. Padrão {top: 0, left: 0, bottom: 0, right: 0}.
Tipo | Requerido | Plataforma |
---|---|---|
object: {top: number, left: number, bottom: number, right: number} | Não | iOS |
contentInsetAdjustmentBehavior
⬆
Esta propriedade especifica como as inserções da área segura são usadas para modificar a área de conteúdo da visualização de rolagem. O valor padrão dessa propriedade é "never". Disponível no iOS 11 e posterior. O padrão é never
.
Valores possíveis:
automatic
scrollableAxes
never
always
Tipo | Requerido | Plataforma |
---|---|---|
string | Não | iOS |
contentMode
⬆
Controla o tipo de conteúdo a ser carregado. Disponível no iOS 13 ou posterior. O padrão é "recomendado", que carrega conteúdo móvel no iPhone e iPad Mini, mas conteúdo de desktop em iPads maiores.
Consulte Apresentando a navegação de classe desktop no iPad para saber mais.
Valores possíveis:
recommended
mobile
desktop
Tipo | Requerido | Plataforma |
---|---|---|
string | Não | iOS |
dataDetectorTypes
⬆
Determina os tipos de dados convertidos em URLs clicáveis no conteúdo da visualização da web. Por padrão, apenas números de telefone são detectados.
Você pode fornecer um tipo ou uma matriz de vários tipos.
Os valores possíveis para dataDetectorTypes
são:
phoneNumber
link
address
calendarEvent
none
all
trackingNumber
flightNumber
lookupSuggestion
Tipo | Requerido | Plataforma |
---|---|---|
string, or array | Não | iOS |
scrollEnabled
⬆
Valor booleano que determina se a rolagem está habilitada na WebView
. O valor padrão é true
. Definir isso como false
impedirá que a visualização da Web mova o corpo do documento quando o teclado aparecer sobre uma entrada.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS e macOS |
nestedScrollEnabled
⬆
Valor booleano que determina se a rolagem é possível na WebView
quando usado dentro de um ScrollView
no Android. O valor padrão é falso
.
Definir isso como true
impedirá que o ScrollView
role ao rolar de dentro do WebView
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | Android |
setBuiltInZoomControls
⬆
Define se o WebView deve usar seus mecanismos de zoom integrados. O valor padrão é true
. Definir isso como "falso" impedirá o uso de um gesto de pinça para controlar o zoom.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | Android |
setDisplayZoomControls
⬆
Define se o WebView deve exibir controles de zoom na tela ao usar os mecanismos de zoom integrados (consulte setBuiltInZoomControls
). O valor padrão é falso
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | Android |
directionalLockEnabled
⬆
Um valor booleano que determina se a rolagem está desabilitada em uma direção específica.
O valor padrão é true
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS |
showsHorizontalScrollIndicator
⬆
Valor booleano que determina se um indicador de rolagem horizontal é mostrado na WebView
. O valor padrão é true
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS, Android, macOS |
showsVerticalScrollIndicator
⬆
Valor booleano que determina se um indicador de rolagem vertical é mostrado na WebView
. O valor padrão é true
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS, Android, macOS |
geolocationEnabled
⬆
Defina se a geolocalização está habilitada na WebView
. O valor padrão é falso
. Usado apenas no Android.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | Android |
allowFileAccessFromFileURLs
⬆
Booleano que define se o JavaScript executado no contexto de uma URL de esquema de arquivo deve ter permissão para acessar o conteúdo de outras URLs de esquema de arquivo. O valor padrão é falso
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS, Android, macOS |
allowUniversalAccessFromFileURLs
⬆
Booleano que define se o JavaScript executado no contexto de uma URL de esquema de arquivo deve ter permissão para acessar conteúdo de qualquer origem. Incluindo o acesso ao conteúdo de outros URLs de esquema de arquivos. O valor padrão é falso
.
Tipo | Requerido | Plataforma |
---|---|---|
bool | Não | iOS, Android, macOS |
allowingReadAccessToURL
⬆
Um valor String que indica quais URLs o arquivo da WebView pode referenciar em scripts, solicitações AJAX e importações CSS. Isso é usado apenas para WebViews que são carregados com um source.uri definido como um URL 'file://'
. Se não for fornecido, o padrão é permitir apenas acesso de leitura à URL fornecida no próprio source.uri.
Tipo | Requerido | Plataforma |
---|---|---|
string | Não | iOS e macOS |
keyboardDisplayRequiresUserAction
⬆
Se false, o conteúdo da Web pode exibir programaticamente o teclado. O valor padrão é true
.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS |
hideKeyboardAccessoryView
⬆
Se true, isso ocultará a visualização do acessório de teclado (< > e Feito).
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS |
allowsBackForwardNavigationGestures
⬆
Se for verdade, isso será capaz de gestos de furto horizontal. O valor padrão é falso
.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS e macOS |
incognito
⬆
Não armazena nenhum dado durante o tempo de vida da WebView.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS, Android, macOS |
allowFileAccess
⬆
Se true, isso permitirá o acesso ao sistema de arquivos por meio de URIs file://
. O valor padrão é falso
.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | Android |
saveFormDataDisabled
⬆
Define se a WebView deve desabilitar o salvamento de dados de formulário. O valor padrão é falso
. Esta função não tem nenhum efeito a partir do nível 26 da API do Android, pois há um recurso de preenchimento automático que armazena dados de formulário.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | Android |
cacheEnabled
⬆
Define seao WebView deve usar o cache do navegador.
Tipo | Requerido | Padrão | Plataforma |
---|---|---|---|
boolean | Não | true | iOS, Android, macOS |
cacheMode
⬆
Substitui a maneira como o cache é usado. A forma como o cache é usado é baseado no tipo de navegação. Para um carregamento de página normal, o cache é verificado e o conteúdo é revalidado conforme necessário. Ao navegar de volta, o conteúdo não é revalidado, em vez disso, o conteúdo é apenas recuperado do cache. Essa propriedade permite que o cliente substitua esse comportamento.
Os valores possíveis são:
LOAD_DEFAULT
- Modo de uso de cache padrão. Se o tipo de navegação não impor nenhum comportamento específico, use recursos em cache quando estiverem disponíveis e não expirados, caso contrário, carregue recursos da rede.LOAD_CACHE_ELSE_NETWORK
- Use recursos em cache quando estiverem disponíveis, mesmo que tenham expirado. Caso contrário, carregue recursos da rede.LOAD_NO_CACHE
- Não use o cache, carregue da rede.LOAD_CACHE_ONLY
- Não use a rede, carregue do cache.
Tipo | Requerido | Padrão | Plataforma |
---|---|---|---|
string | Não | LOAD_DEFAULT | Android |
pagingEnabled
⬆
Se o valor desta propriedade for true, a visualização de rolagem para em múltiplos dos limites da visualização de rolagem quando o usuário rola. O valor padrão é falso.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS |
allowsLinkPreview
⬆
Um valor booleano que determina se pressionar um link exibe uma visualização do destino do link. No iOS esta propriedade está disponível em dispositivos que suportam 3D Touch. No iOS 10 e posterior, o valor padrão é true; antes disso, o valor padrão é false.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS e macOS |
sharedCookiesEnabled
⬆
Defina true
se os cookies compartilhados de [NSHTTPCookieStorage sharedHTTPCookieStorage]
devem ser usados para cada solicitação de carregamento no WebView. O valor padrão é falso
. Para saber mais sobre cookies, leia o Guia
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS e macOS |
textZoom
⬆
Se o usuário definiu um tamanho de fonte personalizado no sistema Android, ocorre uma escala indesejável da interface do site no WebView.
Ao definir o tamanho padrão do parâmetro textZoom (100), esse efeito indesejável desaparece.
Tipo | Requerido | Plataforma |
---|---|---|
number | Não | Android |
Exemplo:
<WebView textZoom={100} />
pullToRefreshEnabled
⬆
Valor booleano que determina se um gesto de puxar para atualizar está disponível na WebView
. O valor padrão é falso
. Se true
, define bounces
automaticamente para true
.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS |
ignoreSilentHardwareSwitch
⬆
(somente ios)
Quando definido como true, o switch silencioso do hardware é ignorado. Padrão: falso
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS |
onFileDownload
⬆
Esta propriedade é somente para iOS.
Função que é chamada quando o cliente precisa baixar um arquivo.
Somente iOS 13+: se a visualização da web navegar para um URL que resulta em um HTTP resposta com um cabeçalho Content-Disposition 'attachment...', então isso será chamado.
iOS 8+: Se o tipo MIME indicar que o conteúdo não pode ser renderizado pelo webview, que também fará com que isso seja chamado. Nas versões do iOS anteriores a 13, esta é a única condição que fará com que esta função seja chamada.
O aplicativo precisará fornecer seu próprio código para realmente fazer o download o arquivo.
Se não for fornecido, o padrão é permitir que o webview tente renderizar o arquivo.
Exemplo:
<WebView
source={{ uri: 'https://reactnative.dev' }}
onFileDownload={({ nativeEvent: { downloadUrl } }) => {
// Você usa downloadUrl que é uma string para baixar arquivos como quiser.
}}
/>
Tipo | Requerido | Plataforma |
---|---|---|
function | Não | iOS |
limitsNavigationsToAppBoundDomains
⬆
Se true indica ao WebKit que um WKWebView navegará apenas para domínios vinculados a aplicativos. Aplicável apenas para iOS 14 ou superior.
Uma vez definido, qualquer tentativa de sair de um domínio vinculado ao aplicativo falhará com o erro "Falha no domínio vinculado ao aplicativo".
Os aplicativos podem especificar até 10 domínios "limitados ao aplicativo" usando uma nova chave Info.plist WKAppBoundDomains
. Para obter mais informações, consulte Domínios vinculados a aplicativos.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS |
Exemplo:
<WebView limitsNavigationsToAppBoundDomains={true} />
textInteractionEnabled
⬆
Se false indica ao WebKit que um WKWebView não irá interagir com o texto, não mostrando um loop de seleção de texto. Aplicável apenas para iOS 14.5 ou superior.
O padrão é true
.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS |
Exemplo:
<WebView textInteractionEnabled={false} />
Esta propriedade especifica como lidar com solicitações de permissão de captura de mídia. O padrão é prompt
, fazendo com que o usuário seja solicitado repetidamente. Disponível no iOS 15 e posterior.
Valores possíveis:
grantIfSameHostElsePrompt
: Se o host da origem de segurança da solicitação de permissão for igual ao host da URL atual do WebView, a permissão será concedida se já tiver sido concedida antes. Caso contrário, o usuário será solicitado.grantIfSameHostElseDeny
: Se o host da origem de segurança da solicitação de permissão for igual ao host da URL atual do WebView, a permissão será concedida se já tiver sido concedida antes. Caso contrário, é negado.deny
grant
: A permissão é concedida se já tiver sido concedida antes.prompt
Observe que uma concessão ainda pode resultar em um prompt, por exemplo, se o usuário nunca tiver sido solicitado a fornecer a permissão antes.
Tipo | Requerido | Plataforma |
---|---|---|
string | Não | iOS |
Exemplo:
<WebView mediaCapturePermissionGrantType={'grantIfSameHostElsePrompt'} />
Se definido como true
, a barra de status será automaticamente ocultada/exibida pela WebView, especificamente quando o vídeo em tela cheia estiver sendo assistido. Se for false
, a WebView não gerenciará a barra de status. O valor padrão é true
.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | iOS |
Exemplo:
<WebView autoManageStatusBarEnabled={false} />
Define se a WebView oferece suporte a várias janelas. Consulte documentação do Android para obter mais informações. Definir isso como false pode expor o aplicativo a essa vulnerabilidade, permitindo que um iframe malicioso escape para o DOM da camada superior.
Tipo | Requerido | Padrão | Plataforma |
---|---|---|---|
boolean | Não | true | Android |
Exemplo:
<WebView setSupportMultipleWindows={false} />
Um valor booleano quando definido como true
, a WebView será renderizado com suporte ao Apple Pay. Uma vez definido, os sites poderão invocar o Apple Pay a partir do React Native Webview.
Isso vem com recursos como injectJavaScript
, html5 histórico, sharedCookiesEnabled
, injectedJavaScript
, injectedJavaScriptBeforeContentLoaded
não funcionará veja na Nota de lançamento do Apple Pay.
Se você for solicitado a enviar uma mensagem para App , a página da Web deve chamar explicitamente o manipulador de mensagens do webkit e recebê-lo no manipulador onMessage
no lado nativo.
window.webkit.messageHandlers.ReactNativeWebView.postMessage("hello apple pay")
Tipo | Requerido | Padrão | Plataforma |
---|---|---|---|
boolean | Não | false | iOS |
Exemplo:
<WebView enableApplePay={true} />
Configurando o tema escuro NOTA : A configuração de forçar o tema escuro não é persistente. Você deve chamar o método estático sempre que o processo do aplicativo for iniciado.
NOTA : A mudança do modo dia<->noite é uma alteração de configuração, portanto, por padrão, a atividade será reiniciada e serão coletados os novos valores para aplicar o tema. Tome cuidado ao substituir esse comportamento padrão para garantir que esse método ainda seja chamado quando as alterações forem feitas.
Tipo | Requerido | Plataforma |
---|---|---|
boolean | Não | Android |
Exemplo:
<WebView forceDarkOn={false} />
Uma matriz de objetos de itens de menu personalizados que serão anexados ao UIMenu que aparece ao selecionar o texto (aparecerá após 'Copiar' e 'Compartilhar...'). Usado em conjunto com onCustomMenuSelection
Tipo | Requerido | Plataforma |
---|---|---|
array of objects: {label: string, key: string} | Não | iOS |
Exemplo:
<WebView menuItems={[{ label: 'Tweet', key: 'tweet' }, { label: 'Guardar para depois', key: 'saveForLater' }]} />
Função chamada quando um item de menu personalizado é selecionado. Ele recebe um evento Nativo, que inclui três chaves personalizadas: label
, key
e selectedText
.
Tipo | Requerido | Plataforma |
---|---|---|
function | Não | iOS |
<WebView
menuItems={[{ label: 'Tweet', key: 'tweet' }, { label: 'Guardar para depois', key: 'saveForLater' }]}
onCustomMenuSelection={(webViewEvent) => {
const { label } = webViewEvent.nativeEvent; // O nome do item de menu, ou seja, 'Tweet'
const { key } = webViewEvent.nativeEvent; // A chave do item de menu, ou seja, 'tweet'
const { selectedText } = webViewEvent.nativeEvent; // Texto destacado
}}
/>
Um objeto que especifica as credenciais de um usuário a serem usadas para autenticação básica.
username
(string) - Um nome de usuário usado para autenticação básica.password
(string) - Uma senha usada para autenticação básica.
Tipo | Requerido |
---|---|
object | Não |
O Android impõe um tamanho mínimo de fonte com base nesse valor. Um número inteiro não negativo entre 1 e 72. Qualquer número fora do intervalo especificado será fixado. O valor padrão é 8. Se você estiver usando tamanhos de fonte menores e estiver tendo problemas para ajustar a janela inteira em uma tela, tente definir um valor menor.
Tipo | Requerido | Plataforma |
---|---|---|
number | Não | Android |
Exemplo:
<WebView minimumFontSize={1} />
goForward()
⬆
goForward();
Avançar uma página no histórico da visualização da web.
goBack()
⬆
goBack();
Volte uma página no histórico da visualização da web.
reload()
⬆
reload();
Recarrega a página atual.
stopLoading()
⬆
stopLoading();
Pare de carregar a página atual.
injectJavaScript(str)
⬆
injectJavaScript('... javascript string ...');
Executa a string JavaScript.
Para saber mais, leia o guia Comunicação entre JS e Native.
requestFocus()
⬆
requestFocus();
Solicite a webView para pedir o foco. (As pessoas que trabalham em aplicativos de TV podem querer dar uma olhada nisso!)
postMessage(str)
⬆
postMessage('mensagem');
Postagem de uma mensagem no WebView, tratada por onMessage
.
clearFormData()
⬆
(somente Android)
clearFormData();
Remove o pop-up de preenchimento automático do campo de formulário em foco no momento, se presente. referência do desenvolvedor.android.com
clearCache(bool)
⬆
(somente Android)
clearCache(true)
Limpa o cache de recursos. Observe que o cache é por aplicativo, portanto, isso limpará o cache de todos os WebViews usados. referência do desenvolvedor.android.com
clearHistory()
⬆
(somente Android)
clearHistory();
Diz a este WebView para limpar sua lista interna de retorno/encaminhamento. referência do desenvolvedor.android.com
Confira também nosso Guia de Introdução e Guia Detalhado.
Esse arquivo está disponível em: