Поиск…


Напишите код Java в nativescript и используйте его непосредственно в javascript

Это образ структуры проекта в студии Android:

введите описание изображения здесь

Это образ проектной структуры проекта nativescript:

введите описание изображения здесь

Как видите, они такие же. поэтому мы можем написать код Java в nativescript, как мы пишем в android studio.

Мы хотим добавить Toast к стандартным приложениям nativescript. после создания нового проекта nativescript создайте каталог java/org/example например:

введите описание изображения здесь

создать новый файл MyToast.java в каталоге example ;

MyToast.java:

package org.example;

import android.widget.Toast;
import android.content.Context;


public class MyToast{

    public static void showToast(Context context,String text ,String StrDuration ){
      int duration;
      switch (StrDuration){
          case "short":
              duration = Toast.LENGTH_SHORT;
              break;
          case "long":
              duration = Toast.LENGTH_LONG;
              break;
      }
        Toast.makeText(context,text, Toast.LENGTH_SHORT).show();
    }
}

Примечания : не забудьте имя пакета;

app.component.ts:

import {Component} from "@angular/core";
let application = require("application");

declare var org:any;
@Component({
    selector: "my-app",
    templateUrl: "app.component.html",
})
export class AppComponent {
    public counter: number = 16;

    public get message(): string {
        if (this.counter > 0) {
            return this.counter + " taps left";
        } else {
            return "Hoorraaay! \nYou are ready to start building!";
        }
    }

    public onTap() {
        this.counter--;
        org.example.MyToast.showToast(application.android.context,"You pressed the button","short");
    }
}

теперь, когда вы нажимаете кнопку, вы увидите тост;

Примечания :

  1. Функция showToast принимает контекст для передачи его Toast.makeText и мы передали ему контекст таким образом: application.android.context
  2. typescript не знает, что такое org , поэтому мы объявили его: declare var org:any;

использовать собственный apis прямо в javascript

Мы хотим добавить Toast в приложение nativescript по умолчанию.

import {Component} from "@angular/core";
let application = require("application");

declare var android:any;

@Component({
    selector: "my-app",
    templateUrl: "app.component.html",
})
export class AppComponent {
    public counter: number = 16;

    public get message(): string {
        if (this.counter > 0) {
            return this.counter + " taps left";
        } else {
            return "Hoorraaay! \nYou are ready to start building!";
        }
    }

    public onTap() {
        this.counter--;
        this.showToast("You pressed the button","short");
    }



    public showToast(text:string ,StrDuration:string ):void{
      let duration:number;
      switch (StrDuration){
          case "short":
              duration = android.widget.Toast.LENGTH_SHORT;
              break;
          case "long":
              duration = android.widget.Toast.LENGTH_LONG;
              break;
      }    
        android.widget.Toast.makeText(application.android.context,text, android.widget.Toast.LENGTH_SHORT).show();
   }
}

для создания тоста мы должны назвать Toast.makeText и он находится в пакете android.widget.Toast . Toast.makeText принимает контекст как первый аргумент, и мы можем получить контекст в nativescript таким образом: application.android.context



Modified text is an extract of the original Stack Overflow Documentation
Лицензировано согласно CC BY-SA 3.0
Не связан с Stack Overflow