首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >角material2在角2.0.0应用程序中不起作用

角material2在角2.0.0应用程序中不起作用
EN

Stack Overflow用户
提问于 2016-09-15 20:40:10
回答 2查看 1.7K关注 0票数 1

我有一个应用程序,加载角2.0.0,9/14/16发布后,所有的rc版本。我试图添加角Material2,官方发布的MD从谷歌团队。我是复制/粘贴代码,从他们的入门网站,但我使用的是Atom,而不是角-cli,因为我已经建立了应用程序的开始。原子类型记录找到了所有的东西,并说没有错误。但是,尽管经历了大量的尝试,但当修改后的应用程序无法加载时,我反复地发现了这些没有找到的控制台错误。

zone.js:1263 GET 模块/@angular2-材料/按钮/ 404 (未找到)scheduleTask@ zone.js:1263

主页:27错误:(SystemJS) XHR错误(404未找到)加载模块/@angular2-材料/按钮(…)

zone.js:1263 GET 模块/@angular2-资料/清单/ 404 (未找到)

我查看了上面的node_modules文件,它们存在于我的代码中。

根据入门指南,相关代码是:

app.module.ts

代码语言:javascript
复制
import { MdButtonModule } from '@angular2-material/button';
import { MdListModule } from '@angular2-material/list';
@NgModule({
  imports:      [ BrowserModule,
                  FormsModule,
                  MdButtonModule,
                  MdListModule,
                  routing
  ],

systemjs.config.js

代码语言:javascript
复制
var map = {
'@angular2-material':                   'node_modules/@angular2-material',
'@angular2-material/core':                   'node_modules/@angular2-material/core/core',
'@angular2-material/list':                   'node_modules/@angular2-material/list',
'@angular2-material/button':                   'node_modules/@angular2-material/button'
};
var packages = {
'app':                        { main: 'main.js',  defaultExtension: 'js' },
'rxjs':                       { defaultExtension: 'js' },
'angular2-in-memory-web-api': { main: 'index.js', defaultExtension: 'js' },
};
function packIndex(pkgName) {
packages['@angular/'+pkgName] = { main: 'index.js', defaultExtension: 'js' };
}
function packUmd(pkgName) {
packages['@angular/'+pkgName] = { main: 'bundles/' + pkgName + '.umd.js', defaultExtension: 'js' };
}
var setPackageConfig = System.packageWithIndex ? packIndex : packUmd;
ngPackageNames.forEach(setPackageConfig);

HTML页面有两个md-list、md-list-item和md-按钮标签.

我该换什么?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-09-16 13:55:09

从9/16开始,我就可以使用Angular2 (final)、Angular2-Material2.0.0-字母-8-2和TypeScript 2.0.0使用它了。正如您在下面的package.json中所看到的,我已经按照这段视频的说明安装(并运行)了大多数当前可用的Angular2材料组件。

发布我的system.config.ts,这样你就可以看到它,希望它能帮助你解决疑难问题。

代码语言:javascript
复制
/**
 * System configuration for Angular 2 samples
 * Adjust as necessary for your application needs.
 */
(function (global) {
  System.config({
    paths: {
      // paths serve as alias
      'npm:': 'node_modules/'
    },
    // map tells the System loader where to look for things
    map: {
      // our app is within the app folder
      app: 'app',
      // angular bundles
      '@angular/core': 'npm:@angular/core/bundles/core.umd.js',
      '@angular/common': 'npm:@angular/common/bundles/common.umd.js',
      '@angular/compiler': 'npm:@angular/compiler/bundles/compiler.umd.js',
      '@angular/platform-browser': 'npm:@angular/platform-browser/bundles/platform-browser.umd.js',
      '@angular/platform-browser-dynamic': 'npm:@angular/platform-browser-dynamic/bundles/platform-browser-dynamic.umd.js',
      '@angular/http': 'npm:@angular/http/bundles/http.umd.js',
      '@angular/router': 'npm:@angular/router/bundles/router.umd.js',
      '@angular/forms': 'npm:@angular/forms/bundles/forms.umd.js',

      // other libraries
      'rxjs':                       'npm:rxjs',
      'angular2-in-memory-web-api': 'npm:angular2-in-memory-web-api',

      // Angular2-Material
      '@angular2-material/core': 'npm:@angular2-material/core/core.umd.js',
      '@angular2-material/button': 'npm:@angular2-material/button/button.umd.js',
      '@angular2-material/card': 'npm:@angular2-material/card/card.umd.js',
      '@angular2-material/checkbox': 'npm:@angular2-material/checkbox/checkbox.umd.js',
      '@angular2-material/grid-list': 'npm:@angular2-material/grid-list/grid-list.umd.js',
      '@angular2-material/icon': 'npm:@angular2-material/icon/icon.umd.js',
      '@angular2-material/input': 'npm:@angular2-material/input/input.umd.js',
      '@angular2-material/list': 'npm:@angular2-material/list/list.umd.js',
      '@angular2-material/radio': 'npm:@angular2-material/radio/radio.umd.js',
      '@angular2-material/sidenav': 'npm:@angular2-material/sidenav/sidenav.umd.js',
      '@angular2-material/toolbar': 'npm:@angular2-material/toolbar/toolbar.umd.js',
    },
    // packages tells the System loader how to load when no filename and/or no extension
    packages: {
      app: {
        main: './main.js',
        defaultExtension: 'js'
      },
      rxjs: {
        defaultExtension: 'js'
      },
      'angular2-in-memory-web-api': {
        main: './index.js',
        defaultExtension: 'js'
      }
    }
  });
})(this);

我的package.json的相关部分:

代码语言:javascript
复制
      ...   
      "dependencies": {
        "@angular/common": "~2.0.0",
        "@angular/compiler": "~2.0.0",
        "@angular/core": "~2.0.0",
        "@angular/forms": "~2.0.0",
        "@angular/http": "~2.0.0",
        "@angular/platform-browser": "~2.0.0",
        "@angular/platform-browser-dynamic": "~2.0.0",
        "@angular/router": "~3.0.0",
        "@angular/upgrade": "~2.0.0",
        "@angular2-material/button": "^2.0.0-alpha.8-2",
        "@angular2-material/card": "^2.0.0-alpha.8-2",
        "@angular2-material/checkbox": "^2.0.0-alpha.8-2",
        "@angular2-material/core": "^2.0.0-alpha.8-2",
        "@angular2-material/grid-list": "^2.0.0-alpha.8-2",
        "@angular2-material/icon": "^2.0.0-alpha.8-2",
        "@angular2-material/input": "^2.0.0-alpha.8-2",
        "@angular2-material/list": "^2.0.0-alpha.8-2",
        "@angular2-material/radio": "^2.0.0-alpha.8-2",
        "@angular2-material/sidenav": "^2.0.0-alpha.8-2",
        "@angular2-material/toolbar": "^2.0.0-alpha.8-2",
        "angular2-in-memory-web-api": "~0.0.19",
        "core-js": "^2.4.1",
        "hammerjs": "^2.0.8",
        "reflect-metadata": "^0.1.3",
        "rxjs": "~5.0.0-beta.12",
        "systemjs": "~0.19.27",
        "zone.js": "^0.6.21"
      },
      "devDependencies": {
        "concurrently": "^2.2.0",
        "lite-server": "^2.2.2",
        "typescript": "^2.0.0",
        "typings": "^1.3.2"
      }
      ...

更新的类型记录到2.0.0版。

此外,还必须注册锤子的类型(触摸手势支持),但我相信只有在使用MdIconModule时才需要这样做。

票数 2
EN

Stack Overflow用户

发布于 2016-11-01 06:15:50

随着角材料2版本2.0.0-字母9的突然变化,您可以简单地在systemjs.config.ts中映射这一行

代码语言:javascript
复制
'@angular/material': 'npm:@angular/material/material.umd.js',

package.json也变得更简单,因为:

代码语言:javascript
复制
"@angular/material": "^2.0.0-alpha.9-3"

别忘了导入NgModule

代码语言:javascript
复制
import { MaterialModule } from '@angular/material';
@NgModule({
  ...
  imports: [MaterialModule.forRoot()],
  ...
})

来自material2释放

角材料已从@angular2-材料/.包装到一个包下面的@角/材料。除了这一变化之外,还有一个新的NgModule,MaterialModule,它包含所有组件。..。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/39520006

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档