NativeScript-JavaScript를 사용하는 네이티브 API

이 섹션에서는 자바 스크립트를 사용하여 네이티브 API에 액세스하는 방법에 대해 설명합니다.

마샬링

NativeScript 런타임은 Android 및 iOS 플랫폼 모두에 대한 암시 적 유형 변환을 제공합니다. 이 개념을 마샬링이라고합니다. 예를 들어, NativeScript- iOS paltform은 JavaScript 및 Objective-C 데이터 유형을 비슷하게 암시 적으로 변환 할 수 있으며, Java / Kotlin은 JavaScript 프로젝트 유형 및 값에 쉽게 매핑 될 수 있습니다. 각 유형에서 하나씩 마샬링을 수행하는 방법을 간략하게 이해하겠습니다.

숫자 값

iOS 및 Android 숫자 데이터 유형을 JavaScript 숫자로 쉽게 변환 할 수 있습니다. iOS에서 JavaScript 로의 간단한 숫자 변환은 아래에 정의되어 있습니다.

console.log(`max(7,9) = ${max(7,9)}`);

여기,

기본 max () 함수는 JavaScript 숫자로 변환됩니다.

Android 환경

Java는 byte, short, int, float, double 및 long과 같은 다양한 숫자 유형을 지원합니다. JavaScript에는 숫자 유형 만 있습니다.

아래에 표시된 간단한 Java 클래스를 고려하십시오.

class Demo extends java.lang.Object {
   public int maxMethod(int a,int b) {
      if(a>b) {
         return a;
      } else {
         return b;
      }
   }
}

여기,

위의 코드에는 두 개의 정수 인수가 포함되어 있습니다. 아래와 같이 JavaScript를 사용하여 위의 코드 객체를 호출 할 수 있습니다.

//Create an instance for Demo class 
var obj = new Demo(); 

//implicit integer conversion for calling the above method 
obj.maxMethod(7,9);

문자열

Android 문자열은 java.lang.string에 정의되고 iOS 문자열은 NSSring에 정의됩니다. 두 플랫폼에서 마샬링을 수행하는 방법을 살펴 보겠습니다.

기계적 인조 인간

문자열은 변경 불가능하지만 문자열 버퍼는 변경 가능한 문자열을 지원합니다.

아래 코드는 간단한 매핑의 예입니다.

//Create android label widget 
var label = new android.widget.Label(); 

//Create JavaScript string 
var str = "Label1";  

//Convert JavaScript string into java label.setText(str); 
// text is converted to java.lang.String

Boolean 클래스는 java.lang.Boolean에 정의되어 있습니다. 이 클래스는 객체에서 부울 값을 래핑합니다. 부울을 문자열로 또는 그 반대로 쉽게 변환 할 수 있습니다. 간단한 예는 다음과 같이 정의됩니다.

//create java string 
let data = new java.lang.String('NativeScript'); 

//map java String to JavaScript string, 
let result = data.startsWith('N'); 

//return result 
console.log(result);// true

iOS 환경

NSString 클래스는 변경할 수 없지만 하위 클래스 NSMutableString은 변경할 수 없습니다. 이 클래스에는 문자열 작업을위한 메서드 모음이 포함되어 있습니다. 다음과 같이 선언됩니다-

class NSString : NSObject

아래와 같이 간단한 Objective-c 선언을 고려하십시오.

NSString *str = @"nativescript"; 
//convert the string to uppercase
NSString *str1; 
str1 = [str uppercaseString]; 
NSLog(@"Uppercase String : %@\n", str1 );

NSStrings는 JavaScript 문자열에 쉽게 매핑 될 수 있습니다.

정렬

이 섹션에서는 배열에서 마샬링을 수행하는 방법에 대해 설명합니다. 먼저 iOS 환경의 예를 들어 보겠습니다.

배열 선언

class NSArray : NSObject

여기,

NSArray는 배열이라는 개체의 정렬 된 컬렉션을 관리하는 데 사용됩니다. 정적 배열을 만드는 데 사용됩니다. 하위 클래스NSMutableArray 동적 배열을 만드는 데 사용됩니다.

NSArray 객체는 아래와 같이 배열 리터럴을 사용하여 생성 될 수 있습니다.

let array: NSArray = ["React","Vue","TypeScript"]

이제이 배열을 아래와 같이 JavaScript로 매핑 할 수 있습니다.

//create native array 
let nsArr = NSArray.arrayWithArray("React","Vue","TypeScript"]); 

//create simple javascript array 
let jsArr = ["Hello,World","NativeScript"]; 

//Now compare the two arrays, 
let compare = nsArr.isEqual(jsArr); 
console.log(comapre);

그러면 출력이 거짓으로 반환됩니다.

Android 배열 선언

Java 배열은 java.util.Arrays. 이 클래스에는 배열을 조작하기위한 다양한 메서드가 포함되어 있습니다. 아래에 예가 나와 있습니다.

//javascript array 
let data = [12,45,23,56,34,78,50]; 

//create java array 
let result = ns.example.Math.maxElement(data);
console.log(result);

클래스와 객체

클래스와 객체는 객체 지향 프로그래밍의 기본 개념입니다. 클래스는 사용자 정의 프로토 타입입니다. 개체는 클래스의 인스턴스입니다. 클래스는 한 유형의 모든 개체에 공통적 인 속성 또는 메서드 집합을 나타냅니다. 모바일 개발 환경 모두에 대한 네이티브 클래스와 객체를 이해하겠습니다.

Android 환경

자바 및 Kotlin 클래스에는 전체 패키지 이름으로 표시되는 고유 식별자가 있습니다.

예를 들면

android.view.View− 화면 레이아웃 및 사용자와의 상호 작용을위한 기본 사용자 인터페이스 클래스입니다. 아래와 같이 JavaScript에서이 클래스에 액세스 할 수 있습니다.

const View = android.view.View;

먼저 아래 문을 사용하여 클래스를 가져옵니다.

import android.view.View;

다음으로 아래 주어진 클래스를 만듭니다-

public class MyClass {
   public static void staticMethod(context) {
      //create view instance
      android.view.View myview = new android.view.View(context);
   }
}

위의 동일한 클래스에서 아래 코드를 사용하여 JavaScript 함수에 액세스 할 수 있습니다.

const myview = new android.view.View(context);

마찬가지로 java.lang 패키지 내의 인터페이스, 상수 및 열거에 액세스 할 수 있습니다.

iOS 환경

Objective-C 클래스는 @interface 및 @implementation 두 섹션으로 정의됩니다. 클래스 정의는 키워드로 시작합니다.@interface 다음에 interface(class)이름. Objective-C에서 모든 클래스는 NSObject라는 기본 클래스에서 파생됩니다.

모든 Objective-C 클래스의 수퍼 클래스입니다. Simple Circle 클래스는 아래와 같이 정의됩니다.

@interface Circle:NSObject {
   //Instance variable
   int radius;
}
@end

아래와 같이 하나의 방법으로 클래스를 고려하십시오.

@interface MyClass : NSObject 
+ (void)baseStaticMethod; 
@end

이 클래스는 아래 코드를 사용하여 자바 스크립트로 변환 할 수 있습니다-

function MyClass() { /* native call */ }; 
Object.setPrototypeOf(MyClass, NSObject); 
BaseClass.baseStaticMethod = function () { /* native call */ };

자바 스크립트 instanceof연산자는 객체가 주어진 클래스에서 상속되는지 확인하는 데 사용됩니다. 이것은 다음과 같이 정의 될 수 있습니다-

var obj = MyClass.alloc().init(); // object creation 
console.log(obj instanceof NSObject); //return true

여기,

Objective-C 인스턴스는 alloc, init 또는 new 메서드를 사용하여 생성됩니다. 위의 예에서 아래와 같은 새로운 방법을 사용하여 객체 초기화를 쉽게 만들 수 있습니다.

var obj = MyClass.new();

마찬가지로 정적 메서드 및 속성에 액세스 할 수 있습니다.