อัปเดตล่าสุดเกี่ยวกับ React Native สำหรับเว็บ, Windows และ macOS!
เผยแพร่แล้ว: 2023-01-10การพัฒนาแอปพลิเคชันเป็นผลมาจากการเกิดขึ้นของเทคโนโลยีก่อกวน ตอนนี้ถูกมองว่าเป็นด้านการตลาดหลักสำหรับทุก บริษัท ผลิตภัณฑ์และบริการ การพัฒนาแอพเริ่มต้นที่อุปกรณ์พกพาที่กำหนดเป้าหมาย เมื่อเวลาผ่านไป ผู้ให้บริการตระหนักว่าพวกเขาต้องเข้าถึงเว็บ เช่นเดียวกับอุปกรณ์เคลื่อนที่ เพื่อให้เข้าถึงข้อมูลประชากรได้ในระดับสูงสุด ตอนนี้ ประเด็นของการสนทนาได้เปลี่ยนจาก "เราควรเป็นเจ้าของแอปพลิเคชันหรือไม่" เป็น “แพลตฟอร์มใดที่เราควรกำหนดเป้าหมายด้วยแอปพลิเคชัน”
และนี่คือหนึ่งในคำถามที่ยากที่สุดในการพัฒนาแอปพลิเคชัน นักพัฒนาแอพจำเป็นต้องครอบคลุมระบบปฏิบัติการที่แตกต่างกัน ในขณะเดียวกัน พวกเขาไม่สามารถเพิกเฉยต่อการเข้าถึงระยะไกลของเว็บแอปที่ตอบสนองได้ มันจะเป็นความคิดที่ดีที่จะสามารถติดตามทุกด้านได้ แต่นั่นทำให้ต้นทุนการพัฒนาและการบำรุงรักษาสูงลิบลิ่ว ดังนั้นคำถามที่ตอบยากก็คือ “อะไรคือทางออกที่ดีที่สุดสำหรับการพัฒนาแอปพลิเคชันข้ามแพลตฟอร์มที่คุ้มค่า” การเลือกกรอบการพัฒนาแอปพลิเคชันที่สนับสนุนเป้าหมายทั้งหมดนี้สามารถเป็นคำตอบที่มีประสิทธิภาพ การพัฒนาแบบเนทีฟของ React กำลังได้รับความนิยมอย่างมากจากเหตุผลเหล่านี้
React Native คืออะไร?
React Native เป็นเฟรมเวิร์กการพัฒนาแอปพลิเคชันที่ใช้ JavaScript ซึ่งใช้เพื่อพัฒนาแอปพลิเคชันมือถือ เริ่มต้นเป็นโครงการโอเพ่นซอร์สโดย Facebook ในปี 2558 ชุดคุณสมบัติที่หลากหลายทำให้หลาย ๆ บริษัท เข้าสู่การพัฒนาแอปพลิเคชัน React Native บริษัทชั้นนำหลายแห่งรวมถึง Facebook และ Instagram ได้ใช้ React Native ในการพัฒนาแอปพลิเคชัน
ประวัติศาสตร์
ก่อนหน้านี้ Facebook ใช้ HTML5 เพื่อพัฒนาหน้าเว็บบนมือถือสำหรับทุกอุปกรณ์ ความพยายามนี้ต้องดิ้นรนในแง่ของ UI และประสิทธิภาพ การแก้ปัญหาไม่ได้ผลในระยะยาว ในปี 2013 Jordan Walke ผู้พัฒนา Facebook ใช้ JavaScript เพื่อพัฒนาองค์ประกอบ UI แนวคิดนี้แหวกแนว Hackathon จัดขึ้นเพื่อทดสอบศักยภาพของการพัฒนาแอปพลิเคชันมือถือโดยใช้ JavaScript สิ่งนี้ทำให้เกิด React Native ตอนแรกเปิดตัวสำหรับ iOS Facebook ค่อย ๆ ให้การสนับสนุน Android และในที่สุดก็เปิดตัวเวอร์ชัน iOS ในปี 2558 React Native กลายเป็นโครงการที่ใหญ่เป็นอันดับสองบน GitHub เพียงสามปีหลังจากเปิดตัว
ทำไม React Native ถึงได้รับความนิยม?
หนึ่งในเหตุผลหลักที่ทำให้ React Native ได้รับความนิยมอย่างล้นหลามคือการใช้ไลบรารี JavaScript ซึ่งเป็นที่นิยมเช่นกันเมื่อเปิดตัว React Native จากนั้น React Native ก็ได้รับความนิยมในหมู่นักพัฒนาโดยอัตโนมัติ เหตุผลที่สองคือ React Native framework ได้นำเสนอคุณสมบัติที่ยอดเยี่ยมมากมายสำหรับการพัฒนา UI ซึ่งเป็นที่ชื่นชอบของนักพัฒนาส่วนหน้า เหตุผลที่สามอาจเป็นกรอบและคุณสมบัติต่างๆ นักพัฒนา React Native จำเป็นต้องเขียนโค้ดเพียงครั้งเดียว สามารถใช้งานได้ทั้งบน Android และ iOS สิ่งนี้ช่วยประหยัดเวลาและความพยายามสำหรับนักพัฒนาและองค์กรได้อย่างมาก
React Native เป็นกรอบการพัฒนาแอปพลิเคชันข้ามแพลตฟอร์มที่ยอดเยี่ยมซึ่งนำเสนอ:
- ผู้ชมที่กว้างขึ้น
- ประสิทธิภาพที่สอดคล้องกันในแพลตฟอร์มต่างๆ
- การพัฒนาที่รวดเร็วยิ่งขึ้น
- คุ้มค่า
นี่คือคุณสมบัติบางอย่างที่ทำให้แอปพลิเคชัน React Native ได้รับความนิยมอย่างมาก
เรายืนอยู่ตรงไหน?
React Native เป็นโอเพ่นซอร์สและรีลีสยังเป็นโอเพ่นซอร์สสำหรับทุกคนในการเข้าถึง มี release train ใน React Native release repository ใน GitHub React Native 0.70 เปิดตัวในเดือนกันยายน 2022 ซึ่งเป็นเวอร์ชันล่าสุด ปี 2022 เริ่มต้นด้วยการเปิดตัว React Native 0.67 ซึ่งมาพร้อมกับการปรับปรุงมากมาย จากนั้นด้วยการเปิดตัว React Native 0.68 เราได้เห็นการเปลี่ยนแปลงที่ก้าวล้ำ ได้แก่:
- การอัปเดต React Native เป็น Node 16 ทำให้นักพัฒนา React ต้องใช้ Node 14 และเวอร์ชันที่สูงกว่า
- การเพิ่มปลั๊กอิน Android Gradle
- การลบทรัพยากรสำรองออกจาก iOS API ชื่อ RCTBundleURLProvider
มีการเพิ่มสถาปัตยกรรมใหม่ที่มีระบบ TurboModule และ Fabric Renderer React Native 0.69 มาพร้อมกับการปรับปรุงมากมายเพื่อรองรับสถาปัตยกรรมใหม่นี้ การรองรับ Bundles Hermes และ React 18 เป็นส่วนเพิ่มเติมหลักสองประการในเวอร์ชันนี้ มีการเปลี่ยนแปลงอื่น ๆ อีกมากมายรวมถึงการสนับสนุน c ++ 17 และการเพิ่มตัวเลือก hotkeysEnabled
ในเวอร์ชัน 0.70 ล่าสุด มุ่งเน้นไปที่ Hermes ซึ่งได้เพิ่มคุณค่าให้กับ React Native เป็นอย่างมาก ได้รับการพัฒนาขึ้นเพื่อประโยชน์ของอุปกรณ์ที่มีทรัพยากรจำกัด เอ็นจิ้น Hermes สามารถคอมไพล์ซอร์สโค้ดของ JavaScript เป็นไบต์โค้ดล่วงหน้าได้ ซึ่งแตกต่างจากเอนจิ้นอื่นๆ Hermes ได้รับการเผยแพร่เป็นเครื่องมือเริ่มต้นในเวอร์ชัน 0.70 ในเดือนธันวาคม พ.ศ. 2565 ได้มีการเปิดตัว API ตัวชี้ข้ามแพลตฟอร์มรุ่นทดลอง ในอนาคต โฟกัสจะอยู่ที่การปรับปรุงประสิทธิภาพของเฟรมเวิร์กสำหรับเดสก์ท็อป VR และเว็บ
ตอบโต้ Native สำหรับเว็บ
ถึงเวลาแล้วที่จะต้องกำจัดความเข้าใจผิดทั่วไปที่ว่า React Native มีไว้สำหรับการพัฒนาแอปพลิเคชันบนมือถือเท่านั้น เว็บ React Native เป็นความจริง สามารถใช้กับแอพที่มีอยู่แล้วและแอพใหม่ ผู้ใช้ยังสามารถใช้เพื่อพัฒนาแอพหลายแพลตฟอร์มพร้อมกับเว็บแอพ React DOM ใช้เพื่อเรนเดอร์โค้ด JavaScript ที่เข้ากันได้ในเว็บเบราว์เซอร์ ทำให้นักพัฒนาสามารถใส่สิ่งที่เป็นนามธรรมอันทรงพลังลงในเว็บได้ เว็บแอปพลิเคชัน React Native สร้างขึ้นโดยใช้ React API ที่ทันสมัย
นักพัฒนาสามารถค้นหาองค์ประกอบหลักทั้งหมดของ React Native สำหรับการพัฒนาเว็บ ส่วนประกอบสำหรับเว็บมาพร้อมกับการใช้งานที่เข้ากันได้กับเบราว์เซอร์ ตัวอย่างเช่น นักพัฒนาซอฟต์แวร์จะได้ใช้คอมโพเนนต์ <view> เวอร์ชันที่ใช้ DOM ของ React Native ซึ่งสามารถใช้แสดงผลเป็น <div> ได้ กรอบการพัฒนา ReactJS กลายเป็นโซลูชันเดียวสำหรับการพัฒนาแอปพลิเคชันทุกประเภท นักพัฒนาสามารถใช้แท็ก HTML เพื่อแปลภาษาดั้งเดิมของ React Native ที่จำเป็นเป็นภาษา DOM ส่งเสริมการนำ React Native มาใช้ในการพัฒนาเว็บแอปพลิเคชัน
ประโยชน์ของการใช้ React Native สำหรับเว็บ
เราสามารถเดิมพันด้วยเหตุผลหลักสองประการที่อยู่เบื้องหลังความนิยมที่เพิ่มขึ้นของ React Native สำหรับเว็บ
- เมื่อคุณสร้างเว็บแอปด้วย React Native คุณจะสามารถเข้าถึงอินเทอร์เฟซเว็บคุณภาพสูงที่ช่วยคุณพัฒนา UI ของเว็บที่ปรับเปลี่ยนได้โดยใช้ JavaScript การสนับสนุนแบบเนทีฟ โหมดอินพุตหลายโหมด รองรับเค้าโครง RTL และการผสานรวมกับ React Dev นำไปสู่การพัฒนา UI ที่ราบรื่น
- นักพัฒนา React จำเป็นต้องเขียนเพียงครั้งเดียวและแสดงผลได้ทุกที่ที่ต้องการ อนุญาตให้เขียนส่วนประกอบใหม่สำหรับเนทีฟและเว็บแอปโดยไม่ต้องเขียนซ้ำ
การแก้ไขข้อผิดพลาดที่สำคัญและการเปลี่ยนแปลงตามแผน
ด้วยการเปิดตัว React Native สำหรับเว็บ 0.18 มีการแก้ไขข้อผิดพลาดมากมาย ได้ทำการแก้ไขสำหรับสิ่งต่อไปนี้:
- การทำซ้ำแบบสั้นและแบบยาว
- การแสดงวงแหวนโฟกัสขององค์ประกอบต่างๆ รวมถึงสวิตช์และช่องทำเครื่องหมาย
- การนำทาง Href สำหรับอุปกรณ์ที่สัมผัสได้และที่กดได้
- Linking.OpenURL รองรับค่าเป้าหมาย
มีการเพิ่มคุณสมบัติใหม่มากมาย
- การซ้อนเค้าโครง LTR/RTL ที่แปลเป็นภาษาท้องถิ่นโดยการตั้งค่าที่ดินหรืออุปกรณ์ประกอบฉากสำหรับส่วนประกอบ
- การสลับแบบไดนามิกของเค้าโครง LTR/RTL ที่แปลเป็นภาษาท้องถิ่นในรันไทม์
- การเพิ่ม useLocaleContext เป็น API การส่งออกใหม่
- รองรับการเรนเดอร์สำหรับ Shadow Boots และหลายหน้าต่าง
- การแยก CSS แบบคงที่
ตอบโต้ Native สำหรับ Windows + macOS
ก่อนจะไปต่อ เรามาดูประวัติของ React Native สำหรับ Windows และ iOS กันก่อน React Native windows + macOS ได้รับการพัฒนาในปี 2558 ตั้งแต่นั้นมาก็มีการเปิดตัวอย่างต่อเนื่องพร้อมการแก้ไขข้อบกพร่องและการปรับปรุง นักพัฒนา React สามารถใช้ React Native สำหรับการพัฒนาแอพเดสก์ท็อป Windows ได้แล้ว แนวคิดเบื้องหลัง React Native windows คือการใช้เครื่องมือ สถาปัตยกรรม ภาษา และองค์ประกอบอื่น ๆ ทั้งหมดของ React Native สำหรับการพัฒนาแอปพลิเคชัน windows
คล้ายกับ Windows มาก React Native สำหรับ macOS เริ่มการพัฒนาในโครงการ React Native จริงโดยคำนึงถึงสภาพแวดล้อมเดสก์ท็อปของ mac React Native สำหรับ windows + macOS framework ช่วยให้นักพัฒนาสามารถสร้างแอพข้ามแพลตฟอร์มได้ แอปพลิเคชันชั้นนำมากมาย เช่น Xbox และ MS Office ประสบความสำเร็จในการใช้ React Native สำหรับ Windows และ macOS ในการพัฒนาแอปพลิเคชัน MacOS สำหรับ iOS ยังได้รับการสนับสนุนที่แข็งแกร่งทุกครั้งที่ออกใหม่
ประโยชน์ของการใช้ React Native สำหรับ Windows + macOS
มีประโยชน์มากมายในการใช้ React Native สำหรับแอปมือถือและการพัฒนาแอป Windows บนเดสก์ท็อป
- นักพัฒนา React สามารถใช้โมดูลดั้งเดิมเพื่อเรียกใช้การควบคุมและส่วนประกอบมาตรฐานของ React Native นักพัฒนาสามารถใช้คุณลักษณะต่างๆ เช่น 'การโหลดซ้ำแบบสด' เพื่อทดสอบการใช้งานของตน เช่นเดียวกับที่ทำในเว็บแอปพลิเคชัน
- สามารถใช้โค้ดเบสเดียวเพื่อรันได้ทั้งบนระบบปฏิบัติการ macOS และ Windows แม้ว่าจะมีโปรเจ็กต์ React Native สองโปรเจ็กต์สำหรับการพัฒนาแอปพลิเคชันที่แตกต่างกัน ส่วนประกอบ UI ที่ใช้ร่วมกันก็มีอยู่ในเลเยอร์บนสุด ซึ่งช่วยลดเวลาในการพัฒนาและบำรุงรักษาสำหรับทั้งสองแอปพลิเคชันได้อย่างมาก
- ชุมชนนักพัฒนาขนาดใหญ่ที่ให้การสนับสนุนไม่สามารถเพิกเฉยได้ ชุมชน React และ React Native ให้การสนับสนุนการพัฒนา React Native Windows และ macOS อย่างต่อเนื่อง
การแก้ไขข้อบกพร่องและฟีเจอร์ที่วางแผนไว้
เวอร์ชัน 0.70 เป็นคุณลักษณะใหม่ มีการแก้ไขค่อนข้างน้อยซึ่ง:
- เป็นการแก้ไขสำหรับตัวเร่งปฏิกิริยา
- เปิดใช้งาน React JSX Transform ใหม่
- เปิดใช้งานการลบ reactnativeutilsjni
นอกจากการเปลี่ยนแปลงแล้ว การพึ่งพาจำนวนมากยังได้รับการอัปเกรดอีกด้วย ไฮไลท์สำคัญของการเปิดตัวคือ:
- ใช้ Hermes เป็นเครื่องมือเริ่มต้น
- การกำหนดค่าแบบครบวงจรใหม่สำหรับ Codegen
- ลิงก์อัตโนมัติสำหรับไลบรารีสถาปัตยกรรมใหม่ใน Android
- รองรับ CMake เต็มรูปแบบเพื่อกำหนดค่าการสร้าง Android
บทสรุป
React Native เป็นตัวเลือกที่ยอดเยี่ยมสำหรับการพัฒนาเว็บข้ามแพลตฟอร์มและแอปพลิเคชันมือถือสำหรับแพลตฟอร์มต่างๆ React Native ช่วยให้นักพัฒนาแชร์โค้ดเบสและตรรกะทางธุรกิจบนเว็บและแอปพลิเคชันแบบเนทีฟ ทำให้มีความสอดคล้องกันของภาพที่ยอดเยี่ยม ตัวเลือกการพัฒนา เช่น 'การรีเฟรชอย่างรวดเร็ว' ช่วยให้นักพัฒนาสามารถเห็นการเปลี่ยนแปลงในแอปพลิเคชันได้ทันที ส่งผลให้ประสิทธิภาพการทำงานสูงขึ้นและประสบการณ์ผู้ใช้ดีขึ้นในที่สุด React Native เป็นภาษาที่มีความก้าวหน้าอย่างมาก ซึ่งการเผยแพร่ฟีเจอร์ใหม่ๆ และการแก้ไขจุดบกพร่องต่างๆ Contributor Summit 2022 เปิดช่องทางใหม่ของการแบ่งปันความรู้และการทำงานร่วมกันเพื่อนำเสนอสิ่งใหม่และนวัตกรรมใน React Native
การพัฒนาที่จะเกิดขึ้นคาดว่าจะอยู่ใน 'วิสัยทัศน์ของหลายแพลตฟอร์ม' ซึ่งมีจุดมุ่งหมายเพื่อสร้างนอกเหนือจากมือถือ การลงทุนที่เพิ่มขึ้นในเดสก์ท็อป เว็บ และ VR รับประกันเฉพาะการออกรุ่นใหม่พร้อมการสนับสนุนที่ดีขึ้นสำหรับแพลตฟอร์มที่มีความแตกต่างของฮาร์ดแวร์ เมื่อพิจารณาจากกราฟการพัฒนาที่เพิ่มขึ้น เราสามารถสรุปได้ว่าการใช้ React Native ในการพัฒนาแอปพลิเคชันนั้นเป็นทางเลือกที่คุ้มค่า มีการเปลี่ยนแปลงที่น่าตื่นเต้นมากมายในปี 2022 และการเปิดตัวใหม่ในปีต่อๆ ไปก็คุ้มค่ากับการรอคอย