полимер 3 cli полимер serve --compile= никогда не работает должным образом

Я обновляю полимерное приложение с версии 2 до 3, и во время разработки я хочу проверить свой прогресс, поэтому я использую полимерный сервер, чтобы мне не приходилось каждый раз создавать. Проблема в том, что по какой-то причине моя точка входа index.html изменяется полимерным сервером.

Я вызываю сервер командой polymer serve --npm -H 0.0.0.0 -p 80 --compile=never но в файле index.html, как видно в браузере, все <script type="module"> теги превращаются в <script>define([..., также неприятная минифицированная функция добавляется непосредственно перед тегами. Я не хочу этого, по крайней мере, для моих целей разработки я использую последнюю версию Chrome или Firefox, у которых нет проблем с ES6. Больше всего сбивает с толку то, что я обновил другую часть платформы с полимера 2 до 3, и полимерный сервер не менял там index.html.

Последняя и самая простая редакция моего index.html:

       <!doctype html>


<head>
    <meta charset="utf-8">
    <base href = "/" tal:attributes="href string:/ui/${build_path}">
    </base>
    <script>
        var BUILD_PATH='';
    </script>
    <script type="module">
        import "./src/mist-app.js" // This is how I wrote it and want it
    </script>
</head>

<body>
    <mist-app>
    </mist-app>
    <!-- <script src="./node_modules/@webcomponents/webcomponentsjs/webcomponents-loader.js"></script> -->
    <script src="./node_modules/@webcomponents/webcomponentsjs/webcomponents-bundle.js"></script>
    <script>
    if (CONFIG) {
        document.querySelector('mist-app').config = CONFIG;
    }
    </script>
</body>

</html>

В любом браузере он отображается как:

         <!DOCTYPE html><html><head>
    <meta charset="utf-8">
    <base href="/ui/">
    
    <script>var BUILD_PATH = '';</script>
    <script>"use strict";(function(){function a(a,b,c){var d=a;if(d.state=b,d.stateData=c,0<d.onNextStateChange.length){var e=d.onNextStateChange.slice();d.onNextStateChange.length=0;for(var f,g=0,h=e;g<h.length;g++)f=h[g],f()}return d}function b(b){function d(){try{document.head.removeChild(f)}catch(a){}}var e=a(b,"Loading",void 0),f=document.createElement("script");return f.src=b.url,null!==b.crossorigin&&f.setAttribute("crossorigin",b.crossorigin),f.onload=function(){var a,b,f;void 0===r?(b=[],f=void 0):(a=r(),b=a[0],f=a[1]),c(e,b,f),d()},f.onerror=function(){g(b,new TypeError("Failed to fetch "+b.url)),d()},document.head.appendChild(f),e}function c(b,c,e){var f=d(b,c),g=f[0],h=f[1];return a(b,"WaitingForTurn",{args:g,deps:h,moduleBody:e})}function d(a,c){for(var e,f=[],g=[],i=0,j=c;i<j.length;i++){if(e=j[i],"exports"===e){f.push(a.exports);continue}if("require"===e){f.push(function(b,c,e){var f=d(a,b),g=f[0],i=f[1];h(i,function(){c&&c.apply(null,g)},e)});continue}if("meta"===e){f.push({url:!0===a.isTopLevel?a.url.substring(0,a.url.lastIndexOf("#")):a.url});continue}var l=k(n(a.urlBase,e),a.crossorigin);f.push(l.exports),g.push(l),"Initialized"===l.state&&b(l)}return[f,g]}function e(b){var c=a(b,"WaitingOnDeps",b.stateData);return h(b.stateData.deps,function(){return f(c)},function(a){return g(c,a)}),c}function f(b){var c=b.stateData;if(null!=c.moduleBody)try{c.moduleBody.apply(null,c.args)}catch(a){return g(b,a)}return a(b,"Executed",void 0)}function g(b,c){return!0===b.isTopLevel&&setTimeout(function(){throw c}),a(b,"Failed",c)}function h(a,b,c){var d=a.shift();return void 0===d?void(b&&b()):"WaitingOnDeps"===d.state?(!1,void h(a,b,c)):void i(d,function(){h(a,b,c)},c)}function i(a,b,c){switch(a.state){case"WaitingForTurn":return e(a),void i(a,b,c);case"Failed":return void(c&&c(a.stateData));case"Executed":return void b();case"Loading":case"WaitingOnDeps":return void a.onNextStateChange.push(function(){return i(a,b,c)});case"Initialized":throw new Error("All dependencies should be loading already before pressureDependencyToExecute is called.");default:throw new Error("Impossible module state: "+a.state);}}function j(a,b){switch(a.state){case"Executed":case"Failed":return void b();default:a.onNextStateChange.push(function(){return j(a,b)});}}function k(a,b){void 0===b&&(b="anonymous");var c=q[a];return void 0===c&&(c=q[a]={url:a,urlBase:m(a),exports:Object.create(null),state:"Initialized",stateData:void 0,isTopLevel:!1,crossorigin:b,onNextStateChange:[]}),c}function l(a){return v.href=a,v.href}function m(a){return a=a.split("?")[0],a=a.split("#")[0],a.substring(0,a.lastIndexOf("/")+1)}function n(a,b){return-1===b.indexOf("://")?l("/"===b[0]?b:a+b):b}function o(){return document.baseURI||(document.querySelector("base")||window.location).href}function p(){var b=document.currentScript;if(!b)return u;if(window.HTMLImports){var c=window.HTMLImports.importForElement(b);return c?c.href:u}var d=b.ownerDocument.createElement("a");return d.href="",d.href}if(!window.define){var q=Object.create(null),r=void 0,s=0,t=void 0,u=o();window.define=function(a,b){var d=!1;r=function(){return d=!0,r=void 0,[a,b]};var f=p(),g=document.currentScript&&document.currentScript.getAttribute("crossorigin")||"anonymous";setTimeout(function(){if(!1==d){r=void 0;var h=f+"#"+s++,i=k(h,g);i.isTopLevel=!0;var l=c(i,a,b);void 0===t?e(l):j(k(t),function(){e(l)}),t=h}},0)},window.define._reset=function(){for(var a in q)delete q[a];r=void 0,s=0,t=void 0,u=o()};var v=document.createElement("a")}})();</script>
<script>define(["./src/mist-app.js"], function (_mistApp) {
  "use strict"; // This is what I get!!!!
});</script> 
</head>

<body>
    <mist-app>
    </mist-app>
    <!-- <script src="./node_modules/@webcomponents/webcomponentsjs/webcomponents-loader.js"></script> -->
    
    <script>if (!window.customElements) { document.write('<!--'); }</script>
    <script type="text/javascript" src="node_modules/@webcomponents/webcomponentsjs/custom-elements-es5-adapter.js"></script>
    
<script src="./node_modules/@webcomponents/webcomponentsjs/webcomponents-bundle.js"></script>
    <script>if (CONFIG) {
  document.querySelector('mist-app').config = CONFIG;
}</script>



</body></html>

Кто-нибудь знает, можно ли заставить полимер оставить index.html нетронутым?

0 ответов

Другие вопросы по тегам