no Firefox, por que esta página é renderizada dessa maneira (o conteúdo da tag noscript é ignorado) ao executar o NoScript ou o uBlock Origin?

no Firefox, por que esta página é renderizada dessa maneira (o conteúdo da tag noscript é ignorado) ao executar o NoScript ou o uBlock Origin?

Eu tenho uma página

http://www.zen76171.zen.co.uk/aaa2.html

com este HTML

<!doctype html>
<html>
<head>
<noscript>aaa</noscript>
<script>document.write("bbb")</script>
</head>
<body>
ccc
</body>
</html>

Entendo que o conteúdo da tag noscript deve ser executado se um navegador não estiver executando javascript.

No Chrome ou no Firefox, sem extensões bloqueando nada, recebo a saída bbb ccc. Tudo bem, isso faz sentido. 'bbb' mostra porque o javascript é permitido e ccc mostra porque mostrará se o javascript está habilitado ou não.

Então tento instalar o NoScript no Firefox https://addons.mozilla.org/en-GB/firefox/addon/noscript/

Agora, quando eu recarregar a página que mencioneihttp://www.zen76171.zen.co.uk/aaa2.html

Isto mostra ccc. Isso me indica que os scripts estão sendo bloqueados, então essa parte é boa.

Mas a saída que eu esperaria é aaa ccc, porque esperaria que 'aaa' fosse exibido quando os scripts estivessem desabilitados e os scripts estivessem desabilitados.

Há também um problema secundário que resolvo: se eu desabilitar ou até mesmo 'remover' o NoScript do Firefox, ainda recebo a mesma resposta de 'ccc', terei que desinstalar e reinstalar o Firefox para remover o NoScript. Mas, por enquanto, isso servirá quando eu quiser remover o NoScript.

Esta questão é: por que mostra apenas 'ccc' e não 'aaa ccc'?

adicionado

Na verdade, recebo apenas o 'ccc' mostrado com 'uBlock Origin'. Se eu instalar o 'uBlock Origin' e optar por deixar como está para não desativar os scripts, recebo 'bbb ccc' (tudo bem). Considerando que, se eu clicar para desativar scripts na página, recebo 'ccc'. O 'aaa' não está sendo exibido.

Responder1

A tag noscript foi usada indevidamente, enquanto a extensão do navegador estava funcionando corretamente. Além disso, o resultado da página pode ser armazenado em cache e, portanto, provavelmente será necessária uma atualização completa (recarregar com cache de substituição).

Uso impróprio

Mas a saída que eu esperaria é 'aaa ccc', porque esperaria que 'aaa' aparecesse quando os scripts estivessem desabilitados e os scripts estivessem desabilitados.

Não, a saída esperada 'aaa' não será mostrada porque a tag noscript foi usada indevidamente.

Tag HTML noscript em W3schoolsfornece uma explicação concisa para o uso:

Definição e uso[...]

O elemento <noscript> pode ser usado tanto em <head> quanto em <body>.

Quando usado dentro do elemento <head>: <noscript> deve conter apenas os elementos <link>, <style> e <meta>.

Diferenças entre HTML 4.01 e HTML5

No HTML 4.01, a tag <noscript> só pode ser usada dentro do elemento <body>.

No HTML5, a tag <noscript> pode ser usada tanto dentro de <head> quanto de <body>.

Em outras palavras, a tag noscript usada pelo OP é válida com base em HTML5, mas isso não segueo padrão HTML. A tag noscript no elemento head HTMLnão deveriaconter qualquer "texto livre".

Resultado da página

Há também um problema secundário que eu resolvo, que é que se eu desabilitar ou até mesmo 'remover' o NoScript do Firefox, ainda recebo a mesma resposta de 'ccc' [...]

A maioria dos navegadores, incluindo o Firefox, usa cache por padrão, portanto, provavelmente será necessária uma atualização completa. Isso pode ser facilmente reproduzido o tempo todo, a menos que o usuário tenha configurado o comportamento do cache de forma diferente.

Discrepância 1: A atualização completa é realizada através do atalho de teclado, que pode ser Ctrl+ F5ou Ctrl+ Shift+ Rpara Firefox. No caso de extensão do navegador, o efeito de cache pode persistir até que o navegador seja reiniciado novamente (a experiência do usuário pode ser diferente).

Se eu instalar o 'uBlock Origin' e optar por deixar como está para não desativar os scripts, recebo 'bbb ccc' (tudo bem). Considerando que, se eu clicar para desativar scripts na página, recebo 'ccc'. O 'aaa' não está sendo exibido.

A tag noscript que continha 'aaa' provavelmente está sendo ignorada ou omitida pelas extensões, pois o uso de 'aaa' não segue o padrão HTML. A tag noscript no elemento head HTML deve conter apenas os três elementos conforme observado acima.

Discrepância 2: O resultado da página será 'bbb ccc' também ao visualizar o arquivo HTML localmente no Firefox, mesmo quando o uBlock Origin estiver habilitado e a opção estendida "Desativar JavaScript" estiver marcada. Provavelmente, isso se deve à permissão limitada concedida às extensões do Firefox Quantum. Em outras palavras, a extensão do navegador não consegue bloquear o script de uma página HTML local exibida viaesquema de URI de arquivo(não via localhost executado por um servidor web, o que é outro assunto diferente).

Tente novamente

Considere o conteúdo HTML modificado da seguinte forma:

<!doctype html>
<html>
<head>
<noscript>aaa<style>#this {color:#cccccc;}</style></noscript>
<script>document.write("bbb")</script>
</head>
<body>
<noscript>nnn</noscript>
<span id="this">ccc</span>
</body>
</html>

Em seguida, carregue o HTML no Firefox com uBlock Origin e sua opção "Desativar JavaScript" está desmarcada (OFF) ou marcada (ON).

  • Se "Desativar JavaScript" estiver desativado, o resultado será 'bbb ccc'
  • Se "Desativar JavaScript" estiver ativado, o resultado será 'nnn ccc', onde 'nnn' é mostrado na tag noscript no elemento HTML body e 'ccc' herda a cor da tag noscript no elemento HTML head
  • Em ambos os casos, 'aaa' nunca aparecerá conforme explicado anteriormente (não segue o padrão)

Discrepância 3: O 'aaa' será visível apenas se o JavaScript estiver desabilitado no próprio navegador (configuração oculta do Firefox, about:config - "javascript.enabled" definido como "false"). Como alternativa, use qualquer navegador somente de texto para ver resultados semelhantes. Isso é diferente da opção oferecida pela extensão do navegador, que o Firefox Quantum limitoupor design.

DRUse a tag noscript no elemento HTML body, para tornar o texto visível quando o script estiver desabilitado. A extensão do navegador está funcionando corretamente de acordo com o padrão HTML, mas limitada por design.

informação relacionada