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();
마찬가지로 정적 메서드 및 속성에 액세스 할 수 있습니다.