More proof you need to use Expo...

Поделиться
HTML-код
  • Опубликовано: 27 янв 2025

Комментарии • 364

  • @Smongo412
    @Smongo412 11 месяцев назад +227

    Why are we acting like expo is not react native?

    • @TechnoDelight
      @TechnoDelight 7 месяцев назад +23

      Views

    • @SK-yb7bx
      @SK-yb7bx 7 месяцев назад

      For one good reason, it isn't

    • @LungeloNgcemu
      @LungeloNgcemu 6 месяцев назад +1

      lol..thats a good question

    • @TADevelopment
      @TADevelopment 5 месяцев назад +11

      Right. This video Should be named ‘moving off React-Native-CLI’

    • @yewo.m
      @yewo.m 4 месяца назад +2

      Clickbait, as always

  • @GaborGubicza
    @GaborGubicza Год назад +232

    I'm a 36 year old Hardware Engineer with a lot of PCB design and robotics experience, in October I decided to start learning software development: JS, at first now looking into React, React Native, I came across expo a few weeks ago, but now I'm convinced to invest more energy into it.
    Thanks, these videos are extremely helpful.
    Happy new year to everyone.

    • @sugaith
      @sugaith Год назад +3

      dont do it

    • @RaZziaN1
      @RaZziaN1 Год назад +6

      Don't do it, native is total mess, even bigger than react itself.

    • @sshet24
      @sshet24 Год назад +3

      You are lucky to reach this channel so early on in your new career!

    • @emptybottle1200
      @emptybottle1200 Год назад +3

      ​@@RaZziaN1i think it's more healthy if u have a point why it is a total mess.

    • @Talk378
      @Talk378 Год назад +5

      @@RaZziaN1most of what made working in react native a total mess is alleviated with expo. The dx is one of the best I’ve used. Watch your requests in the chrome debugger just like you would in a web app, live debugging integration in vs code, easy builds via EAS. If you are going green field mobile it’s a no brainer imo.

  • @nro337
    @nro337 Год назад +260

    Definitely a bit of clickbait here, but the message is good and valuable generally, especially for those who have heard of Expo a few years ago but didn't use it due to shortcomings at the time that have sense been overcome.

    • @PrinzEugen39
      @PrinzEugen39 Год назад +39

      Classic theo and his crazy ass thumbnail as always lmao. Honestly he made me hate him day by day

    • @Shanetim
      @Shanetim Год назад +39

      Yeah. His ridiculous faces in the thumbnails and click-bait titles are getting real old. I unsubbed a while ago because it was too much, resubbed recently and but he's still at it. :/

    • @case_sensitive
      @case_sensitive Год назад +1

      It's the name of the game. For me (and I know this is not a good criticism), but I'm not a huge fan his narration style. Too perfect...

    • @TomNook.
      @TomNook. Год назад +5

      Yeah, that's Theo

    • @readywhen
      @readywhen Год назад

      @@PrinzEugen39 It's dumb for subscribers, but it 100% works to bait newcomers.

  • @bideshbanerjee5506
    @bideshbanerjee5506 Год назад +87

    In college days I was using a PC with 2 GB ram, with expo I have managed to build mobile apps for my resume projects.
    Even today it's surprises me, how the hell it is possible.

    • @sleekism
      @sleekism Год назад +2

      Wow 2gb, it's impressive you made that work

    • @GODWORDSorg
      @GODWORDSorg Год назад +8

      In my college days I used a PC with 640k of RAM. I had a copy of Windows 1, but couldn't use it... it required 1 MG. =)

    • @yewo.m
      @yewo.m 4 месяца назад

      🥳🎉 Good for you. I also started my web dev freelancing with a meager PC (4GB RAM with an older Intel Celeron CPU), and this was in 2022 while I was a student. With the money I generated from that, I managed to buy myself a better one

  • @ccheever2
    @ccheever2 Год назад +5

    Great video. Classic Theo clickbait title and switcheroo. Thanks for making this.

  • @Atmos41
    @Atmos41 Год назад +106

    Moving off React... to NextJS.
    The clickbait is real.

  • @djimi9803
    @djimi9803 Год назад +47

    1 month ago I was between flutter and react-native, then I saw a video of yours about react-native and I was shocked
    I never heard that before.
    You helped me understand why react-native is so powerful, thank you Theo

    • @alenasenie6928
      @alenasenie6928 Год назад

      a while ago there was an app being developed in my workplace, the external consultant used flutter, it went so bad that I had to learn how to use flutter in general in 2 hours and help him try to solve it, flutter is the worst, riddled with problems, slow, etc, at least compared with the few apps I have done as test in react and kotlin. Take in mind I am not a front end developer.

    • @gregorydaggett7444
      @gregorydaggett7444 Год назад +9

      Which video was that one?

    • @djimi9803
      @djimi9803 Год назад

      @@gregorydaggett7444
      React Natives Secret Superpower

    • @ogphoenix8965
      @ogphoenix8965 Год назад +2

      I am in the same situtation and I was blown away by Expo capacity, which video were you talking about?

    • @okokokokokok5173
      @okokokokokok5173 Год назад +2

      ya djamal yhdik rabi

  • @ianjakubek4143
    @ianjakubek4143 Год назад +20

    I love your videos man, but this "sorry I know I baited you" is becoming a bit too common. If you bait me into watching the videos I don't feel like watching, I won't click on the videos I might want to watch thinking it'll be a bait anyway

  • @grimm_gen
    @grimm_gen Год назад +32

    I use expo on personnal projects, and for a one man team Expo is a no brainer. The documentation is good, it has most of the native api you would need, the EAS flow is simple and effective, I love it!

  • @sheikhabujubayer9176
    @sheikhabujubayer9176 Год назад +35

    expo is life saver for me . expo-router + nativewind = 🤞

    • @pencilcheck
      @pencilcheck Год назад

      you mean nativewind v4? their v2 isn't as good.

    • @pencilcheck
      @pencilcheck Год назад

      @@JEsterCW It used to suck as well, now it is ok, I use it just for the basic building blocks and the app i'm building doesn't have a lot of weird requirements of navigation so it is ok.

    • @pencilcheck
      @pencilcheck Год назад

      @@JEsterCWSo what do you recommend for those that has your use case?

    • @sheikhabujubayer9176
      @sheikhabujubayer9176 Год назад +1

      @@JEsterCW for me, it's easier because my apps have minimal complex navigation requirements. As a new React Native developer, I find working with expo-router, familiar from my web development experience, to be straightforward.

    • @andreajr2021
      @andreajr2021 11 месяцев назад

      i'am still using react-native-cli so what wrong with me? any explanation ?? iam using my lapt i9-13th intel genration and 16gram thats ok ! :D,
      what benefit of expo?

  • @antopolskiy
    @antopolskiy Год назад +21

    my team is about to start developing a companion app for our webapp, and we were trying to make a decision between expo and RN. this is extremely timely and helpful, thanks, Theo

    • @bulljimmy2056
      @bulljimmy2056 Год назад +4

      The use of Expo is beneficial, but when you need to work with native code, such as compressing a video with FFmpeg, you'll need pure React Native because Expo doesn't support FFmpeg. What you should do is use both together (Expo and React Native). Another example involves push notifications in the background, for which you'll need pure React Native to handle them, as even stated on their website.

    • @okie9025
      @okie9025 11 месяцев назад +1

      @@bulljimmy2056 Expo has allowed native plugins to run, the same way React Native allows them, for a few years now. 99% of the native things you need have been custom-built by Expo, but if you need something more, you can still use 3rd party native plugins from npm, which wasn't the case a few years ago.

    • @pranjalkesarwani9993
      @pranjalkesarwani9993 10 месяцев назад

      My team is also going to write the code for a product....I am still not sure what to choose

    • @antopolskiy
      @antopolskiy 10 месяцев назад

      @@pranjalkesarwani9993 we eventually went with expo setup, and we already have the first version on app store. worked pretty well for our case

  • @nathanpiper1614
    @nathanpiper1614 Год назад +7

    One thing that often gets missed with the obsession of web technology driven cross-platform mobile stacks is that companies/devs are trying to “cheat” by not learning the design system of the platform and this often results in a lesser user experience.
    Talking from an iOS perspective, you can tell apps that are made with RN and other such frameworks, because the accessibility is usually poor and the UI mixes design systems (e.g. Apple HIG and Material). Also, performance can be an issue.
    The argument about being able to write native bindings doesn’t stack up, because then you’ve got more layers/frameworks and languages to understand and debug.
    When most user trends are towards native apps being the primary frontend being consumed (vs web apps), why don’t companies/devs just suck it up and make the investment?

  • @readingsmash6097
    @readingsmash6097 Год назад +14

    Alan has been my health insurance for a few months and have to say, never had a health insurance with such a good iOS app.

    • @XavierSeignard
      @XavierSeignard Год назад +9

      Thanks for the kind words!
      (I'm the author of the article Theo's talking about in the video.)

  • @akashbag09
    @akashbag09 8 месяцев назад +2

    As someone who was preparing to migrate to native cli from expo(because of people claiming it's not production ready) you definitely did save me a ton of time and energy. Thanks Theo!

  • @dealloc
    @dealloc Год назад +12

    We are also moving from a bare React Native app to Expo for our app. The main pain point with bare React Native is updates; not to React Native itself, that's the easy part, but rather for iOS and Android, whenever they change their distribution and build tools. We end up using the same tools you'd use for native development anyway (Fastlane, Gradle, Maven, CocoaPods, etc.) and it's a hassle.
    My hope is that Expo will do away we a lot of this, though I don't know whether we'll be using EAS but it could help us provide faster minor updates to users without having to go through the entire review process that doesn't fit our release cycle.

    • @blazi_0
      @blazi_0 Год назад

      Hi, will u guys use the new expo router ? And what will u do if you need some background operations on the phone?

    • @Dnserror88
      @Dnserror88 Год назад

      If your app doesn't require native code then Expo should indeed definitely be the choice. I've spent months updating a react native app from 0.62 to latest. Expo would've made the process so much easier, but the app requires native code so we had to eject from Expo early on.

    • @dealloc
      @dealloc Год назад

      @@blazi_0 We haven't determined that yet. We are currently using React Navigation. The only "background operations" we need is handled through push notifications and bluetooth connection. These will automatically keep the app active in the background to sync when needed.

    • @dealloc
      @dealloc Год назад +2

      @@Dnserror88 It does require some native code, especially for iOS widgets and live activities.
      The native parts can be integrated with expo-config-plugins, so I don't worry about ejecting. This is the major reason we are moving to Expo now.

    • @RidwanHD
      @RidwanHD Год назад

      If you aren't building on EAS on the cloud, then not sure Expo will alleviate the issues of Android/iOS Upgrading their build tools, since you'd more or less be building locally anyway.

  • @PM-4564
    @PM-4564 Год назад +27

    When I first wanted to make a mobile app, I kept searching "react-native vs flutter" only to get these bland "the one you go with depends on your specific needs" videos. Theo, because he is not afraid to offend people and serve hot takes, has an informative react-native vs flutter video, which was much more useful than other bland SEO this-vs-that content. The Hooks/JSX style of rendering is exactly the same in react-native as it is in react. Libraries liker react-query and jotai for state management work in both react and react-native.

    • @raghavendra3422
      @raghavendra3422 Год назад

      What would you prefer if you already know react and want to explore app development..
      React native or flutter

    • @somedude6420
      @somedude6420 Год назад +1

      ​@@raghavendra3422i have been developing with react for quite a while. I am using react native because similar state management and api integration libraries + logic can be implemented.
      I haven't explored flutter yet, probably not until our company or a client requires us to.
      I'd say if you already know react, just go for react-native 😅

    • @raghavendra3422
      @raghavendra3422 Год назад

      @@somedude6420 oh. Thankyou

    • @okie9025
      @okie9025 11 месяцев назад

      @@raghavendra3422 Flutter feels like a framework made for Android devs who want to make their apps cross-platform. Flutter makes easy things cumbersome, but at least makes the hard things possible. Making complex animations in Flutter (which would be 5 lines of code in CSS) is a PITA, not to mention the state management mess. Also why are "stateful" and "stateless" widgets 2 completely different things??
      Expo makes the easy things easy, and the hard things also easy. I personally see the winner.

  • @jaronfort9097
    @jaronfort9097 Год назад +5

    We use Expo in our video sharing app. Combined with Nativewind (Tailwindcss for React Native), the developer experience has been quite a positive one. My main criticism of React Native is that it is not PNPM friendly. It is making migrating to a PNPM monorepo a hassle.

    • @Gruak7
      @Gruak7 Год назад

      It was a minor hassle but disabling package hoisting in pnpm and applying monorepo tips from expo docs did the trick.
      With Expo 50 and RN 0.73 it should get even better as it will ship the new Metro version that now supports following symlinks so no need to disable hoisting anymore.

  • @SandraWantsCoke
    @SandraWantsCoke Год назад +4

    The free tier of expo has very long build times, because you sometimes* have to wait in line. Sometimes means during peak time (work time), it can also take over an hour of waiting in a queue for your build to start building. Average is maybe 20 minutes. That was the free version, so can't complain. There's a paid version though, where you basically don't wait.

  • @DanKelly-x3e
    @DanKelly-x3e Год назад +7

    Love this. Sucha great summary of all the ways that Expo makes life better. "Work smarter not harder" ya know.

  • @majdeddinebentahar5434
    @majdeddinebentahar5434 Год назад +4

    It's quite frustrating; I prefer building apps directly using native iOS and Android code, creating two separate codebases, and avoiding tools like React Native and Expo. There are constant issues and updates required when using these tools, which can be a significant headache. You end up spending a substantial amount of your time fixing bugs and making updates rather than focusing on developing new features.

  • @brennan123
    @brennan123 Год назад +10

    Isn't Expo how pretty much everyone builds React Native nowadays? I was confused when you said moving away from React Native because Expo is just improved process around React Native isn't it? It's still RN.

  • @nziranziza
    @nziranziza Год назад +13

    I don’t get why people think Expo is not React Native

  • @alexmachin1785
    @alexmachin1785 Год назад +7

    Probably worth mentioning if you change your environment variables often e.g. changing ip address or enabling Storybook it's worth setting up android and xcode locally still so you don't burn through CI/CD minutes 😅

  • @Shogoeu
    @Shogoeu Год назад +3

    So it's still React Native, just in a fancy suit!

  • @NeoChromer
    @NeoChromer Год назад +4

    Moving Off React Native - to React Native.. with some boilerplate.. should be the title

  • @asdfjackal
    @asdfjackal Год назад +12

    Expo/RN are great, if you aren't building anything more complicated than what is basically just a web view. The second you need to use something outside of the ecosystem it tears you a new one. I remember spending hours trying to get the android "share to" menu to include my expo app, and ended up just using flutter and got it working in 10 minutes, because having to use dart was less of a headache than figuring out how to get all the native stuff figured out.
    Right tool for the rifht problem.

    • @r2in360
      @r2in360 Год назад +3

      This is just plain wrong. I have built multiple apps using react native that are much more than 'basically just a web view'. Just because limitations exist on certain use cases does not mean that react native is not a capable tool for building complex applications.

    • @sheikh.salman101
      @sheikh.salman101 10 месяцев назад +1

      Good luck learning bloc, provider and other flutter specific knowledge when you already have all these under your belt from react.

  • @arivanhouten6343
    @arivanhouten6343 Год назад +1

    4:19: I worked with a setup of ionic, capacitor, react and adb before. I quite liked the hot reload provided by adb but it was a pain to set it up each time and the compilation step also took its time. Glad to see that there's another solution besides adb which I will definitely try out.

  • @malespecimen_old
    @malespecimen_old 5 месяцев назад

    can i use react native without expo?

  • @Abdallh-w4h
    @Abdallh-w4h 11 месяцев назад +4

    Flutter doesn't use some wired abstraction
    It uses skia which Chrome and Firefox use to render
    and in Flutter we can use native APIs through packages and if it is not available we can write one
    and use it in our project
    I think that Dart is better than JavaScript

    • @sheikh.salman101
      @sheikh.salman101 10 месяцев назад +1

      Unless you're a go to react developer, yes.

    • @Ali-fl8hv
      @Ali-fl8hv 6 месяцев назад

      unless you want a native experience, you may want to choose flutter. but if your goal is to make a native app, then react native is absolutely better

  • @aerocodes
    @aerocodes Год назад +4

    expo Is like making a pact with the devil (as a +5 years rn developer)

    • @pencilcheck
      @pencilcheck Год назад

      expo used to suck, I think they turn it around and is feeling a lot better now.

    • @aerocodes
      @aerocodes Год назад +1

      @@pencilchecknothing takes it away from my mind that is just a massive lock-in. Yeah if you wanna ship slightly faster for a small/medium sized app then why not. Remember everything that you put on a software will have it's tradeoffs

    • @pencilcheck
      @pencilcheck Год назад

      @@aerocodes if you have unlimited amount of money and can hire unlimited amount of talent with unlimited amount of time to interview, then go with whatever you propose. In the real world, you don't have any luxury, even in a big company. The vendor lockin isn't an issue, as everything expo can do, someone else will find it and replace it similar to how react and nextjs has many competitors after they win. Expo is the winner right now, and most of developers will drift very quickly to the next "similar" things very soon in a couple years anyway.

  • @OtivDev
    @OtivDev Год назад +6

    I'm on a team that is investigating expo for a new app at our company. It's not that well implemented to be honest. If you want to use exactly the set up they imagined (and trust them with all credentials and all that) it might be easy and great. But if you don't it's quite mediocre and bunch of use cases are not ironed out or a priority for expo team (like building the app locally, we want to use our own CI; they want us to pay $1k/month). Great product, but not an answer to all.

    • @XavierSeignard
      @XavierSeignard Год назад +2

      I completely disagree with your comment.
      We have zero troubles building the app locally and use our own CI
      (I'm the author of the article Theo's talking about.)

    • @OtivDev
      @OtivDev Год назад

      @@XavierSeignard I'm not saying it's impossible to use your own CI, just that it's not a priority for a team nor that those cases are ironed out. To give you more specific example, try to use a private npm repo with your own local expo CLI. It's much more complicated than it should be.

    • @poaches8714
      @poaches8714 Год назад

      ​@@XavierSeignardhave you found any performance degradation since moving to expo?

    • @XavierSeignard
      @XavierSeignard Год назад

      @@poaches8714 we monitor closely various perf metrics (TTI, long renders, freezes and so on) with datadog and home made integration and we haven't noticed any degradations 😌

  • @segun1
    @segun1 9 месяцев назад +2

    Is this an ad for Expo?

  • @tanzeelahmad9152
    @tanzeelahmad9152 10 месяцев назад +2

    expo is now not free now. for build and adding native modules you to recreate build and also not fit for larger apps

  • @MrAVQ
    @MrAVQ 20 дней назад

    A lot of videos talking about moving to Expo sound like sponsored content, :-. I was part of a React Native team that involved 15 React Native developers and 4 native developers. In the end, every release had many bugs, and the custom modules created by the native developers often became bottlenecks. Ultimately, I believe it’s cheaper to have 3 skilled native developers for the same app. And also, Expo is not entirely free; there are build limitations and other restrictions.

  • @TheMitchingHour
    @TheMitchingHour Год назад +1

    Does anyone know the name of the browser Theo is using here?

  • @zenpool
    @zenpool Год назад +10

    this is top tier bait lol. 😂

  • @classic-25
    @classic-25 Год назад +5

    I love react with it pros and cons but react native is not it, both expo and react native are just full of bugs.
    Having problems with something as basic as npm install is mind bending to me, while working on an expo application I used a package which required me to use yarn install (react native map) and the development went on and package required me to use npm install(react native toast) to run smoothly like how, since when did we have problems like this.
    In conclusion after using expo and react native for 3 years professionally nothing just work, and you have to spend time debugging even the framework to understand why things are not working and sometimes even though you know there is nothing you can do.

    • @XavierSeignard
      @XavierSeignard Год назад +3

      I'm using react-native and expo professionally for 6 years, and I now have zero problems with it
      (I'm the author of the article Theo's talking about)

    • @classic-25
      @classic-25 Год назад +1

      @@XavierSeignard is it meant to be this hard , I have never seen a package on npm installed it and follow it guide and it just works. The usual process is it breaks everything I spend 2 - 4 hours fixing the issue created from it, and I don't want to even start with animations.

  • @sergeynaryzhny9145
    @sergeynaryzhny9145 Год назад +7

    I like the headline, it set a lot of people's asses on fire. The folks were hoping the video would be about how they moved to Flutter or Native LOL

  • @JohannesHörteis
    @JohannesHörteis Год назад +3

    Suggestion: experiment with - and then make a video about Capacitor.

  • @himanshuagarwal7925
    @himanshuagarwal7925 Год назад +11

    me debugging my react native code while watching this video.... crying in the corner...

  • @thisweekinreact
    @thisweekinreact Год назад +2

    Tricked by the title 😂
    Nice to see a French company featured. Expo is great 👌

  • @coldtech06
    @coldtech06 Год назад

    Those like and sub callouts are so smooth

  • @tsooooooo
    @tsooooooo 7 месяцев назад

    Just coming back to rn after 6 years away and am pleasantly surprised how much it's improved thanks to expo

  • @Skorupa9
    @Skorupa9 Год назад +3

    Is Bluetooth works with Expo?

    • @snowwsquire
      @snowwsquire Год назад

      4:30

    • @DanRNLab
      @DanRNLab Год назад

      Bluetooth Low Energy is actually quite easy
      ruclips.net/video/UuHLPsjp6fM/видео.htmlsi=c85Nxh0GrumS14Ur

  • @PrathmeshGodse-s3y
    @PrathmeshGodse-s3y Год назад +1

    There are issues with expo I have faced, primarily with integrations. Sentry for example does not work with expo (specifically expo-router). Some SSO libraries do not work with expo go. Its a good workflow for development but still needs some improvements in integrations side of things.

  • @WhyWouldYouDrawThat
    @WhyWouldYouDrawThat 6 месяцев назад

    I’m finding that Expo hides problems. When you do an actual build, it sometimes crashes and you have no easy way to find out why. And worse, if you have done a lot of things since your last “real” build, then you might have no idea what caused it. I have also found Expo itself to be buggy. I haven’t tried ejecting yet. This might offer a balance. However, for enterprise Apps, at this point, I can’t recommend Expo - too unstable, and unpredictable. Am I missing something?

  • @tomyeoman4560
    @tomyeoman4560 Год назад +13

    The clickbait really lets down what is otherwise a great channel.

  • @kehan6252
    @kehan6252 Год назад +1

    Question.
    Can Expo let you run local databases on React Native such as RealmDB?
    I tried making a mobile app with Expo once and I found out I could not add RealmDB into it so I switched to normal React Native.

    • @XavierSeignard
      @XavierSeignard Год назад +1

      Yes, you'd need to use custom dev client and config plugins

    • @kehan6252
      @kehan6252 Год назад

      @@XavierSeignard thank you 😊

  • @Pixelflames1
    @Pixelflames1 Год назад

    The big reason we use expo is over the air updates. It basically means your users dont need to update their applications for anything other than big releases. New assets or code gets downloaded when the application starts.

  • @masedup
    @masedup 11 месяцев назад

    Expo looks good! I would go with it if I wanna keep it all in JS, but if we're really thinking about the dev experience with hybrid to native efficiently, I think Flutter sounds like the right choice here.

  • @CatDevz
    @CatDevz 11 месяцев назад

    16:59 Nix works on macOS
    Edit: No clue how well it works as a replacement for Xcode though. Doubt you could use it to fully replace Xcode for sure.

  • @haneenal-jabrah4165
    @haneenal-jabrah4165 Год назад

    I am currently the solo mobile developer of a react native app, inherited from a previous client with 0 knowledge transfer, coming form a web development background and 2018 react native familiarity. The development experience on iOS is a huge pain since i need to run it on physical devices, no hot reload, re-packaging the app breaks the build phases and i have to reset manually, and so on.
    A lot of time is wasted just running / building / rebuilding the app, not to mention how hard white labeling for other clients make it.
    I know it can be worse too, so i am looking for a solution to save me time in building, re-packaging the assets and configs (partially done manually), and this video has been helpful in providing ideas on how to approach this.
    I wish i can eventually move the app to expo, and use OTA for the many app assets, but it's hard to balance it with releasing new features since i am working solo with other project responsibilities, the stakeholders don't care about this unfortunately.

  • @perpetuus.flamma
    @perpetuus.flamma 9 месяцев назад +2

    bruh. Flutter can do all that for free.

  • @YuriAlbuquerque
    @YuriAlbuquerque Год назад +1

    Nix works on the Mac. I don't know how well it works together with xcode, though.

  •  10 месяцев назад +2

    Flutter has a mssive ecosystem of libs and plugins for exactly this purpose as well, so some of the statements here are completely incorrect. Also hot reload in flutter build tools is exactly the same as shown here for expo, works on you mobile phones directly plus it always worked from the beginning of flutter, even when you have a lot of plugins that tap into native code... so not sure how are any of these statements correct. Cool that expo also supports all of this for react native, not sure if I am correct here but it looks like they've were inspired by flutter in many cases from what I can see shown here

  • @thepawelk
    @thepawelk 7 месяцев назад

    I am a React Native dev for 6+ years now. Expo became the go to solution for creating RN apps around 2-3 years ago and there are people still that don't want to use it and it makes me really mad. Expo is the best DX experience for writing RN apps and allows you to actually benefit from using a cross platform technology and yet I'm now working in a project where I can't use Expo, because the management requirements said so
    🤷‍♀

  • @Mariiius53
    @Mariiius53 Год назад

    Most interesting video so far. Clearly explained for someone that never experienced mobile development.

  • @rebbavarapurakesh2279
    @rebbavarapurakesh2279 Год назад +3

    A drawback is that to build the APK, we need to rely on the Expo servers for Windows since there is no native support for building APKs on this platform.

    • @paulezaga5301
      @paulezaga5301 9 месяцев назад +1

      Actually expo you great freedom to use eas servers or just generate an apk by using gradlew simply from the android folder, but you need to eject the App.

    • @benny-shen
      @benny-shen 7 месяцев назад

      @@paulezaga5301 what do you mean by eject?

  • @FyyMyy
    @FyyMyy Год назад +4

    The main drawback for me is that you have vendor lockin. So when expo goes bankrupt I have to rewrite again, right?

    • @XavierSeignard
      @XavierSeignard Год назад +5

      As Expo's open source, I don't see vendor lock-in 🤔
      Only EAS part would create vendor lock-in
      (I'm the author of the article Theo's talking about)

    • @akashdeepnandi
      @akashdeepnandi Год назад +1

      ​@@XavierSeignard great work and read the full article. Thanks for the documenting it.

  • @hanro50
    @hanro50 6 месяцев назад

    The only issue with expo I've found is that when you need to use native modules. There isn't a good way to get intellisence working that I've found.

  • @ricardotrujillo4959
    @ricardotrujillo4959 Год назад

    This was already a thing like 4 years ago, still love it!!

  • @somnathgolui2912
    @somnathgolui2912 Год назад

    Keep making videos like this. It's helps a lot.

  • @grimm_gen
    @grimm_gen Год назад +1

    Also did you know about Nativewind? tailwind css integration for react native, for me this is the best way to build apps

  • @caaltz
    @caaltz Год назад

    I just got an expo project to update some dependencies and modify some parts of it and seems really cool

  • @ramonj360
    @ramonj360 Год назад +1

    As a RN dev i tried expo and its good. The downside is that its not really good for bigger projects with lots of custom configs. E.g. I work for a company where i port an app with a single code base to more than 10 whitelabels. The app is made very variable so the name icon themes etc is based on the whitelabel. Press build once and its builds them all. Expo isnt able to do this yet or configure it dynamically like this. If i build a single app which is static, expo is the way to go ofcourse.

    • @XavierSeignard
      @XavierSeignard Год назад

      We have 4 apps that rely on similar principles as white label apps and have zero problems using expo for that
      If it was 10 instead of 4 it wouldn't change a thing
      (I'm the author of the article Theo's talking about)

    • @ramonj360
      @ramonj360 Год назад

      ​@@XavierSeignard awesome! I did have the issues a long time ago. Will try it again over the weekends with a fresh project :)

  • @Hamza-sv9en
    @Hamza-sv9en Год назад +2

    Why does Theo think he’s some high profile tech journalist

  • @pencilcheck
    @pencilcheck Год назад +3

    expo used to suck, I tried it 5-6 years ago and moved away frmo it immediately, but this year it look promising so i'm trying again.

  • @beck4715
    @beck4715 Год назад +1

    I've had to use gradle for both native android stuff at school and flutter professionally. If I never have to deal with its bullshit again, it is a huge win.

  • @developerjk
    @developerjk 8 месяцев назад

    You can also build locally using --local flag to avoid build queue waiting time.

  • @old_H
    @old_H Год назад

    How does Expo compared to Appflow?

  • @JGrffn
    @JGrffn Год назад +1

    The fact that expo just doesn't work on React Native Windows makes RNW incredibly hard to vouch for. I worked for nearly 2 years developing a RNW app and even though I mostly got there, by the end it was so frustrating to fix bugs and try and get features to work that I got completely mentally blocked and just couldn't keep going. I stopped working for the company due to a takeover that ended in me being seen as disposable, but even if that hadn't happened, I couldn't have gone on for much longer due to the huge guilt I felt over being mentally blocked and having development happening at a crawling pace. Either they wouldn't have tolerated much more of my pace or I would've resigned since I couldn't in good faith keep getting paid to just be blocked.
    I don't see you touching on RNW that much, which is understandable, but I think RNW either needs more love from the community, or it needs to die altogether.

  • @WilliamAlvarez
    @WilliamAlvarez 11 месяцев назад

    what do you think about flutterflow ?

  • @benjaoliva3383
    @benjaoliva3383 Год назад

    - Hey, Theo. Who's the best football player?
    - 10:18

  • @alextl97
    @alextl97 Год назад

    In which cases expo would not be the way to go? When you work with things like hardware sensors and such?

  • @hamzakyamanywa9792
    @hamzakyamanywa9792 Год назад

    What fonts is this guy using? They look so good.

  • @systematicpsychologic7321
    @systematicpsychologic7321 Год назад

    GREAT video. Okay, you got me, I'm going to try Expo again. Everyone badmouths it as being on the left side of the meme chart, but if a right side exists, I wanna experience it. And you are 100% right about the mac thing, I've had that exact experience.

  • @phemartin
    @phemartin Год назад +3

    I'd love if you could talk about Capacitor and its tradeoffs (as it is the easiest mobile solution)

    • @brandonmansfield6570
      @brandonmansfield6570 Год назад +3

      Doesn't get as much love as it's further from native.
      I've built Cordova apps, Capacitor, Expo. Capacitor has some drawbacks and limitations. But if you don't bump into those it's a no-brainer IMHO. Having one code base to hit web and mobile is very very sweet.
      I don't know where Expo is now. When I was building stuff with it, it was really rough. Every version update was a crapshoot if we would need to spend 1-2 weeks of dev time updating our app to be compatible with the latest expo. Lots of bugs in the expo layer as well as the native bridge that were rough to track down.
      Then there were javascript bugs that would work properly in the debugger and fail in the actual app. Yuck.
      We spent half our dev time fighting with the platform rather than building features.

    • @phemartin
      @phemartin Год назад

      @@brandonmansfield6570 Makes sense! What are the main drawbacks/limitations from Capacitor in your POV?

    • @brandonmansfield6570
      @brandonmansfield6570 Год назад

      @@phemartin
      Input for one, browser views need to delay sending the touch event a bit to see if there is some kind of scroll or other gesture going on instead. If you want your input to be really low latency, you can't do this via the browser by over-riding this behavior (or at least I haven't found a way) . This is fairly noticeable if you put a browser next to a very low latency app and run them both watching closely for button actuation time.
      Mostly people don't notice though, actual browsers have the same latency built in and for the most part it's "fine". You probably haven't noticed, until I point this out and maybe you look for it, and it may become something you can't unsee.
      Some of the plugins for native API features are old and don't work, don't even exist, or don't support the feature you want. So you have to write or update them yourself. Sometimes this is so labor intensive, or limitations make it impossible to do, and the feature becomes a deal killer for the direction.
      In my experience, the app can usually totally exist as a capacitor app if you're willing to drop the features in the areas where you run up against such platform limitations. If you don't have much, if any, native API capability, then you are very unlikely to hit a deal breaking limitation.

  • @blazi_0
    @blazi_0 Год назад +2

    Yeah expo is very easy and cool, but it didn't work well with my last project where I needed spme background operations on the phone, especially i was using expo router it didn't work no matter what i did. Also the background fetch and task manager is not great, sometimes it just stops working or stops when u terminate the app etc.. not great at all

  • @simbarashemaunga5575
    @simbarashemaunga5575 Год назад +3

    React native will always fall behind Flutter, in the grand scheme of things, the end user is more concerned with UX rather than a button that isn't some abstraction of the component.

  • @rhaikh
    @rhaikh Год назад +1

    I wish Rails/Hotwire had an Expo

  • @matfire1999
    @matfire1999 Год назад +2

    I looked at React Native and Expo for a work project where we needed to use Bluetooth Classic (not ble). For the use case we had, and although there was a community package for this in Expo, we ended up developping the plugin ourselves using Capacitor (the API is, IMO, more straightforward). If there ever is an Expo bluetooth classic plugin (apparently planned, but no ETA), we may consider Expo because of all the features in the video

  • @bloodandbonezzz
    @bloodandbonezzz Год назад +1

    Most of development with react native and expo has nothing to do with start up and more to do with actual coding. Switching from React Native to Expo honestly seems like a waste of time.
    You do have hot reload on React Native, you can wirelessly setup react native to work with your phone and continue developing with it, in most cases you will need native features so using react native over expo seems more ideal, it’s extremely easy building and maintaining your app with react native, using expo seems like and meaningless route.

  • @m3speedking
    @m3speedking Год назад +1

    i used to do React Native with Expo, so it was not React Native OR Expo , but React Native WITH Expo

  • @SonAyoD
    @SonAyoD Год назад

    Local builds work great for me when i need it. Expo updates for the everything else.

  • @poaches8714
    @poaches8714 Год назад

    Can anyone help me understand the difference between using expo vs expo bare? In the latter case are you forgoing the ability to create expo dev clients?

  • @galaxies_dev
    @galaxies_dev Год назад +9

    Crying inside when people still mention "eject" as a reason against Expo in 2024 🥲

  • @karmatraining
    @karmatraining Год назад

    I've had a thousand years of problems with these high-level frameworks...if I could go back in time, I would use Swift, with Expo a close second. Iteration time is the killer on mobile projects - if you have hot reload you're happy.

  • @andreajr2021
    @andreajr2021 11 месяцев назад

    i'am still using react-native-cli so what wrong with me? any explanation ?? iam using my lapt i9-13th intel genration and 16gram thats ok ! :D

  • @cristicode4301
    @cristicode4301 Год назад +1

    Why even use something on top of React Native, which itself is something on top of the native system? Since the reason ppl use Native is is for getting an app for both Android and IOS, why not use Kotlin Multiplarform with Jetpack Compose?

  • @BrunoSantos-bt2bk
    @BrunoSantos-bt2bk Год назад

    Is there a way to force android light mode on xiaomi devices with expo? I couldn't find a way. The dark mode fucks all of the colors of the app, things that SHOULD be white turn into gray

  • @dweblinveltz5035
    @dweblinveltz5035 Год назад +1

    Oh no he's selling me!!

  • @JonStelly
    @JonStelly Год назад

    I'd love to see expo support react-native-windows both so I could get into it and also to give other developers/teams a good alternative to just shipping electron for desktop apps.

    • @paulezaga5301
      @paulezaga5301 9 месяцев назад

      Yes, that will become a game changer. I developed a UWP using react native. I had to improvide in cases where no packages existed for my use case

  • @raihan7422
    @raihan7422 Год назад

    am i need to fully understand react native first to understand expo? like... if i want use next js i must understand react js first right

  • @BayramArif
    @BayramArif 3 месяца назад

    4:00 its not even that the greatest part. There is a built in tunneling system, which allows you to debug in real time code via URL. That means you can make a code change from your home and your tester can recieve this change from their home in real time.

  • @OvidiuLatcu
    @OvidiuLatcu Год назад +3

    Great. An abstraction on top of an abstraction on top of other native systems... I'll pass on Expo. I'd rather know what an AndroidManifest and Info.plist files are, and how they are configured, rather than relying on Expo for it. ( it's easier for me as I've been building natively and on mobile for ~ 10 years, so maybe many hasells others are facing are not relevant for me )

    • @lautarolopez5372
      @lautarolopez5372 Год назад

      Agree. And it is not that hard to play with those files.

  • @zearthus7089
    @zearthus7089 10 месяцев назад

    I'm still doing the old way without the expo, I might migrate someday once I can convince the company the expo is a secured environment where configuration and keys cannot be hack.

  • @minh2717
    @minh2717 Год назад +1

    what’s the browser he’s using?

  • @LexMadafaka
    @LexMadafaka Год назад

    I understand this, but with angular you can do similar thing with --port flag specification. I do not used or done my research on React Native, I am not judging it negativelly, but as I watch this, mobile-developing with Angular+Ionic+Capacitor is not that different on first watch as from React Native on perspective of "web-like developer experience".

  • @NomadicBrian
    @NomadicBrian 11 месяцев назад

    Almost 30 years of building apps with around 15 in web development. A client I interviewed with mentioned React Native so i thought I'd do a quick dive and cut my teeth on it. I have used React for web as well as Angular. I used VS Code and used the React Native latest CLI and it generated a project that would not build. I spent a few days fixing the configuration only to stop in frustration and the countless levels of package bugs in gradle for the android build. I did see Expo in the notes as the alternative to the React Native CLI and might give it a try. I built Native Android mobile apps a number of years ago with Java and Android Studio. The apps were easy to build. The Android system version updates were constant I recall. To be honest most CLI tools for Angular and React work without issues on a new app. Very frustrating. I wonder if the React Native is worth it.

    • @NomadicBrian
      @NomadicBrian 11 месяцев назад +1

      Nope I don't like expo. Screw React Native. Not worth it.

  • @brunofelipe5380
    @brunofelipe5380 7 месяцев назад

    i am a beginner react native developer, i dont get it, even the react native documentation recommends uses Expo. is that some joke?