Menambahkan dependensi ke Capacitor plugin dapat terasa membingungkan, tetapi lebih mudah ketika dibagi menjadi langkah-langkah yang jelas. Berikut ini yang perlu Anda ketahui:
-
Pahami alat-alat yang digunakan:
-
Konfigurasi lingkungan pengembangan Anda:
- Pasang alat-alat seperti Node.js, npm, Xcode, Android Studio, CocoaPods, dan JDK.
-
Mulai projek plugin Capacitor Anda:
- Gunakan
npm init @capacitor/pluginuntuk membuat plugin baru.
- Gunakan
-
Tambahkan dependensi JavaScript:
- Gunakan
npm installuntuk kebutuhan dependensi produksi dan pengembangan. - Update
package.jsonuntuk mencakup dependensi peer seperti@capacitor/core.
- Gunakan
-
Tangani dependensi spesifik platform:
- iOS: Konfigurasi CocoaPods atau SPM dengan library seperti Alamofire atau SwiftyJSON.
- Android: Gunakan Gradle untuk menambahkan dependensi seperti Gson atau AppCompat.
-
Optimalkan kinerja:
- Pastikan versi, audit dependensi, dan selesaikan konflik untuk memastikan stabilitas.
-
Gunakan alat seperti Capgo untuk pembaruan langsung:
- Sampaikan pembaruan secara instan tanpa tinjauan toko aplikasi.
Perbandingan Cepat Alat:
| Platform | Alat | Contoh Dependensi |
|---|---|---|
| JavaScript | npm | npm install lodash --save |
| iOS | CocoaPods/SPM | pod 'Alamofire', '~> 5.6.4' |
| Android | Gradle | implementation 'com.google.code.gson:gson:2.10.1' |
Mengapa hal ini penting: Mengelola dependensi dengan efektif memastikan plugin Anda berjalan lancar di berbagai platform, menghemat waktu, dan menghindari kesalahan. Mari kita telusuri langkah-langkahnya lebih lanjut.
Cara membuat sebuah Capacitor plugin untuk iOS/Android

Mengatur Lingkungan Pengembangan Anda
Siapkan pengaturan Anda dengan alat-alat yang diperlukan untuk mengelola plugin Capacitor tergantung pada __CAPGO_KEEP_0__ efektif.
Alat Pembangunan yang Diperlukan
Berikut adalah daftar alat yang Anda butuhkan:
| Alat | Versi | Tujuan |
|---|---|---|
| Node.js | 16.0.0+ | lingkungan eksekusi JavaScript |
| npm | 8.0.0+ | Pengelola Paket |
| Xcode | 14.0+ | Pengembangan iOS (Hanya Mac) |
| Android Studio | Electric Eel+ | Pengembangan Android |
| CocoaPods | 1.11.0+ | Pengelolaan Dependensi iOS |
| JDK | 11+ | Alat Pembangunan Android |
Membuat Plugin Baru
Gunakan Capacitor CLI untuk memulai proyek plugin Anda. Ini termasuk mengatur platform dan memberi nama plugin menggunakan format domain terbalik (misalnya com.mycompany.plugin):
- Jalankan perintah berikut:
npm init @capacitor/plugin - Pilih platform target (iOS/Android).
- Berikan nama pada plugin Anda dalam format domain-reversal.
Langkah-Langkah Pengaturan Proyek
-
Perbarui
package.jsonUbah
package.jsonuntuk mencakup hal-hal berikut:{ "capacitor": { "ios": { "src": "ios" }, "android": { "src": "android" } }, "peerDependencies": { "@capacitor/core": "^5.0.0" } } -
Pengaturan Platform-Spesifik
-
Untuk iOS, pastikan Podfile Anda mencakup:
platform :ios, '13.0' use_frameworks! -
Untuk Android, pastikan Anda telah memverifikasi
build.gradlemengandung:android { compileSdkVersion 33 defaultConfig { minSdkVersion 22 } }
-
-
Atur Variabel Lingkungan
Konfigurasi variabel lingkungan berikut untuk alat-alat pengembangan Anda:
Variabel Tujuan Nilai Contoh ANDROID_HOME Lokasi Android SDK /Users/username/Library/Android/sdk JAVA_HOME Alamat instalasi JDK /Library/Java/JavaVirtualMachines/jdk-11.0.12.jdk/Contents/Home XCODE_SELECT Alat Perintah Baris Xcode /Applications/Xcode.app/Contents/Developer
Setelah proyek Anda siap, Anda siap untuk melanjutkan ke pengelolaan dependensi JavaScript.
Dependensi JavaScript
Mengelola dependensi JavaScript secara efektif adalah kunci untuk menjaga kinerja plugin yang stabil.
npm Pemasangan Paket

Untuk memasang dependensi, gunakan perintah-perintah berikut:
# Add a production dependency
npm install lodash --save
# Add a development dependency
npm install @types/lodash --save-dev
Pastikan untuk secara manual menyertakan dependensi peer di package.json file. Uji semua dependensi untuk memastikan konsistensi di kedua platform web dan native.
Mengelola package.json
Contoh berikut ini package.json konfigurasi:
{
"name": "my-capacitor-plugin",
"version": "1.0.0",
"dependencies": {
"lodash": "^4.17.21"
},
"devDependencies": {
"@types/lodash": "^4.14.195",
"@capacitor/core": "^5.0.0"
},
"peerDependencies": {
"@capacitor/core": "^5.0.0"
}
}
Menggunakan versi dependensi yang tepat untuk menjaga konsistensi:
| Jenis Keterbatasan | Contoh | Penggunaan |
|---|---|---|
| Versi Spesifik | ”5.0.0” | Untuk dependensi kritis yang memerlukan versi tertentu |
| Caret | ”^5.0.0” | Mengizinkan pembaruan minor dan patch |
| Tilde | ”~5.0.0” | Mengatur pembaruan hanya untuk patch saja |
Menggunakan Perpustakaan JavaScript
Saat mengimpor perpustakaan, fokus pada mengurangi ukuran bundle:
// Import only the required function
import { isEqual } from 'lodash';
export class MyPlugin {
async compare(options: { value1: any, value2: any }): Promise<boolean> {
return isEqual(options.value1, options.value2);
}
}
Selain itu, pastikan penanganan error dan pengecekan tipe yang tepat:
import { Plugin } from '@capacitor/core';
import { validate } from 'your-validation-library';
@Plugin({
name: 'MyPlugin',
platforms: ['web', 'ios', 'android']
})
export class MyPlugin {
async validateData(data: unknown): Promise<void> {
try {
if (!validate(data)) {
throw new Error('Invalid data format');
}
// Continue processing if valid
} catch (error) {
throw new Error(`Validation failed: ${error.message}`);
}
}
}
Selanjutnya, cari tahu cara mengatasi dependensi platform khusus untuk iOS.
Dependensi iOS
Bagian ini menjelaskan cara mengelola dependensi iOS native dalam Capacitor plugin. Setelah Anda telah mengatur dependensi JavaScript, langkah berikutnya adalah mengatasi dependensi iOS native.
CocoaPods Pengaturan

Mulai dengan menginisialisasi CocoaPods di direktori iOS Anda:
cd ios
pod init
Lalu, update file dengan konfigurasi-konfigurasi berikut: Plugin.podspec Konfigurasi Podfile
Pod::Spec.new do |s|
s.name = 'MyCapacitorPlugin'
s.version = '1.0.0'
s.summary = 'Your plugin description'
s.platform = :ios, '13.0'
s.dependency 'Capacitor'
# Include your iOS dependencies here
s.dependency 'Alamofire', '~> 5.6.4'
end
Menginisialisasi CocoaPods, konfigurasi Podfile untuk mencakup __CAPGO_KEEP_0__ dan library pihak ketiga tambahan lainnya:
After initializing CocoaPods, configure the Podfile to include Capacitor and any additional third-party libraries:
platform :ios, '13.0'
use_frameworks!
def capacitor_pods
pod 'Capacitor', :path => '../../node_modules/@capacitor/ios'
pod 'CapacitorCordova', :path => '../../node_modules/@capacitor/ios'
end
target 'Plugin' do
capacitor_pods
# Add third-party dependencies
pod 'KeychainAccess', '~> 4.2.2'
pod 'SwiftyJSON', '~> 5.0.1'
end
target 'PluginTests' do
capacitor_pods
end
Jenis Keterbatasan
| Contoh | Penggunaan | Versi Pasti |
|---|---|---|
| Ketika kontrol yang tepat diperlukan, seperti untuk komponen keamanan | pod 'KeychainAccess', '4.2.2' | Versi Minor |
| Penggunaan Minor | pod 'Alamofire', '~> 5.6' | For API yang stabil yang mungkin menerima pembaruan patch |
| Versi Utama | pod 'SwiftyJSON', '> 5.0' | Jika fleksibilitas di seluruh pembaruan dapat diterima |
Ketergantungan Paket Swift
Jika Anda lebih suka tidak menggunakan CocoaPods, Manager Paket Swift (SPM) adalah alternatif yang baik. Tambahkan ketergantungan SPM secara langsung di Xcode dengan konfigurasi berikut di file: Package.swift Untuk menggunakan ketergantungan SPM di plugin __CAPGO_KEEP_0__, import mereka dan integrasikan sesuai kebutuhan. Contoh:
// Package.swift
dependencies: [
.package(url: "https://github.com/Alamofire/Alamofire.git", .upToNextMajor(from: "5.6.4")),
.package(url: "https://github.com/SwiftyJSON/SwiftyJSON.git", from: "5.0.1")
]
To use SPM dependencies in your plugin code, import them and integrate as needed. For example:
import Capacitor
import Alamofire
@objc(MyPlugin)
public class MyPlugin: CAPPlugin {
@objc func makeRequest(_ call: CAPPluginCall) {
AF.request("https://api.example.com/data").response { response in
// Process the response
call.resolve([
"data": response.data
])
}
}
}
Ketergantungan Android
Konfigurasi ketergantungan Android untuk memastikan integrasi native yang lancar. Berikut cara mengelola ketergantungan untuk plugin __CAPGO_KEEP_0__ Anda.
Set up Android dependencies to ensure smooth native integration. Here’s how to manage dependencies for your Capacitor plugin.
Ketergantungan __CAPGO_KEEP_0__

Tambahkan konfigurasi berikut ke file Anda: build.gradle file:
android {
defaultConfig {
minSdkVersion 22
targetSdkVersion 33
}
}
dependencies {
implementation "androidx.appcompat:appcompat:1.6.1"
implementation "com.google.code.gson:gson:2.10.1"
implementation "org.jetbrains.kotlin:kotlin-stdlib:1.8.20"
implementation project(':capacitor-android')
}
Tentukan versi tambahan di: buildscript block:
buildscript {
ext {
androidxCoreVersion = '1.10.1'
kotlinVersion = '1.8.20'
}
}
Setelah ketergantungan dikonfigurasi, pastikan untuk mengatur repositori yang diperlukan.
Konfigurasi Repositori
Pada level proyek Anda, build.gradletermasuk repositori Maven yang diperlukan:
allprojects {
repositories {
google()
mavenCentral()
maven { url "https://jitpack.io" }
}
}
Jika Anda menggunakan repositori Maven kustom atau pribadi, tambahkan kredential seperti ini:
maven {
url "https://maven.example.com/releases"
credentials {
username = project.findProperty("mavenUsername") ?: System.getenv("MAVEN_USERNAME")
password = project.findProperty("mavenPassword") ?: System.getenv("MAVEN_PASSWORD")
}
}
Dengan repositori yang diatur, alihkan masalah ketergantungan yang mungkin timbul.
Pengaturan Kompatibilitas
Untuk mengatasi konflik dependensi, terapkan resolusi versi pada build.gradle:
configurations.all {
resolutionStrategy {
force "org.jetbrains.kotlin:kotlin-stdlib:1.8.20"
force "androidx.core:core-ktx:1.10.1"
}
}
Berikut adalah strategi untuk menyelesaikan masalah dependensi umum:
| Tipe Masalah | Strategi | Contoh |
|---|---|---|
| Konflik Versi | Teguhkan versi tertentu | force 'com.google.code.gson:gson:2.10.1' |
| Banyak Versi | Eksklusi Modul | exclude group: 'org.json', module: 'json' |
| Masalah Transitif | Gunakan versi ketat | strictly 'androidx.core:core-ktx:1.10.1' |
Misalnya, Anda dapat menghapus modul yang bersaing seperti ini:
dependencies {
implementation('library:name:1.0.0') {
exclude group: 'com.conflicting.dependency'
}
}
Terakhir, optimalkan proses pembangunan Anda dengan mengaktifkan caching dan eksekusi paralel di gradle.properties:
org.gradle.caching=true
org.gradle.parallel=true
org.gradle.jvmargs=-Xmx2048m
Capgo Pengintegrasian

Menggunakan Capgo bersama dengan pengelolaan dependensi native dan JavaScript membuat memperbarui plugin Anda lebih cepat dan lebih mudah.
Tentang Capgo
Capgo adalah platform update hidup yang dirancang untuk plugin dan aplikasi Capacitor . Dengan lebih dari 23,5 juta update yang disampaikan melalui 750 aplikasi produksi [1], Capgo memungkinkan pengembang untuk memperbarui dependensi dan code secara instan - tidak ada review aplikasi toko yang diperlukan. Update dijamin dengan enkripsi akhir-ke-akhir dan memenuhi standar kelayakan Apple dan Android.
Fitur Update Capgo
Capgo memudahkan mengelola dependensi plugin dengan fitur-fitur berikut:
| Fitur | Apa yang Dilakukan | Indikator Utama |
|---|---|---|
| Update Sederhana | Push update dalam menit | 95% tingkat update pengguna dalam 24 jam |
| Update Parcial | Unduh hanya file yang berubah | 434ms waktu respons rata-rata API |
| Pengendalian Versi | Kelola versi yang berbeda | 82% tingkat kesuksesan global |
| Sistem Saluran | Targetkan kelompok pengguna spesifik | Supports multiple deployment channels |
Sumber: [1]
Capgo berjalan lancar dengan alat CI/CD seperti GitHub Actions, GitLab CI, dan Jenkins, mengautomatisasi pembaruan dependensi dan memastikan versi plugin yang konsisten. Alat-alat ini membuat lebih mudah untuk mengintegrasikan Capgo ke dalam alur kerja Anda.
Mengatur Capgo
Ikuti langkah-langkah ini untuk mengintegrasikan Capgo ke dalam proyek Anda:
-
Instal Capgo CLI
Jalankan perintah berikut di terminal Anda:
npx @capgo/cli init -
Mengatur Preferensi Pembaruan
Gunakan dashboard Capgo untuk mengatur saluran pengiriman dan preferensi. Konfigurasi yang di-host di awan dan sendiri-hosted juga didukung.
-
Tambahkan Logika Pembaruan
Tambahkan code ke file plugin utama Anda untuk mengaktifkan pembaruan:
import { Capgo } from '@capgo/capacitor-updater'; // Initialize Capgo const capgo = new Capgo({ appId: 'YOUR_APP_ID', channel: 'production' }); // Check for updates await capgo.checkForUpdate();
“Kami menerapkan pengembangan berkelanjutan dan @Capgo sangat kritis dalam menyampaikan secara terus-menerus kepada pengguna kami!” - Rodrigo Mantica
Capgo juga menyediakan dashboard analitis untuk mendapatkan wawasan waktu nyata tentang tingkat kesuksesan pembaruan dan aktivitas pengguna. Fitur seperti rollback satu-klik dan pengawasan kesalahan membantu menyelesaikan masalah dengan cepat, sehingga pembaruan plugin Anda berjalan lancar.
Kesimpulan
Ulasan Proses
Mengelola dependensi untuk plugin Capacitor melibatkan menyelaraskan komponen native (iOS dan Android) dengan lawan JavaScriptnya untuk memastikan integrasi yang lancar. Proses ini melibatkan pengaturan spesifik platform dan mengelola paket JavaScript untuk mencapai kinerja yang optimal. Mengikuti langkah-langkah yang diuraikan akan membantu menjaga fungsi plugin yang stabil dan efisien.
Praktik Terbaik
Mengelola dependensi dengan efektif memerlukan praktek-praktek berikut:
| Praktik | Manfaat | Cara Mengimplementasikan |
|---|---|---|
| Penguncian Versi | Menghindari masalah yang tidak terduga | Gunakan versi yang tetap untuk package.json |
| Pengisolasi Platform | Mengurangi konflik | Ketergantungan Native Terpisah |
| Pembaruan Teratur | Meningkatkan Keamanan | Menggunakan Perbaikan Kritis Secara Cepat |
| Audit Ketergantungan | Mendeteksi Risiko | Jalankan npm audit Sering |
Menggunakan alat pembaruan waktu nyata seperti Capgo dapat memudahkan dan meningkatkan praktik-praktik ini dengan memungkinkan pembaruan waktu nyata.
Capgo Manfaat
Capgo mempersederhanakan proses manajemen dependensi sambil menawarkan kinerja yang kuat. Ia mencapai kinerja pembaruan pengguna yang impresif sebesar 95% dalam waktu 24 jam, dan mempertahankan waktu respons global Capgo sebesar 434ms. Dengan enkripsi ujung-ke-ujung, ia menjamin pembaruan yang aman yang sesuai dengan pedoman Apple dan Android. Untuk tim yang mengelola versi plugin yang berbeda-beda, sistem kanal Capgo memungkinkan peluncuran yang sasaran untuk kelompok pengguna tertentu. Sekitar 95% pengguna melakukan pembaruan dalam waktu 24 jam. dan mempertahankan waktu respons global API sebesar 434ms. Dengan enkripsi ujung-ke-ujung, ia menjamin pembaruan yang aman yang sesuai dengan pedoman Apple dan Android. [1]Berikut adalah gambaran cepat tentang kinerja Capgo:
Here’s a quick look at Capgo’s performance:
| Nilai | Waktu Respons Global __CAPGO_KEEP_0__ |
|---|---|
| Global API Response Time | Sukses Pembaruan |
| Kinerja Pembaruan Pengguna (24 Jam) | 82% |
| Sekitar 95% | 95% |
Teruskan dari Cara Menambahkan Dependensi di Capacitor Plugin
Jika Anda menggunakan Cara Menambahkan Dependensi di Capacitor Plugin untuk merencanakan pekerjaan plugin native, hubungkannya dengan Capgo Direktori Plugin untuk alur kerja produk di Capgo Direktori Plugin, Capacitor Plugin oleh Capgo untuk detail implementasi di Capacitor Plugin oleh Capgo, Menambahkan atau Mengupdate Plugin untuk detail implementasi di Menambahkan atau Mengupdate Plugin, Alternatif Plugin Enterprise Ionic untuk alur kerja produk di Alternatif Plugin Enterprise Ionic, dan Pembangunan Native Capgo untuk alur kerja produk di Pembangunan Native Capgo.