NativeScript - widżety

NativeScript zapewnia duży zestaw składników interfejsu użytkownika i są nazywane „widżetami”. Każdy widżet ma specjalne zadanie i zawiera zestaw metod. W tej sekcji omówimy szczegółowo widżety NativeScript.

Przycisk

Przycisk jest komponentem do wykonywania akcji zdarzenia dotknięcia. Gdy użytkownik naciśnie przycisk, wykonuje odpowiednie czynności. Jest zdefiniowany poniżej -

<Button text="Click here!" tap="onTap"></Button>

Dodajmy przycisk w naszej aplikacji BlankNgApp, jak poniżej -

Krok 1

Otworzyć src\app\home\home.component.html. To jest strona projektowania interfejsu użytkownika naszego komponentu domowego.

Krok 2

Dodaj przycisk wewnątrz GirdLayoutskładnik. Kompletny kod jest następujący -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<GridLayout> 
   <button text="Click Here!"></button> 
</GridLayout>

Wynik

Poniżej znajduje się wyjście przycisku -

Krok 3

Możemy stylizować przycisk za pomocą CSS, jak określono poniżej -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<GridLayout> 
   <button text="Click Here!" class="-primary"></button> 
</GridLayout>

Tutaj -primary klasa jest używana do reprezentowania przycisku głównego.

Wynik

Poniżej znajduje się wynik ButtonPrimary -

Krok 4

NativeScript udostępnia opcję sformatowania, aby zapewnić niestandardowe ikony na przycisku. Przykładowy kod jest następujący -

<GridLayout> 
   <Button class="-primary"> 
      <FormattedString> 
         <Span text="&#xf099;" class="fa"></Span> 
         <Span text=" Button.-primary with icon"></Span> 
      </FormattedString> 
   </Button> 
</GridLayout>
.fa {
   font-family: "FontAwesome", "fontawesome-webfont";
}

Tutaj,

& # xf099 określa położenie ikony w czcionce FontAwesome. Pobierz najnowszą czcionkę Font Awesome i umieść plik fontawesome-webfont.ttf w folderze src \ fonts.

Wynik

Poniżej znajduje się wynik ButtonPrimary -

Krok 5

Zaokrąglony przycisk można utworzyć za pomocą poniższej składni -

<Button text="Button.-primary.-rounded-sm" class="-primary -rounded-sm"></Button>

Wynik

Poniżej znajduje się wyjście ButtonPrimary -

Etykieta

Składnik Label służy do wyświetlania tekstu statycznego. Zmień stronę główną jak poniżej -

<GridLayout> 
   <Label text="NativeScript is an open source framework for creating native iOS and Android apps in TypeScript or JavaScript." textWrap="true">
   </Label> 
</GridLayout>

Tutaj textWrap zawija zawartość etykiety, jeśli etykieta wykracza poza szerokość ekranu.

Wynik

Poniżej znajduje się wynik działania Label -

Pole tekstowe

Komponent TextField służy do pobierania informacji od użytkownika. Zmieńmy naszą stronę główną, jak określono poniżej -

<GridLayout> 
   <TextField hint="Username" 
      color="lightblue" 
      backgroundColor="lightyellow" 
      height="75px">
   </TextField> 
</GridLayout>

Tutaj,

  • kolor reprezentuje kolor tekstu

  • backgroundColor reprezentuje tło pola tekstowego

  • wysokość reprezentuje wysokość pola tekstowego

Wynik

Poniżej znajduje się wynik pola tekstowego -

Widok tekstu

Składnik TextView służy do pobierania wielowierszowej zawartości tekstowej od użytkownika. Zmieńmy naszą stronę główną, jak określono poniżej -

<GridLayout> 
   <TextView loaded="onTextViewLoaded" hint="Enter text" returnKeyType="done" autocorrect="false" maxLength="100"> 
   </TextView> 
</GridLayout>

Tutaj maxLength reprezentuje maksymalną długość akceptowaną przez TextView .

Wynik

Poniżej znajduje się wynik działania TextView -

SearchBar

Ten komponent służy do wyszukiwania wszelkich zapytań lub przesyłania dowolnego żądania. Jest zdefiniowany poniżej -

<StackLayout> 
   <SearchBar id="bar" hint="click here to search ..."></SearchBar> 
<StackLayout>

Możemy nakładać style -

<StackLayout> 
   <SearchBar id="bar" hint="click here to search ..." color="green" backgroundColor="green"></SearchBar> 
</StackLayout>

Poniżej znajduje się wynik SearchBarStyle -

Przełącznik

Przełącznik opiera się na przełączaniu do wyboru między opcjami. Stan domyślny to fałsz. Jest zdefiniowany poniżej -

<StackLayout> 
   <Switch checked="false" loaded="onSwitchLoaded"></Switch> 
</StackLayout>

Dane wyjściowe dla powyższego programu pokazano poniżej -

Suwak

Suwak to element przesuwny służący do wybierania zakresu liczbowego. Jest zdefiniowany poniżej -

<Slider value="30" minValue="0" maxValue="50" loaded="onSliderLoaded"></Slider>

Dane wyjściowe dla powyższego programu podano poniżej -

Postęp

Widżet postępu wskazuje postęp operacji. Bieżący postęp jest przedstawiony w postaci paska. Jest zdefiniowany poniżej -

<StackLayout verticalAlign="center" height="50"> 
   <Progress value="90" maxValue="100" backgroundColor="red" color="green" row="0"></Progress>
</StackLayout>

Poniżej znajduje się wyjście widżetu Postęp -

ActivityIndicator

ActivityIndicator pokazuje zadanie w toku. Jest zdefiniowany poniżej -

<StackLayout verticalAlign="center" height="50"> 
   <ActivityIndicator busy="true" color="red" width="50" 
   height="50"></ActivityIndicator> 
</StackLayout>

Poniżej znajduje się dane wyjściowe dla ActivityIndicator -

Wizerunek

Widżet obrazu służy do wyświetlania obrazu. Można go załadować za pomocą adresu URL „ImageSource”. Jest zdefiniowany poniżej -

<StackLayout class="m-15" backgroundColor="lightgray">
   <Image src="~/images/logo.png" stretch="aspectFill"></Image> 
</StackLayout>

Dane wyjściowe dla Widżetu obrazu są pokazane poniżej -

WebView

WebView wyświetla strony internetowe. Strony internetowe można ładować za pomocą adresu URL. Jest zdefiniowany poniżej -

<WebView row="1" loaded="onWebViewLoaded" id="myWebView" src="http://www.google.com"></WebView>

Dane wyjściowe dla powyższego kodu są pokazane poniżej -

DatePicker

Składnik DatePicker służy do wybierania daty. Jest zdefiniowany poniżej -

<StackLayout class="m-15" backgroundColor="lightgray"> 
   <DatePicker year="1980" month="4" day="20" verticalAlignment="center"></DatePicker> 
</StackLayout>

Dane wyjściowe składnika DatePicker są pokazane poniżej -

TimePicker

Składnik TimePicker służy do wybierania czasu. Jest zdefiniowany poniżej -

<StackLayout class="m-15" backgroundColor="lightgray"> 
<TimePicker hour="9" 
   minute="25" 
   maxHour="23" 
   maxMinute="59" 
   minuteInterval="5"> 
</TimePicker> 
</StackLayout>

Poniżej znajduje się dane wyjściowe komponentu TimePicker -