使用TS开发Angular2但没有NPM

时间:2016-02-25 09:30:23

标签: javascript angular typescript npm

所有指南建议安装npm,但我正在寻找没有它的方法。

There are Angular2 files available,但它们都不是TypeScript代码。

那我该怎么办?我需要Angular2.ts或特定Angular2-xx.js.d.ts个文件吗?

更新:我已经通过Angular2下载了NPM并获得了完整的源代码树,其中很难找到具体内容。搜索.d.ts的{​​{1}}未找到任何结果。很多Angular2.ts文件都在大量代码中。

1 个答案:

答案 0 :(得分:11)

实际上,这些文件是Angular2及其依赖项的捆绑版本。它们可以在使用TypeScript编写的应用程序中使用。事实上,TypeScript不能直接用于浏览器。您必须预处理它们以使用TypeScript编译器将它们编译为ES代码,或者直接使用TypeScript库在浏览器中对它们进行转换。

这可以通过其transpiler配置属性直接在SystemJS中配置(见下文)。

首先,只需在HTML文件中添加这些文件:

<script src="https://code.angularjs.org/2.0.0-beta.2/angular2-polyfills.js"></script>
<script src="https://code.angularjs.org/tools/system.js"></script>
<script src="https://code.angularjs.org/tools/typescript.js"></script>
<script src="https://code.angularjs.org/2.0.0-beta.2/Rx.js"></script>
<script src="https://code.angularjs.org/2.0.0-beta.2/angular2.dev.js"></script>
<script src="https://code.angularjs.org/2.0.0-beta.2/http.dev.js"></script>

如果您想在没有NPM的情况下实现应用程序,可以在浏览器中转换TypeScript文件。这是我们在使用plunkr时的方式。为此,您需要按如下所述配置SystemJS:

<script>
  System.config({
    transpiler: 'typescript', 
    typescriptOptions: {
      emitDecoratorMetadata: true
    },
    packages: {
      'app': {
        defaultExtension: 'ts'
      }
    } 
  });
  System.import('app/main')
        .then(null, console.error.bind(console));
</script>

小心在app文件夹

下定义TypeScript文件

这是一个简单(完整)的plunkr,描述了如何做到这一点:https://plnkr.co/edit/vYQPePG4KDoktPoGaxYu?p=info

您可以下载相应的代码,并使用静态HTTP服务器(如http-server)在本地使用其代码,而无需使用NPM。这可能是您用例的一个很好的起点......

修改

如果您的TypeScript文件是由VS编译的,则需要调整SystemJS配置,如下所述:

<script>
  System.config({
    packages: {
      app: {
        defaultExtension: 'js',
      }
    }
  });
  System.import('app/boot')
        .then(null, console.error.bind(console));
</script>

这样,SystemJS将在导入时加载您的JS文件。例如:System.import('app/boot')将使用app/boot.js而不是TypeScript