مشکلاتی که ممکن میباشد با آن ها مواجه گردید
ممکن میباشد با یک کتابخانه فرد ثالث مواجه گردید که مایحتاج میباشد به‌روزرسانی گردد. برای مثال بعضا اشخاص متوجه گردیده‌اند که ورژن کنونی SqlDelight به یک ورژن دیرین از کتابخانه Room persistence نیاز دارااست. به این ترتیب تقاضای یک به‌روزرسانی کرده‌اند و Square ورژن به‌روز گردیده کتابخانه را عرضه نموده است. در صورتی‌که با اینگونه ایراد‌هایی مواجه شدید، هر چه زودتر از بسط‌دهنده تقاضای به‌روزرسانی بکنید، عالی میباشد. جدیدترین ورژن از Room یعنی ورژن 2.1 هم در حال حاضر مستلزم AndroidX میباشد که احتمالاً سبب ساز شود اکثری از اشخاص این ارتقاء را جاری ساختن دهند. در حین کتابت این نوشته ی علمی Facebook SDK همچنان به‌روز نشده میباشد  طراحی اپلیکیشن در مشهد و این قضیه احتمالاً برای اشخاص متعددی موجب بروز نقص‌ شود.
به‌روزرسانی پروژه به واپسین ورژن از AppCompat ممکن میباشد چندان معمولی نباشد. درین فرآیند ممکن میباشد مشکلاتی در کد شما وجود داشته باشد که از باگ‌های پیشین بر مکان باقی مانده‌اند و یا این که این ارتقاء مستلزم بعضی ویرایش‌های عمده در کد باشد. برای این مسائل می بایست از پیش اپلیکیشن‌ریزی کرده باشید.
پوشه‌های منبع از سوی Jetifier تغییر تحول نمی‌یابند و از این رو ممکن میباشد هنگام استعمال از مستندات مبتلا سردرگمی گردید.
نمی‌اقتدار مطابق ماژول Jetify کرد و از این رو این کار یک فعالیت «کلیه یا این که هیچ» روی کد شما به حساب می آید. این فرآیند احتمالاً موجب توقف فرآیند پیشرفت مداوم پروژه خواهد شد و یا مشکلاتی در طی مخلوط کدهای پیشرفت تولید نماید.
ابزار نگاشت قادر است تعلق‌های آلفا (alpha) برای مثال ConstraintLayout alpha را در کد شما درج نماید.
اندروید استودیو در ارتباط Jetifier اگاهی دارااست و خطاهایی را درین خصوص آرم میدهد. اجرای یک عملیات «Invalidate Cache and Restart» میتواند این اختلال را رفع نماید.
Jetifier کد ساخت‌و‌ساز گردیده را تغییر تحول نمی‌دهد و بدین ترتیب درین خصوص به عمل بیشتری نیاز میباشد.
بعضی از اسم‌های جایگزین به صحت نگاشت نمیشوند (که اکثر آنان به صورت عمده در کتابخانه design قرار دارا‌هستند). ابزار refactor درین مفاد شغل نخواهد کرد و کد شما کامپایل نمیشود. برای حل این اختلال می بایست به صورت دستی ایمپورت‌ها را رسیدگی نمائید. خوشبختانه این ایرادات در طول فرصت به کمترین مقدار رسیده‌اند، زیرا این ابزار به بلوغ رسیده و باگ‌ها در ابزار Reactor اصلاح میگردند.
نکته اثر گذار: قاعده اسم‌گذاری استاندارد در Jetpack به کار گیری از یک نسخه برداری از اسم بسته در خصوصیات Mavem میباشد. در جت‌پک، بسته همواره با groupid یکسان میباشد.
 
برای مثال چنانچه بدانید که اسم بسته «androidx.webkit» بوده میباشد، در این حالت این تعلق به «androidx.webkit:webkit:VERSION» نگاشت گردد.
 
حرف نهایی
از پیشین در زمینه ی تغییرات ما یحتاج ابزار مسافرت به Jetpack استحصال استحضار نمایید. سخت ترین قسمت این افزایش احتمالاً به‌روزرسانی پروژه برای به کار گیری از جدیدترین تعلق‌ها میباشد. ممکن میباشد برخی کتابخانه‌های فرد ثالث هنوز به‌روزرسانی نشده باشند. اساسی میباشد که‌این مورد ها را شناسایی کرده و از توسعه و گسترش‌دهنده تقاضا فرمایید که آنها را به‌روزرسانی نماید.
 
چه طور یک کتابخانه اندروید در React Native بسازیم؟ – راهنمای جامع توسعه یافته
در‌صورتی‌که یک گسترش‌دهنده جاوا اسکریپت باشید و از شما منظور گردد که در قسمت native در فریمورک React Native عمیق گردید، احتمالاً با مشکلاتی مواجه خواهید شد. ما درین نوشته با اکران یک نحوه سهل و آسان برای ساخت و استعمال از کدهای native که میتوانند یک SDK جاوا را به صورت یک کتابخانه کپسوله‌سازی نمایند، نشانه میدهیم که‌این شغل به هیچ عنوان مشقت بار وجود ندارد. مستندات فعال‌سازی و اجرای کدهای native در فریمورک React Native به طور کاملً اثرگذار میباشد. با این وجود گرد هم آوردن کلیه این نصیب‌های گوناگون به طور یک کتابخانه کارآمد، میتواند کاری بحران‌برانگیز و مجال‌بر باشد.
به همین استدلال این ریپازیتوری گیت‌هاب (+) برای یاری به فعال‌سازی و اجرای موردها ما یحتاج برای توسعه و گسترش کتابخانه فراهم گردیده‌است که مشمول موردها پایین میباشد:
 
اجرای یک Promise در جاوا از یک نرم افزار React Native و عوض کردن شرایط بر مبنای سود.
اجرای یک سیاق در جاوا و گوش دادن به یک callback برای جواب (DeviceEventEmitter). این حالت مشابه رفتاری میباشد که هنگام پوشش SDK-های فرد ثالث نیاز داریم.
آزمایش کردن با Jest.
فضا پیشرفت سریع با یک نرم افزار آزمایش.
شایسته ترین منش‌ها از react-native-create-bridge و react-native-create-library.
شایسته ترین شیوه برای ارتقا سرعت پیشرفت یک کتابخانه، این میباشد که آغاز بدین عمل بکنیم. براین اساس پیرو به توضیح نحوه ساخت boilerplate می پردازیم. کد انتهای هر مرحله را میتوانید در‌این ریپو (+) پایین «STEP_NUMBER» ببینید.
 
قدم اولیه – جاوا اسکریپت و ساختار کتابخانه
قبل از هر چیز خوب میباشد تحقیق کنیم که آیا حقیقتاً به یک کتابخانه نیاز داریم یا این که خیر. در شرایطی‌که می خواهید وسعت پایینی از کد native را که رابطه تنگاتنگی با نرم افزار شما دارااست تولید نمائید، سریع‌ترین و شایسته ترین طرز ساخت یک native درون نرم افزار میباشد. به این مراد react-native-create-bridge نقطه آغاز بسیار خیر و خوبی به حساب میآید. ما قصد داریم از کدی که پیرو معرفی خوا هیم کرد به کار گیری کنیم. در صورتی درین خصوص در گیر تردید می باشید، می توانید از همین مسیر فعالیت را استارت فرمایید و از قدم‌های آتی این نوشته الهام گرفته و به رفع خطاها بپردازید. زیرا تبدیل یک ماژول به کتابخانه شغل دشواری وجود ندارد.
 
 
کلیک فرمائید
ما قصد داریم یک کتابخانه جدا از هم تولید کنیم که بتوان در نرم افزار‌های گوناگون از آن به کار گرفت و به احتمال بالا مقادیر بالایی از یک SDK نیتیو را نیز مشتمل بر میگردد. برای مثال یک SDK از سوی مشقت بار‌افزار سفارشی اندروید ارائه میگردد.
 
فعالیت خویش را با ابزار سفارش گردیده از سوی مستندات ری‌اکت نیتیو (+) استارت میکنیم:
 
$ npm install -g react-native-create-library
$ react-native-create-library TestLib
بنابراین مبنا قابل قبولی برای کتابخانه به دست می آوریم، با این وجود، شاید همچنان شم فرمایید که درباره‌ی کیفیت گرد هم آوردن این قسمت‌ها سردرگم میباشید. برای این که‌این مورد پر‌نور گردد، در پی این مرحله قصد داریم روی ساختار کد کتابخانه خویش متمرکز گردیده و یک نرم افزار مثال برای آزمایش ساخت‌و‌ساز کنیم.
 
نرم افزار مثال
ابتدا می بایست یک سری عمل مدیریتی اعمال دهیم. یک فایل به اسم library تولید کرده و کلیه محتوای فایل TestLib را به آن جابجایی میدهیم. بعد از آن فرمان react-native init ExampleApp را برای آزمایش کردن نرم افزار خویش انجام میکنیم.
 
فعلا قادر خواهیم بود کیفیت استعمال از کتابخانه خویش را با کارایی برای تصاحب کردن پاره ای از آن تمجید کنیم. تغییراتی که بایستی در App.js ساخت‌و‌ساز خواهد شد را به دنبال مشاهده میکنید:
 
import RNTest from 'react-native-test-lib’  - کتابخانه ما
state – برای حفظ جواب خالص از کد نیتیو ما.
()getNativeResult که یک تابع ناهمگام میباشد و آغاز state.nativeResult را به طور loading… تهیه و تنظیم می‌نماید و درپی به طور یک اشتباه با پاسخی از Promise به اسم ()RNTest.getValaue انتخاب میشود.
ما در JSX خویش مقدار this.state.nativeResult اکران داده و یک دکمه برای فراخوانی ()getNativeResult اضافه می کنیم.
همینطور می بایست package.json خویش را بازنویسی کنیم تا دربرگیرنده کتابخانه ما که هم فعلا در App.js ایمپورت کردیم باشد و هم پا با آن یک شیوه برای به‌روزرسانی این کتابخانه در هنگام ساخت‌و‌ساز تغییرات داشته باشیم. در‌پی اسکریپت updateLib ماژول‌های گره را حذف کرده و کش را تمیز می‌نماید. آن‌گاه بسته‌های ما مجدداً نصب گردیده و React Native packager استارت میگردد.
 
DEPENDENCY: "react-native-test-lib": "../library"
 
SCRIPT: “updateLib”: “rm -rf node_modules/ && yarn --reset-cache && yarn start”
ولی می‌قدرت این شرایط را فارغ از نیاز به حذف همگی node_modules نیز باصرفه‌سازی کرد. همینطور قابل ذکر میباشد که شما بایستی چنانچه که کد نیتیو تغییر‌و تحول یابد، نرم افزار خویش را rebuild کرده و نصب نمایید.
 
ساخت چارچوب کتابخانه
غرض مهم ما این میباشد که لایه‌های به طور کاملً تعریف و تمجید گردیده‌ای از انتزاع را در تک تک مسیر از Native تا جاوا اسکریپت ساخت‌و‌ساز کنیم. این ساختار نیازمند تأیید این حیث میباشد که تایپ کردن جاوا اسکریپت به کدنویسی جاوا ترجیح دارااست.
 
با در حیث داشتن این قاعده یک فولدر testBridge ساخت و ساز میکنیم که مشمول کلیه کدهای جاوا اسکریپت میباشد.
 
> testBridge
> __tests__ -> Will contain our tests
> bridgeOperations -> Operations available in native
getValue.js -> Calls the getValue native code
index.js -> Defines the bridge and exports operations
> library -> Contains the features of our library
index.js -> Crafts the library API
index.js -> exports our library to the world ?
در صورتیکه توضیح کد فوق را از آخر شروع کنیم، testBridge/bridgeOperations/index یک بریج تمجید می‌نماید که گزینه به کار گیری قرار میدهیم. در این باره NativeModules.RNTestLib اسم بریج میباشد و آن را به تمامی bridgeOperation-ها (مانند getValue) ارسال میکنیم. این‌ها متدهای جاوا میباشند که هریک در فولدر خویش تعریف و تمجید گردیده‌اند. دو برهان برای این مورد وجود دارااست: ابتدا این که قصد داریم از بضاعت مشابه سای بریج برای آزمایش کردن استعمال کنیم و دوم این که نظارت می کنیم در حالتی‌که کد نیتیو متبوع غامض باشد و عملیات به تطهیر نیاز داشته باشد چه فیس می دهد. برای مثال فرض نمائید یک روال جاوا که سیاق callback مجزایی داراست را اعمال کنیم و از DeviceEventEmitter برای ارسال مقدار callback منفعت بگیریم. در‌این‌صورت مطمئناً بسیار خوب میباشد کد کتابخانه یک promise اخذ نماید و با مکانیسم درونی کد نیتیو و emmiter روی داد، رمز و فعالیت نداشته باشد.
 
در‌پی یک API که در testBridge/library/index ساخته شده است را اکسپورت می کنیم و این فولدر ممکن میباشد مشتمل بر تعدادی پوشه باشد که خصوصیت‌های کتابخانه ما مانند الحاق یک سری bridgeOperations به API منزه را ارائه می‌نمایند. از جمله فرض نمایید می خواهید کتابخانه شما یک تابع connect را اکسپورت نماید؛ ولی میخواهید این عمل در دو bridgeOperation به اسم‌های checkPermission و connect جاری ساختن گردد. این به عبارتی جایی میباشد که پوشه‌های اجرایی این عملیات در آن قرار دارا‌هستند. این شرایط در نمودار پایین عده‌بندی گردیده است:
 
 
 
آن چه دراین مکان ساخت کرده‌ایم، سطح های مشخصی از انتزاع از کد نیتیو میباشد. bridgeOperations/ بایستی کارکرد درونی کد نیتیو مارا شعور نماید تا بتواند رابط منزه جاوا اسکریپت را اکسپورت نماید؛ البته library/ جایی میباشد که خصوصیت‌هایی از bridgeOperations ساخت‌و‌ساز می شوند تا API نرم افزار ما آیتم به کار گیری قرار دهد.
 
فعلا شایسته ترین فرصت برای رسیدگی ساختار ماژول و شناخت بی نقص با آن میباشد. شما می توانید نرم افزار مثال را ایفا فرمایید، دکمه را فشار دهید و چشم به راه پاسخی از promise ما به اسم bridgeOperations/getValue.js باشید. همگی چیزهایی که تا این جا نظارت کردیم در شاخه STEP-ONE کد منبع ما قابل مشاهده میباشد.