Buscar..


Escriba código java en nativescript y utilícelo directamente en javascript

Esta es la imagen de la estructura del proyecto en el estudio de Android:

introduzca la descripción de la imagen aquí

Esta es la imagen de la estructura del proyecto del proyecto nativescript:

introduzca la descripción de la imagen aquí

Como veis son iguales. así que podemos escribir código java en nativescript como escribimos en Android Studio.

Queremos agregar Toast a la aplicación predeterminada de nativescript. después de crear un nuevo proyecto nativescript, cree un directorio en el directorio java/org/example como este:

introduzca la descripción de la imagen aquí

cree un nuevo archivo MyToast.java en el directorio de 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();
    }
}

Notas : no olvide el nombre del paquete;

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");
    }
}

ahora cuando presionas el botón se mostrará un brindis;

Notas :

  1. La función showToast acepta el contexto para pasarlo a Toast.makeText y le pasamos un contexto de esta manera: application.android.context
  2. Typescript no sabe qué es org , por lo que lo declare var org:any; : declare var org:any;

usar apis nativos directamente en javascript

Queremos añadir Toast a la aplicación predeterminada 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();
   }
}

para crear brindis debemos llamar a Toast.makeText y está en el paquete android.widget.Toast . Toast.makeText acepta el contexto como primer argumento y podemos obtener el contexto en nativescript de esta manera: application.android.context



Modified text is an extract of the original Stack Overflow Documentation
Licenciado bajo CC BY-SA 3.0
No afiliado a Stack Overflow