Warm tip: This article is reproduced from serverfault.com, please click

javascript-通过Heroku运行的Autodesk Forge将不会显示 dashboard 扩展

(javascript - Autodesk Forge run via Heroku won't display the Dashboard Extension)

发布于 2020-11-30 13:10:32

我正在学习在learningforge.autodesk.io上找到的Autodesk Forge分步教程,并使用NodeJS选项。

我目前处于最后的“部署”部分,并决定使用Heroku当应用程序通过本地计算机运行时, dashboard 扩展程序可以很好地运行,但通过Heroku运行时则不会显示。

尝试过以下Autodesk Forge Extensions主题,但对我而言不起作用。

编辑: 我通过Heroku CLI对Heroku上的实际文件进行了检查,并且文件和所有其他路径与本地计算机上的文件完全相同。顺便说一句,我也在使用免费版本的Heroku,这可能是原因吗?

Chrome浏览器控制台显示以下错误:

我的index.html是:

<!DOCTYPE html>
<html>
  <head>
    <title>View Models - Autodesk Forge</title>
    <meta charset="utf-8" />
    <link
      rel="shortcut icon"
      href="https://github.com/Autodesk-Forge/learn.forge.viewmodels/raw/master/img/favicon.ico"
    />
    <!-- Common packages: jQuery, Bootstrap, jsTree -->
    <script src="//cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
    <script src="//cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.4.1/js/bootstrap.min.js"></script>
    <script src="//cdnjs.cloudflare.com/ajax/libs/jstree/3.3.7/jstree.min.js"></script>
    <link
      rel="stylesheet"
      href="//cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/3.4.1/css/bootstrap.min.css"
    />
    <link
      rel="stylesheet"
      href="//cdnjs.cloudflare.com/ajax/libs/jstree/3.3.7/themes/default/style.min.css"
    />
    <!--Chart JS  packages-->
    <script src="//cdnjs.cloudflare.com/ajax/libs/Chart.js/2.8.0/Chart.min.js"></script>
    <link
      rel="stylesheet"
      href="//cdnjs.cloudflare.com/ajax/libs/Chart.js/2.8.0/Chart.min.css"
    />
    <!-- Autodesk Forge Viewer files -->
    <link
      rel="stylesheet"
      href="https://developer.api.autodesk.com/modelderivative/v2/viewers/7.*/style.min.css"
      type="text/css"
    />
    <script src="https://developer.api.autodesk.com/modelderivative/v2/viewers/7.*/viewer3D.min.js"></script>
    <!-- this project files -->
    <link href="css/main.css" rel="stylesheet" />
    <script src="js/ForgeTree.js"></script>
    <script src="js/ForgeViewer.js"></script>
    <!-- Autodesk Forge Viewer HandleSelectionExtension -->
    <script src="js/HandleSelectionExtension.js"></script>
    <!-- Autodesk Forge Viewer Dashboard Extension -->
    <script src="js/Dashboard/Dashboard.js"></script>
    <script src="js/Dashboard/DashboardPanel.js"></script>
    <script src="js/Dashboard/PanelBarChart.js"></script>
    <script src="js/Dashboard/PanelPieChart.js"></script>
  </head>
  <body>
    <!-- Fixed navbar by Bootstrap: https://getbootstrap.com/examples/navbar-fixed-top/ -->
    <nav class="navbar navbar-default navbar-fixed-top">
      <div class="container-fluid">
        <ul class="nav navbar-nav left">
          <li>
            <a href="http://developer.autodesk.com" target="_blank">
              <img
                alt="Autodesk Forge"
                src="//developer.static.autodesk.com/images/logo_forge-2-line.png"
                height="20"
              />
            </a>
          </li>
        </ul>
      </div>
    </nav>
    <!-- End of navbar -->
    <div class="container-fluid fill">
      <div class="row fill">
        <div class="col-sm-4 fill">
          <div class="panel panel-default fill">
            <div class="panel-heading" data-toggle="tooltip">
              Buckets &amp; Objects
              <span
                id="refreshBuckets"
                class="glyphicon glyphicon-refresh"
                style="cursor: pointer"
              ></span>
              <button
                class="btn btn-xs btn-info"
                style="float: right"
                id="showFormCreateBucket"
                data-toggle="modal"
                data-target="#createBucketModal"
              >
                <span class="glyphicon glyphicon-folder-close"></span> New
                bucket
              </button>
            </div>
            <div id="appBuckets">tree here</div>
          </div>
        </div>
        <div class="col-sm-8 fill">
          <div id="forgeViewer"></div>
        </div>
      </div>
    </div>
    <form id="uploadFile" method="post" enctype="multipart/form-data">
      <input
        id="hiddenUploadField"
        type="file"
        name="theFile"
        style="visibility: hidden"
      />
    </form>
    <!-- Modal Create Bucket -->
    <div
      class="modal fade"
      id="createBucketModal"
      tabindex="-1"
      role="dialog"
      aria-labelledby="myModalLabel"
    >
      <div class="modal-dialog" role="document">
        <div class="modal-content">
          <div class="modal-header">
            <button
              type="button"
              class="close"
              data-dismiss="modal"
              aria-label="Cancel"
            >
              <span aria-hidden="true">&times;</span>
            </button>
            <h4 class="modal-title" id="myModalLabel">Create new bucket</h4>
          </div>
          <div class="modal-body">
            <input type="text" id="newBucketKey" class="form-control" /> For
            demonstration purposes, objects (files) are NOT automatically
            translated. After you upload, right click on the object and select
            "Translate". Bucket keys must be of the form [-_.a-z0-9]{3,128}
          </div>
          <div class="modal-footer">
            <button type="button" class="btn btn-default" data-dismiss="modal">
              Cancel
            </button>
            <button type="button" class="btn btn-primary" id="createNewBucket">
              Go ahead, create the bucket
            </button>
          </div>
        </div>
      </div>
    </div>
  </body>
</html>

哦,共同码的巫师,请注意我的电话,因为我需要帮助。

Questioner
MaPikka
Viewed
0
MaPikka 2020-12-01 15:56:24

好吧,让它工作。

这只是一个“区分大小写”的问题。

我的真实路径是“ js / d ashboard /”,被称为“ js / d ashboard /”。它必须是实际案例级别。本地计算机调试并不关心此事,但是服务器会关心。

我遵循了Learnforge循序渐进的教程“按字母顺序排列”,就像复制了已经考虑过的代码一样。我猜这是我忘记的一些基本服务器端知识。

多谢你提供协助!