NativeScript - Veri Bağlama
Veri bağlama, NativeScript tarafından desteklenen gelişmiş kavramlardan biridir. NativeScript, Angular veri bağlama konseptini olabildiğince yakından takip eder. Veri bağlama, UI bileşeninin herhangi bir programlama çabası olmadan uygulama veri modelinin geçerli değerini göstermesini / güncellemesini sağlar.
NativeScript, iki tür veri bağlamayı destekler. Bunlar aşağıdaki gibidir -
One-Way data binding - Model her değiştirildiğinde kullanıcı arayüzünü güncelleyin.
Two-Way data binding- Kullanıcı arayüzünü ve modeli senkronize edin. Model her güncellendiğinde, kullanıcı arayüzü otomatik olarak güncellenir ve ayrıca kullanıcı arayüzü kullanıcıdan veri aldığında (UI güncellenir) model güncellenir.
Bu bölümde her iki kavramı da öğrenelim.
Tek Yönlü Veri Bağlama
NativeScript, bir UI bileşeninde tek yönlü veri bağlamayı etkinleştirmek için basit bir seçenek sağlar. Tek yönlü veri bağlamayı etkinleştirmek için, hedef kullanıcı arayüzünün özelliğine köşeli parantez ekleyin ve ardından ona gerekli modelin özelliğini atayın.
Örneğin, bir Etiket bileşeninin metin içeriğini güncellemek için, aşağıdaki gibi kullanıcı arayüzü kodunu değiştirmeniz yeterlidir -
<Label [text]='this.model.prop' />
Buraya,
this.model.prop modelin özelliğini ifade eder, this.model.
Tek yönlü veri bağlamayı anlamak için BlankNgApp'ımızı değiştirelim.
Aşama 1
Aşağıdaki gibi yeni bir model ekleyin, Kullanıcı (src / model / user.ts) -
export class User {
name: string
}
Adım 2
Bileşenimizin kullanıcı arayüzünü açın, src/app/home/home.component.html ve kodu aşağıdaki gibi güncelleyin -
<ActionBar>
<Label text="Home"></Label>
</ActionBar>
<GridLayout columns="*" rows="auto, auto, auto">
<Button text="Click here to greet" class="-primary" color='gray'
(tap)='onButtonTap($event)' row='1' column='0'>
</Button>
<Label [text]='this.user.name' row='2' column='0'
height="50px" textAlignment='center' style='font-size: 16px;
font-weight: bold; margin: 0px 32px 0 25px;'>
</Label>
</GridLayout>
Buraya,
Etiketin metni, kullanıcı modelinin özellik adına ayarlanır.
Düğmeye dokunma olayı, onButtonTap yöntemine eklenir.
Aşama 3
Ev bileşeninin açık kodu, src/app/home/home.component.ts ve kodu aşağıdaki gibi güncelleyin -
import { Component, OnInit } from "@angular/core";
import { User } from "../../model/user"
@Component({
selector: "Home",
templateUrl: "./home.component.html"
})
export class HomeComponent implements OnInit {
public user: User;
constructor() {
// Use the component constructor to inject providers.
this.user = new User();
this.user.name = "User1";
}
ngOnInit(): void {
// Init your component properties here.
}
onButtonTap(args: EventData) {
this.user.name = 'User2';
}
}
Buraya,
kullanıcı modeli içe aktarıldı
Kullanıcı nesnesi, bileşenin yapıcısında oluşturulur
onButtonTap olayı uygulandı. OnButtonTap uygulaması, Kullanıcı nesnesini günceller ve özelliğin adını Kullanıcı2 olarak ayarlar
4. adım
Uygulamayı derleyin ve çalıştırın ve modeli değiştirmek için düğmeye tıklayın; otomatik olarak Label Metin.
Başvurunun ilk ve son hali aşağıdaki gibidir -
Başlangıç hali
Tek Yönlü Veri Bağlama İlk Durumu aşağıda gösterilmiştir -
Son Durum
Tek Yönlü Veri Bağlama Son Durumu aşağıda gösterilmiştir -
İki yönlü Veri Bağlama
NativeScript ayrıca gelişmiş işlevsellik için iki yönlü veri bağlama sağlar. Model verilerini kullanıcı arayüzüne bağlar ve ayrıca kullanıcı arayüzünde güncellenen verileri modele bağlar.
İki yönlü veri bağlama yapmak için ngModel özelliğini kullanın ve ardından aşağıdaki gibi [] ve () ile çevreleyin -
<TextField [(ngModel)] = 'this.user.name'></TextField>
İki yönlü veri bağlamayı daha iyi anlamak için BlankNgApp uygulamasını değiştirelim.
Aşama 1
NativeScriptFormsModule'ü HomeModule'a (src/app/home/home.module.ts) aşağıda belirtildiği gibi -
import { NgModule, NO_ERRORS_SCHEMA } from "@angular/core";
import { NativeScriptCommonModule } from "nativescript-angular/common";
import { HomeRoutingModule } from "./home-routing.module";
import { HomeComponent } from "./home.component";
import { NativeScriptFormsModule } from "nativescript-angular/forms";
@NgModule({
imports: [
NativeScriptCommonModule,
HomeRoutingModule,
NativeScriptFormsModule
],
declarations: [
HomeComponent
],
schemas: [
NO_ERRORS_SCHEMA
]
})
export class HomeModule { }
Buraya,
NativeScriptFormsModule, iki yönlü veri bağlamayı etkinleştirir. Aksi takdirde, iki yönlü veri bağlama beklendiği gibi çalışmayacaktır.
Adım 2
Giriş bileşeninin kullanıcı arayüzünü aşağıda verildiği gibi değiştirin -
<ActionBar> <Label text="Home"></Label></ActionBar>
<GridLayout columns="*" rows="auto, auto">
<TextField hint="Username" row='0' column='0' color="gray"
backgroundColor="lightyellow" height="75px" [(ngModel)]='this.user.name'>
</TextField>
<Label [text]='this.user.name' row='1' column='0' height="50px"
textAlignment='center' style='font-size: 16px; font-weight: bold;
margin: 0px 32px 0 25px;'>
</Label>
</GridLayout>
Buraya,
Etiket bileşeninin metin özelliği, tek yönlü veri bağlamayla ayarlanır. Model kullanıcısı güncellenirse, metin özelliği otomatik olarak güncellenir.
TextField bileşeni ngModel'i this.user.name olarak ayarlar. Model kullanıcısı güncellenirse, metin özelliği otomatik olarak güncellenir. Aynı zamanda, kullanıcı TextField'ın değerini değiştirirse, model de güncellenir. Model güncellenirse, Label'ın metin özelliği değişikliklerini de tetikleyecektir. Dolayısıyla, kullanıcı verileri değiştirirse, Label'ın metin özelliğinde gösterilecektir.
Aşama 3
Uygulamayı çalıştırın ve metin kutusunun değerini değiştirmeyi deneyin.
Başvurunun ilk ve son durumu aşağıda belirtildiği gibi benzer olacaktır -
Başlangıç hali
İki yönlü veri bağlama - Başlangıç durumu aşağıda verilmiştir -
Son Durum
İki yönlü veri bağlama - Son durum aşağıda gösterilmiştir -