Post Views: 5,465
สำหรับผู้พัฒนาที่ต้องการพัฒนา Mobile App แต่รู้สึกว่ายังไม่พร้อมศึกษา React Native แบบจริงจัง สามารถใช้งาน Expo Framework โดยสามารถใช้ได้ทั้งในการพัฒนา หรือ Build ขึ้น Store ได้เลยทั้ง iOS/Android ด้วยภาษา JavaScript/TypeScript
โดยวันนี้จะเริ่มด้วยแนะนำวิธีติดตั้ง Tools สำหรับพัฒนาชื่อ Expo CLI ครับ
- Reference : https://docs.expo.io/versions/latest/
- Installation Version
- windows 10 version 1909 64 bit
- npm 12.14.0 LTS
- python 3.8
- Expo SDK 36
- ติดตั้ง Node Js (โหลดติดตั้งแบบ LTS)
https://nodejs.org/en/ - ถ้ามีแจ้งไฟล์ไม่ปลอดภัยกดข้ามไป
data:image/s3,"s3://crabby-images/52912/52912364e0a3e37d52cb1ef4c690670977bbc065" alt=""
data:image/s3,"s3://crabby-images/ae962/ae962ae6a71d36fdea8d8e8f2ff3eda9441a04f4" alt=""
data:image/s3,"s3://crabby-images/a0180/a01800d3223c48c839cc09a865ff3882e0b03a2c" alt=""
data:image/s3,"s3://crabby-images/47e1e/47e1effa132d59a2024e736f7de64b5652091613" alt=""
- จะมีให้เลือกว่าจะลง Chocolatey หรือเปล่า เพื่อติดตั้ง Module เพิ่มเติม และแนะนำติดตั้ง Node-Gyp ซึ่งจะต้องติดตั้งเองภายหลัง
data:image/s3,"s3://crabby-images/c582b/c582b3b60833397cd59871aa1894b35e4075c13c" alt=""
data:image/s3,"s3://crabby-images/f9046/f9046cd5ee990e32450677ff46676edab9b1cbd1" alt=""
data:image/s3,"s3://crabby-images/82d33/82d33e5f5db22de939385365cb3a86eaf7bc642d" alt=""
data:image/s3,"s3://crabby-images/a44b3/a44b379b085f2f99513fe19674ef39b2bc1e9d2c" alt=""
- ติดตั้ง Python ก่อนติดตั้ง Node-Gyp ผ่าน Windows Store (หลังกด Get ไม่ต้อง Sign In ก็ได้)
data:image/s3,"s3://crabby-images/04a06/04a0624a5acb2068076b92d8e9c905f2981c7a99" alt=""
data:image/s3,"s3://crabby-images/0456d/0456d1f5aa064723483b27d400b9dc1c27ac39c4" alt=""
- เปิด windows cmd (Run as Administrator หรือไม่ก็เลือก Start->Node.js command prompt)
data:image/s3,"s3://crabby-images/42c19/42c19c78ae5a84538c982ed55549e86a91132eb8" alt=""
- ติดตั้ง node-gyp
npm install -g node-gyp
data:image/s3,"s3://crabby-images/d33e6/d33e652b4d2383d6fad13be7f982fd1133714442" alt=""
- ติดตั้ง Expo CLI ด้วย npm
npm install -g expo-cli
data:image/s3,"s3://crabby-images/428ea/428ea4ee74fb7fbd8250c8af9fbc37be3c97822c" alt=""
- ทดสอบสร้างโปรเจ๊คใหม่ดังนี้
expo init
data:image/s3,"s3://crabby-images/51893/518930d77c4a06bfd8a22db1c3ab47ec7eaa726d" alt=""
data:image/s3,"s3://crabby-images/fba50/fba5036dd5f9acffc0f33d2559542c4bab38c39e" alt=""
data:image/s3,"s3://crabby-images/a5161/a51614a6f40baa158bd9c1e58315682be87afd79" alt=""
- สั่งรัน Web สำหรับ Debug จะพบว่า Error
data:image/s3,"s3://crabby-images/4965c/4965c7b41c2bf87b2c1cffe464f11d443afec5dd" alt=""
- สำหรับ Expo SDK 36 ต้องแก้ \node_modules\metro-config\src\defaults\blacklist.js ดังนี้
var sharedBlacklist = [
/node_modules[\/\\]react[\/\\]dist[\/\\].*/,
/website\ /node_modules\/.*/,
/heapCapture\/bundle\.js/,
/.*\/__tests__\/.*/
];
data:image/s3,"s3://crabby-images/9168c/9168c5d095c1f1fed7daa5c1b58fceb2147abf6a" alt=""