Estou usando o ArcGIS JSAPI 4.12 e desejo usar Ilusões Espaciais para desenhar símbolos militares em um mapa.
Quando adiciono milsymbol.js
ao script, o console retorna erro
SyntaxError não capturado: não é possível usar a instrução de importação fora de um módulo`
então eu adiciono type="module"
ao script e ele retorna
Não detectado ReferenceError: ms não está definido
Aqui está o meu código:
<link rel="stylesheet" href="https://js.arcgis.com/4.12/esri/css/main.css">
<script src="https://js.arcgis.com/4.12/"></script>
<script type="module" src="milsymbol-2.0.0/src/milsymbol.js"></script>
<script>
require([
"esri/Map",
"esri/views/MapView",
"esri/layers/MapImageLayer",
"esri/layers/FeatureLayer"
], function (Map, MapView, MapImageLayer, FeatureLayer) {
var symbol = new ms.Symbol("SFG-UCI----D", { size: 30 }).asCanvas(3);
var map = new Map({
basemap: "topo-vector"
});
var view = new MapView({
container: "viewDiv",
map: map,
center: [121, 23],
zoom: 7
});
});
</script>
Então, se eu adiciono type="module"
ou não, sempre há erros. No entanto, no documento oficial de Spatial Illusions, não há nenhum type="module"
no script. Agora estou realmente confuso. Como eles conseguem fazer o trabalho sem adicionar o tipo?
Arquivo milsymbol.js
import { ms } from "./ms.js";
import Symbol from "./ms/symbol.js";
ms.Symbol = Symbol;
export { ms };
javascript
ecmascript-6
arcgis
arcgis-js-api
Jerry Chen
fonte
fonte
require()
. Confira este vídeoRespostas:
Eu recebi esse erro porque esqueci o type = "module" dentro da tag de script:
fonte
Parece que a causa dos erros é:
1) No momento, você está carregando o arquivo de origem no
src
diretório em vez do arquivo criado nodist
diretório (você pode ver qual é o arquivo distribuído pretendido aqui ). Isso significa que você está usando o código-fonte nativa em estado inalterado / desagregado, levando ao seguinte erro:Uncaught SyntaxError: Cannot use import statement outside a module
. Isso deve ser corrigido usando a versão empacotada, pois o pacote está usando rollup para criar um pacote configurável.2) O motivo pelo qual você está recebendo o
Uncaught ReferenceError: ms is not defined
erro é que os módulos têm escopo definido e, como você está carregando a biblioteca usando módulos nativos,ms
não está no escopo global e, portanto, não está acessível na seguinte tag de script.Parece que você deve conseguir carregar a
dist
versão deste arquivoms
definida nowindow
. Confira este exemplo do autor da biblioteca para ver um exemplo de como isso pode ser feito.fonte
require
o pacote incorporado diretamente no seu código.<script src="node_modules/milsymbol/dist/milsymbol.js"></script>
mas o console ainda retornaUncaught ReferenceError: ms is not defined
. O problemams
não está definido nodist/milsymbol.js
, está definido nosrc/milsymbol.js
, mas requertype="module"
e causará um problema de escopo. Existe alguma solução para isso. Muito obrigado!Resolvi esse problema fazendo o seguinte:
Ao usar os módulos ECMAScript 6 no navegador, use a extensão .js em seus arquivos e na tag de script add
type = "module"
.Ao usar os módulos ECMAScript 6 em um ambiente Node.js., use a extensão
.mjs
em seus arquivos e use este comando para executar o arquivo:fonte
Eu também estava enfrentando o mesmo problema até adicionar o type = "module" ao script. Antes era assim
E depois de mudar para
Funcionou perfeitamente
fonte
O erro é acionado porque o arquivo ao qual você está vinculando no arquivo HTML é a versão desagrupada do arquivo. Para obter a versão completa do pacote, você deverá instalá-la com
npm
:Isso baixa o pacote completo para sua
node_modules
pasta.Você pode acessar o arquivo JavaScript minificado independente em
node_modules/milsymbol/dist/milsymbol.js
Você pode fazer isso em qualquer diretório e, em seguida, basta copiar o arquivo abaixo para o seu
/src
diretório.fonte
--save
é o padrão desdenpm 5
&node 8
(2017): stackoverflow.com/q/36022926/1821548 , nodejs.dev/npm-dependencies-and-devdependencies , github.com/benmosher/eslint-plugin-import/issues/884 , auth0. com / blog / whats-new-in-node8-e-npm5Basta adicionar
.pack
entre o nome e a extensão na<script>
tag em src. ou seja:fonte