<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
    <channel>
        <title>نوشته های امیرحسن امیرماهانی</title>
        <link>https://virgool.io/feed/@hasanm08</link>
        <description>برنامه نویس فلاتر و علاقه مند به ماشین لرنینگ</description>
        <language>fa</language>
        <pubDate>2026-06-16 23:02:32</pubDate>
        <image>
            <url>https://files.virgool.io/upload/users/248337/avatar/aUEF65.png?height=120&amp;width=120</url>
            <title>امیرحسن امیرماهانی</title>
            <link>https://virgool.io/@hasanm08</link>
        </image>

                    <item>
                <title>فراتر از پلتفرم ها</title>
                <link>https://virgool.io/cheyab-blog/%D9%81%D8%B1%D8%A7%D8%AA%D8%B1-%D8%A7%D8%B2-%D9%BE%D9%84%D8%AA%D9%81%D8%B1%D9%85-%D9%87%D8%A7-hwnhbq0ckpp5</link>
                <description>در این مطلب از منبع زیر استفاده شده است https://academind.com/learn/flutter/react-native-vs-flutter-vs-ionic-vs-nativescript-vs-pwa/ از دغدغه های کسب و کارهای جدید و یا استارتاپی توسعه کسب و کار در بین کاربران مختلف با دستگاه های متفاوت و سیستم عامل های مختلف استصاحبان این کسب و کارها دو راه دارندچندین بار توسعه نرم افزارشان به ازای هر پلتفرم استفاده از ابزار های کراس پلتفرم در راه اول علاوه بر هزینه بیشتر ? چالش های ویرایش و یا تغییر نسخه های مختلف نرم افزار وجود دارد که به هیچ وجه توصیه نمیشودپس تنها راه باقی مانده استفاده از ابزارهای کراس پلتفرم (چند سکویی) است که در این مطلب تنها به مقایسه سه ابزار میپردازیمFlutterReact NativeIonicاولین عامل مقایسه را میتوان زبان پایه این ابزارها دانست زبان دارت (Dart) پایه فریمورک یا کیت توسعه نرم افزار (SDK) فلاتر است که توسط شرکت گوگل معرفی و عرضه شده است. این زبان کاملا قابل ترجمه(compile) به کد محلی(native code) برای تمامی پلتفرم هاست.زبان جاوا اسکریپت(Js) و کتابخانه React پایه فریمورک ریکت نیتیو است. لازم به ذکر است که این زبان و فریمورک توسط شرکت فیسبوک توسعه داده میشود. درمورد ایونیک کمی ماجرا فرق دارد این ابزار برپایه js+html+css است که برای توسعه وب استفاده میشود و از نسخه 4 میتوان از کامپوننت های فریمورک ها توسعه فرانت وب برای ظاهر سازی آن استفاده کرد هرچند که شرکتی به بزرگی مانند گوگل یا فیسبوک حامی آن نیست. دومین عامل سازگاری کد با پلتفرم های مختلف استمقایسه سازگاری ابزار ها با سطح محلی1. ایونیک : سازگاری کد با پلتفرم های مختلف عالی مفهوم &quot;برنامه مبتنی بر وب&quot; تضمین می کند که می توانید به راحتی از کد خود مجددا  استفاده کنید - شما در پایان فقط یک برنامه مبتنی بر وب می سازید. کتابخانه ی عالی کامپوننت هایی از اجزای سازگار (که بطور خودکار برای پلتفرمی که برنامه در آن اجرا می شود طراحی شده است) نیز به این موضوع کمک می کند.2.فلاتر:سازگاری کد با پلتفرم های مختلف عالی (ولی کمتر از ایونیک)به کمک ساختار ویجت (widget) محور فلاتر سازگاری بالایی با پلتفرم ها دارد بعلاوه اینکه برای ظاهر ios نیز ابزارهایی دارد که باعث افزایش کدنویسی به نسبت ایونیک میشود3.ریکت نیتیو : سازگاری متوسط (کمی کمتر از متوسط)با وجود اینکه به کد محلی ترجمه میشود ولی به دلیل وجود کامپوننت های پایه کمتر و اجبار توسعه دهنده به ویرایش زیاد کامپوننت ها سازگاری کمی دارد.هرچند با وجود کتابخانه هایی کار باآن آسان تر شده است.سومین عامل مقایسه سرعت یادگیری استسرعت یادگیری ابزارها در مقایسه با سطح محلیدراین مقایسه همه ابزار ها تقریبا در یک سطح هستند هرچندکه نیاز به کمی  تغییرات آن ها را متفاوت ساخته است چهارمین عامل کامپوننت های آماده استکامپوننت های آماده ابزار ها در مقایسه با سطح محلی ایونیک در هسته خود مجموعه بزرگی از اجزای از پیش ساخته است. کامپایلر /تولچین ای که یک برنامه محلی را به همراه دارد ،با بخشی از پکیج Ionic (از طریق CLI آن ) و به کمک  پکیج های دیگری مانند Cordova یا Capacitor مؤلفه های ارائه شده توسط Ionic به طور خودکار با پلت فرم برنامه اجرا می شود و بنابراین ، Ionic ایجاد برنامه های زیبا و بومی را به آب خوردن تبدیل می کند!فلاتر به کمک Material-style , Cupertino-style کامپوننت یا ویجت های زیادی برای توسعه دهندگان آماده کرده است تا براحتی بتوانند ظاهر کاربری زیبا طراحیکنند.در ریکت نیتیو درصدی از کامپوننت ها طراحی شده اند اما علاوه بر اینکه نیاز به ویرایش دارند تطبیق پذیر نیستند و این دو باعث شده است تا در سطح پایینی باشدپنجمین عامل اکوسیستم استبه این معنا که یافتن جواب سوالات و یا کتابخانه های مورد نیاز چقدر راحت استمقایسه اکوسیستم ابزار ها با سطح محلیایونیک به خاطر جامعه بزرگ جاوا اسکریپت و به کمک جامعه بزرگ انگولار که با ان میتوان ایونیک را توسعه داد بسیار اکوسیستم بزرگی دارد و با استفاده از ابزار npm دسترسی به کتابخانه های زیادی را فراهم کرده است.فلاتر همانگونه که از بحث ها در سایت StackOverFlow مشخص است با وجود جوان بودن به طور چشم گیری در حال رشد است  و با استفاده از pub دسترسی به کتابخانه های زیادی را فراهم کرده استریکت نیتیو نیز به لطف جاوا اسکریپت جامعه و کتابخانه های بزرگ و زیادی دارد اما نکته منفی این است که شما اغلب باید به اکوسیستم تکیه کنید ، زیرا تنها ویژگی های اصلی در خود React Native گنجانده شده است.ششمین عامل محبوبیت استمقایسه محبوبیت ابزار ها در مقایسه با سطح محلیاگر در این مرحله مقدار محبوبیت هر ابزار را در سایت گیتهاب را شاخص در نظر بگیریمریکت نیتیو با 80 هزار استار در رتبه اولفلاتر با 72 هزار استار در رتبه دومو ایونیک با 39 هزار استار در رتبه سوم استهفتمین عامل پرفورمنس یا بازدهی مناسب استمقایسه بازدهی با سطح محلیبه دلیل ساختار مبتنی بر وب ایونیک بدترین پرفورمنس و بازدهی را داردفلاتر و ریکت نیتیو با توجه به ترجمه شدن به سطح محلی تفاوت چندانی ندارند ولی نحوه عملکرد ان ها در کاربردها و دستگاه های متفاوت باعث شده که دقیقا یک امتیاز نداشته باشندهشتمین عامل دسترسی به ویژگی های محلی استمقایسه دسترسی ابزارها با سطح محلیایونیک به خاطر ساختار مبتنی بر وبی که دارد به سطح بسیار محدودی از ویژگی ها دسترسی دارد هرچند که به ویژگی های رایجی مثل دوربین دسترسی داردتیم فلاتر در طی یک سال اخیر پکیج های خوبی را برای اتصال به ویژگی های محلی توسعه داده اند با اینهمه شما میتوانید مستقیما به کمک زبان های جاوا و سوییفت به ویژگی ها دسترسی یابیدبرای ریکت نیتیو به لطف محوبیبت بالا نیز پکیج های زیادی موجود است اما نکته منفی اینست که هسته اصلی ممکن است با پکیج ها سازگار نباشدنهمین عامل کاربرد جهانی استمقایسه سطح برنامه های نوشته شده با هر ابزار ایونیک توسط کسب کارهای کوچک و زود بازده بیشتر استفاده شده است هرچند که دلیلی بر استفاده در اپ های بزرگ نیست نمونه اپ های پیاده سازی شده با ایونیک2. بر خلاف به نسبت جوان بودن فلاتر توسط برنامه های بزرگی استفاده شده است.نمونه اپ های پیاده سازی شده با فلاتر3. ریکت نیتیو توسط کمپانی های بزرگ تری استفاده شده است هرچند که مهاجرت کمپانی های بزرگی مانند AirBnB ازین ابزار کمی امتیاز ان را کاهش میدهدنمونه اپ های پیاده سازی شده با ریکت نیتیوبا تمام مقایسه های بالا در آخر باید گفت هر سه این ابزار ها قوی و قدرتمند اند و اینکه شما بعنوان برنامه نویس به سمت کدام میروید کاملا به سلیقه خودتان مربوط استدر اخر نیاز دانستم که نمودار علاقه مندی افراد به این سه ابزار را مبتنی بر جستجوی یک سال اخیر مردم ایالات متحده قرار دهماین نمودار در لینک زیر قابل دسترسی است https://stackshare.io/stackups/flutter-vs-ionic-vs-react-nativeبا تشکر از شما بابت خواندن این مطلب علاقه مندم که نظرات شما را نیز بدانم بخصوص راجب ابزارهایی که در این مطلب بررسی نشد ?✌</description>
                <category>امیرحسن امیرماهانی</category>
                <author>امیرحسن امیرماهانی</author>
                <pubDate>Fri, 21 Aug 2020 19:09:38 +0430</pubDate>
            </item>
                    <item>
                <title>چگونه از پروژه کنونی فلاترمان خروجی وب بگیریم؟</title>
                <link>https://virgool.io/mobit-eng/%DA%86%DA%AF%D9%88%D9%86%D9%87-%D8%A7%D8%B2-%D9%BE%D8%B1%D9%88%DA%98%D9%87-%DA%A9%D9%86%D9%88%D9%86%DB%8C-%D9%81%D9%84%D8%A7%D8%AA%D8%B1%D9%85%D8%A7%D9%86-%D8%AE%D8%B1%D9%88%D8%AC%DB%8C-%D9%88%D8%A8-%D8%A8%DA%AF%DB%8C%D8%B1%DB%8C%D9%85-nz8qx9cnlivs</link>
                <description>خروجی وب فلاتر در حال حاظر بصورت بتا عرضه شده است ولی ممکن است دوست داشته باشید برای تست یک پروژه وب داشته باشید در اینصورت دوراه پیش روی شماست1 ایجاد یک پروژه جدید2 گرفتن خروجی وب از پروژه کنونیاین دو حالت مراحل اولیه یکسانی دارند که به شرح زیر میباشدتوصیه میکنم در این مرحله به محل sdk فلاتر خود رفته و با zip کردن ان به نحوی یک نسخه پشتیبان تهیه کنید(  در این نوشته فرض شده که شما فلاتر را کاملا نصب کرده اید و از تحریم عبور کرده اید :)   )سپس با باز کردن ترمینال (یا cmd ) دستورات زیر را به ترتیب وارد کنیدflutter channel beta (تغییر چنل فلاتر به نسخه بتا)flutter upgrade (دریافت اخرین نسخه ی چنل بتا ی فلاتر )flutter config --enable-web( فعال کردن نسخه وب)flutter doctor -v (اطمینان از سلامت sdk فلاتر)flutter devices (مشاهده دستگاه های قابل موجود که کروم باید قابل مشاهده باشد)حال به یک دو راهی میرسیم که پروژه موجود است یا خیر اگر پروژه موجود نیست از کامند زیر برای ساخت پروژه استفاده کنیدflutter create project_nameو اگر موجود است به پوشه پروژه رفته و از کامند زیر استفاده کنید (بهتر است یک نسخه پشتیبان تهیه کنید!!!!)(flutter create .(dotسپس شما یک پروژه فلاتری در چنل بتا دارید که با کامندflutter runمیتوانید روی مرورگر یا گوشی اجرا کنیددر  صورتی که میخواهید کد را روی یک هاست و دامنه فعال ببرید نیاز است تا از کامند زیر استفاده نماییدflutter build web --releaseو به پوشه web داخل محل پروژه رفته و تمامی فایل هارا روی هاست قرار دهیدنکات قابل توجه :1. برخی از پکیج ها ممکن است با نسخه وب سازگار نباشند که لازم است در سایت pub.dev چک شود2. این خروجی وب خروجی بتاست پس اگر مشکلی مشاهده کردید نا امید نشده و منتظر نسخه نهایی بمانید :)نمونه خروجی : hasanm08.github.io</description>
                <category>امیرحسن امیرماهانی</category>
                <author>امیرحسن امیرماهانی</author>
                <pubDate>Sat, 15 Aug 2020 16:59:42 +0430</pubDate>
            </item>
            </channel>
</rss>