Nativescript 自定义组件
Nativescript Custom Components
我按照本指南创建了一个 nativescript 自定义组件 http://moduscreate.com/custom-components-in-nativescript/ 但它对我不起作用
我有一个文件夹 pages,里面有一个名为 main 的文件夹。
main 有几个文件
main.html
<StackLayout
xmlns="http://schemas.nativescript.org/tns.xsd"
xmlns:hello="pages/helllo"
loaded="pageLoaded" >
<hello:hello/>
</StackLayout>
main.component.ts
import { Component, ElementRef, OnInit, ViewChild} from "@angular/core";
import { Page } from "ui/page";
import colorModule = require("color");
var Color = colorModule.Color;
@Component({
selector: "my-app",
templateUrl: "pages/main/main.html",
styleUrls: ["pages/main/main-common.css"]
})
export class MainComponent implements OnInit{
constructor(private page: Page) {
}
ngOnInit() {
this.page.actionBarHidden = true;
}
}
我也有 main-common.css 但这并不重要。然后我在 pages 中有另一个名为 hello 的文件夹,其中只有一个文件
hello.html
<StackLayout width="100%" height="100%" backgroundColorr="red">
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
</StackLayout>
但是无论我做什么,hello 组件都没有显示,我只得到一个空屏幕。我还尝试将 hello.html 文件中的这一行 xmlns:hello="pages/helllo"
更改为此 xmlns:hello="../helllo"
但我什么也没得到,甚至连错误都没有。有人可以指出我做错了什么吗?
您所说的在 NativeScript Core 中有效但在 NativeScript + Angular-2.
中不起作用
您需要的是以 Angular-2 方式创建自定义组件。
为了演示,我们可以参考this sample where a custom item component is created. The example is also described in the documentation,它还会向您展示如何使用此组件的@Input 指令绑定数据。
让我来指导您完成整个过程。
1.) 创建自定义组件
using-item-template.component.ts
import { Component, ChangeDetectionStrategy, Input } from "@angular/core";
@Component({
selector: 'item-component',
styleUrls: ["listview/using-item-template/using-item-template.component.css"],
template: `
<StackLayout *ngFor="let element of data.list" class="model">
<Label [text]="element.model" class="name"></Label>
<Label [text]="element.speed +'mph'" class="speed"></Label>
</StackLayout>
`
})
export class ItemComponent {
@Input() data: any; // this way we "pass data" to our item-component
}
@Component({
selector: 'using-item-template',
styleUrls: ["listview/using-item-template/using-item-template.component.css"],
templateUrl: "listview/using-item-template/using-item-template.component.html",
changeDetection: ChangeDetectionStrategy.OnPush
})
export class UsingItemTemplateComponent {
public manufacturers: Array<any>;
constructor() {
var bugatti = [{ "model": "Bugatti Chiron", "speed": "261" }, { "model": "Bugatti Veyron Super Sport", "speed": "268" }];
var mclaren = [{ "model": "McLaren P1", "speed": "211" }, { "model": "McLaren F1", "speed": "242" }];
var jaguar = [{ "model": "Jaguar XJ220", "speed": 217 }];
this.manufacturers = [{ "list": bugatti }, { "list": mclaren }, { "list": jaguar }];
}
}
using-item-template.component.html
<StackLayout exampleTitle toggleNavButton>
<GridLayout rows="50, *" class="example-container">
<Label text="Top Cars" row="0" class="title" textWrap="true" horizontalAlignment="center"></Label>
<ListView [items]="manufacturers" row="1">
<template let-item="item">
<item-component [data]="item" ></item-component>
</template>
</ListView>
</GridLayout>
</StackLayout>
最后也是至关重要的部分是不要忘记在 NgModule 中声明您的 ItemComponent!
main.ts
import { ItemComponent } from "./listview/using-item-template/using-item-template.component";
@NgModule({
declarations: [
ItemComponent, // declare the item component
// the other components in your app
],
bootstrap: [AppComponent],
imports: [
.....
],
})
class AppComponentModule { }
我按照本指南创建了一个 nativescript 自定义组件 http://moduscreate.com/custom-components-in-nativescript/ 但它对我不起作用
我有一个文件夹 pages,里面有一个名为 main 的文件夹。 main 有几个文件
main.html
<StackLayout
xmlns="http://schemas.nativescript.org/tns.xsd"
xmlns:hello="pages/helllo"
loaded="pageLoaded" >
<hello:hello/>
</StackLayout>
main.component.ts
import { Component, ElementRef, OnInit, ViewChild} from "@angular/core";
import { Page } from "ui/page";
import colorModule = require("color");
var Color = colorModule.Color;
@Component({
selector: "my-app",
templateUrl: "pages/main/main.html",
styleUrls: ["pages/main/main-common.css"]
})
export class MainComponent implements OnInit{
constructor(private page: Page) {
}
ngOnInit() {
this.page.actionBarHidden = true;
}
}
我也有 main-common.css 但这并不重要。然后我在 pages 中有另一个名为 hello 的文件夹,其中只有一个文件
hello.html
<StackLayout width="100%" height="100%" backgroundColorr="red">
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
<Label class ="h1" text="h1 hello world" color="black"></Label>
</StackLayout>
但是无论我做什么,hello 组件都没有显示,我只得到一个空屏幕。我还尝试将 hello.html 文件中的这一行 xmlns:hello="pages/helllo"
更改为此 xmlns:hello="../helllo"
但我什么也没得到,甚至连错误都没有。有人可以指出我做错了什么吗?
您所说的在 NativeScript Core 中有效但在 NativeScript + Angular-2.
中不起作用您需要的是以 Angular-2 方式创建自定义组件。 为了演示,我们可以参考this sample where a custom item component is created. The example is also described in the documentation,它还会向您展示如何使用此组件的@Input 指令绑定数据。
让我来指导您完成整个过程。
1.) 创建自定义组件
using-item-template.component.ts
import { Component, ChangeDetectionStrategy, Input } from "@angular/core";
@Component({
selector: 'item-component',
styleUrls: ["listview/using-item-template/using-item-template.component.css"],
template: `
<StackLayout *ngFor="let element of data.list" class="model">
<Label [text]="element.model" class="name"></Label>
<Label [text]="element.speed +'mph'" class="speed"></Label>
</StackLayout>
`
})
export class ItemComponent {
@Input() data: any; // this way we "pass data" to our item-component
}
@Component({
selector: 'using-item-template',
styleUrls: ["listview/using-item-template/using-item-template.component.css"],
templateUrl: "listview/using-item-template/using-item-template.component.html",
changeDetection: ChangeDetectionStrategy.OnPush
})
export class UsingItemTemplateComponent {
public manufacturers: Array<any>;
constructor() {
var bugatti = [{ "model": "Bugatti Chiron", "speed": "261" }, { "model": "Bugatti Veyron Super Sport", "speed": "268" }];
var mclaren = [{ "model": "McLaren P1", "speed": "211" }, { "model": "McLaren F1", "speed": "242" }];
var jaguar = [{ "model": "Jaguar XJ220", "speed": 217 }];
this.manufacturers = [{ "list": bugatti }, { "list": mclaren }, { "list": jaguar }];
}
}
using-item-template.component.html
<StackLayout exampleTitle toggleNavButton>
<GridLayout rows="50, *" class="example-container">
<Label text="Top Cars" row="0" class="title" textWrap="true" horizontalAlignment="center"></Label>
<ListView [items]="manufacturers" row="1">
<template let-item="item">
<item-component [data]="item" ></item-component>
</template>
</ListView>
</GridLayout>
</StackLayout>
最后也是至关重要的部分是不要忘记在 NgModule 中声明您的 ItemComponent!
main.ts
import { ItemComponent } from "./listview/using-item-template/using-item-template.component";
@NgModule({
declarations: [
ItemComponent, // declare the item component
// the other components in your app
],
bootstrap: [AppComponent],
imports: [
.....
],
})
class AppComponentModule { }