Zomato API를 사용하는 레스토랑 검색 어플리케이션(React Native)
11184 단어 reactreactnativewebdevjavascript
그래서 저는 Udemy로 가서 호평을 받은 Stephen Gridercourse를 시작했습니다.
그는 Yelp API로 식당 프로그램을 만들었지만 Yelp가 인도에서 사용할 수 없기 때문에 저는 Zomato API를 계속 사용하기로 했습니다.Zomato는 인도에서 유행하는 식품 배송 플랫폼이다.
우리 식당 검색 프로그램은 음식에 대한 정보를 검색하고 성가가 높고 가격이 적당하며 돈을 많이 쓰는 세 가지 식당을 검색할 수 있는 검색란이 있을 것이다.
expo cli를 사용하여 React 네이티브 프로젝트를 생성합니다.따라서 터미널로 가서 다음 명령을 실행합니다.
npx expo-cli init restroSearch
다음 화면이 표시됩니다.enter 키를 누릅니다.data:image/s3,"s3://crabby-images/263f0/263f0caaed1cab296e2d6075e22b70917a06f709" alt=""
그런 다음 항목의 이름을 입력하라는 메시지가 표시됩니다.같은 이름restroSearch를 입력하고 enter 키를 누르십시오.
data:image/s3,"s3://crabby-images/05b8b/05b8b405e03a3b052d61a177aea528b6284830a2" alt=""
설치가 완료되면 새 폴더restroSearch를 만듭니다.이 옵션으로 변경하고 npmstart를 실행합니다.브라우저에서 열립니다 http://localhost:19002 /.
data:image/s3,"s3://crabby-images/263f6/263f65c32be4447264bef2738522f47bb65c2496" alt=""
현재, 나는 물리적 안드로이드 장치에서 출력을 실행하고 있다.물리적 장치에서 실행하려면 Play Store and install Expo
이제 핸드폰에 있는 앱을 켜세요.아래 화면이 표시됩니다.
data:image/s3,"s3://crabby-images/1bdba/1bdbacf41496bf2b0bbb6cf3df2079b5d254672d" alt=""
QR코드를 스캔하면 카메라를 켤 수 있다.브라우저의 QR 코드를 가리키면 모든 설치가 완료되면 아래 화면을 볼 수 있습니다.
data:image/s3,"s3://crabby-images/1df87/1df87755be7e49837c9d5b669fff2812c7efe846" alt=""
프로젝트에서 StackNavigator를 사용합니다.따라서 이러한 의존 항목을 계속 설치합니다.
npm install react-navigation
npx expo-cli install react-native-gesture-handler react-native-reanimated
Visual Studio 코드에서 항목을 열고 응용 프로그램을 교체합니다.js의 내용은 다음과 같다.data:image/s3,"s3://crabby-images/89ffe/89ffe1805f60bac372e57270f1a275bb6cb0033e" alt=""
이제 파일 검색 화면을 만듭니다.js내 src-> 화면.이 두 폴더를 더 만들어야 합니다.
data:image/s3,"s3://crabby-images/e4b84/e4b84faaaf7f24e94a5f2a40ab509f6cab9179d7" alt=""
이것은 Android 응용 프로그램의 응용 프로그램을 바꾸고 SearchScreen 구성 요소를 표시합니다.
data:image/s3,"s3://crabby-images/19ae1/19ae19c4acbfb9f5b41139b8049414c604c28866" alt=""
먼저 검색 표시줄을 만듭니다.우선 src에components 폴더를 만듭니다.파일 검색 표시줄을 만듭니다.안에 js예요.여기에 다음 내용을 추가합니다.
여기에서 우리는 react native에서 온 View, Text Input, 스타일시트를 사용합니다.우리는 엑스포를 검색하기 위해 아이콘도 사용했다.
react native의 조형은 대부분camelCase 기호를 통해 완성됩니다.
data:image/s3,"s3://crabby-images/2d16a/2d16a09022589730b3d1eaa836d7c5385018f367" alt=""
현재, 우리의 응용 프로그램은 아래와 같다.
data:image/s3,"s3://crabby-images/89278/89278900a8e61623f8b1851a2b93ec2f25716b56" alt=""
상위 구성 요소인 SearchScreen에서 SearchBar로 상태를 전달하고 리셋을 사용하여 SearchBar에서 변경합니다.
따라서 SearchScreen을 엽니다.상태를 추가하여 검색 모음에 전달합니다.
data:image/s3,"s3://crabby-images/90222/9022281e5e50180f80b8f7f7ab1dae2ec035c696" alt=""
이제 검색 표시줄 구성 요소에서 사용할 것입니다.
data:image/s3,"s3://crabby-images/0cb1e/0cb1e7902ccc6ad690c873acf3a8bd06aaec84a3" alt=""
우리의 검색은 사용자가 장치의 enter 키를 눌렀을 때만 시작해야 합니다.따라서 우리는 다음 단계에 같은 논리를 추가할 것이다.SearchScreen에 새 콜백을 추가합니다.나중에 zomato API를 호출합니다.
data:image/s3,"s3://crabby-images/3981b/3981b365cdf7087295eece039e4ed1dcc372edb5" alt=""
다음은 검색 표시줄 구성 요소에 같은 내용을 추가합니다.
data:image/s3,"s3://crabby-images/35864/35864dc893d37af4c1b47e3b3f30b15ca2d181ce" alt=""
이제 우리는 그것을 테스트할 수 있다.안드로이드 프로그램을 열고 그 위에 내용을 입력하고 녹색 enter 키를 누르십시오.
data:image/s3,"s3://crabby-images/f36bc/f36bc20ff98ac36ed8e567db5427fd2e9c44a163" alt=""
제출 후, 우리는 단말기에서 컨트롤러 로그를 볼 수 있습니다.
data:image/s3,"s3://crabby-images/5b701/5b7019eac66e4c075d65edc02f522812c8afc46d" alt=""
다음은 식당 목록을 가져오고 모든 내용을 검색하기 위해 API 호출을 실행합니다.따라서 https://developers.zomato.com/api로 이동하여 API 키를 가져옵니다.
Zomato의 문서는 매우 좋습니다. swagger가 포함되어 있기 때문에 그곳에서 API 자체를 검사할 수 있습니다.
data:image/s3,"s3://crabby-images/254c5/254c5bdf2bcbaad7d1fc8567fa3e18f5d624a064" alt=""
우리는 주로 식당 검색 API를 사용할 것이다.나는 반가로르의 식당만 검색할 것이기 때문에 아래의 GETapi를 사용할 것이다.헤더에 API 키를 전달해야 합니다.
https://developers.zomato.com/api/v2.1/search?entity_id=4&entity_type=city&q=Kabab
다음에 우리는 터미널로 가서axios를 설치할 것이다npm install axios
다음은 zomato API를 사용하려면 axios 실례 방법을 사용합니다.src에서 폴더api와 파일zomato를 만듭니다.안에 js예요.data:image/s3,"s3://crabby-images/9f1ed/9f1ed1955f366023f94331defcb924d3993ab0bf" alt=""
다음으로, 우리는 다시 사용할 수 있는 갈고리를 만들 것이다.src에 폴더 연결을 만들고 파일useResults를 만듭니다.안에 js예요.여기서, 우리는zomato url을 클릭하고 결과에 결과를 설정합니다.응용 프로그램이 불러올 때 데이터를 얻을 수 있도록 초기 검색을 사용하고 있습니다.
data:image/s3,"s3://crabby-images/c0125/c0125ff5d9905e79d6710b19c62ce86575d0b126" alt=""
이제 SearchScreen 구성 요소에서 이러한 연결을 사용합니다.
data:image/s3,"s3://crabby-images/ff032/ff032e14a6ff7fe4db278b46d295d4eda0e322e3" alt=""
지금, 나는 우리android 응용 프로그램에서 결과를 얻었다.
data:image/s3,"s3://crabby-images/78013/78013bc8d6a36a1c3cf0f264386d38eea31033ea" alt=""
다음은 화면에 이 결과를 표시하기 위한 구성 요소를 만들 것입니다.구성 요소 결과 목록을 만들 것입니다.회사 명
data:image/s3,"s3://crabby-images/74fbd/74fbd2e1d47de576a9792f3aab2e56694fd87bb2" alt=""
이제 SearchScreen에서 제목을 전달합니다.
data:image/s3,"s3://crabby-images/d85b5/d85b56c4a3af538bcfe35191b7c4ba3f14db12f0" alt=""
우리의 응용 프로그램에서, 우리는 가격에 따라 세 가지 다른 종류의 식당을 표시할 것이다.현재,zomato는 가격 구간값에 따라 분류합니다.우리는 그룹을 필터링하고 서로 다른 가격표를 서로 다른 ResultsList에 전달할 것입니다.
data:image/s3,"s3://crabby-images/b2f00/b2f003a8e5d6dba941164f36cab4b15311bd7a55" alt=""
다음은 ResultsList 구성 요소에서 사용합니다.
data:image/s3,"s3://crabby-images/174b4/174b496cc50cae203e8d5b00bad94714691ce40e" alt=""
이것은 우리의 응용 프로그램에 다음과 같은 내용을 표시할 것이다.
data:image/s3,"s3://crabby-images/f15c1/f15c1b0fde8d41abf2bb92ccad9ddfe29f7e5f43" alt=""
이제 데이터를 사용하고 정확하게 표시합시다.우리는 평면 목록을 사용하여 수평 목록을 표시하지만, 다른 구성 요소를 사용하여 모든 항목을 표시합니다.
data:image/s3,"s3://crabby-images/b2036/b2036b8b214a713120f0cd0b4ebb20f28dd0e37a" alt=""
다음은 ResultsDetail 구성 요소를 만듭니다.그것은 단지 이 항목을 통행증으로 표시하고, 그것과 일부 조형만 표시할 수 있다.
data:image/s3,"s3://crabby-images/40835/4083576a42696bbe29db8609d77bb729111872fd" alt=""
응용 프로그램의 거의 전체 버전으로 표시됩니다.
data:image/s3,"s3://crabby-images/15b6b/15b6b85f392348c11436cbd0a1d2ef03d022280f" alt=""
너는 우리가 안드로이드 핸드폰에서 수직으로 굴러갈 수 없다는 것을 이미 알아차렸을 것이다.따라서 이 문제를 해결하려면 ScrollView 패키지 목록을 사용해야 하며, 보기를 빈 div로 변경해야 합니다
data:image/s3,"s3://crabby-images/88005/88005cb23e40286b4f0abf44567e7c0b436307ca" alt=""
이제 사용자가 어떤 식당을 눌렀을 때 이 식당에 대한 더 자세한 정보를 표시하는 논리를 추가할 것입니다.이렇게 하려면 새 화면을 만들어야 합니다.우선 응용 프로그램에 연결합시다.회사 명
data:image/s3,"s3://crabby-images/ec699/ec69965e0f0cebbe55eba842a59e7bfc454e5edc" alt=""
그런 다음 탐색 논리를 ResultsList 구성 요소에 추가합니다.우리는 withNavigation을 사용하고 식당 id를 ResultsShow 구성 요소에 전달합니다.With had는 Touchable Opacity가 있는 Results Detail을 포장했기 때문에 클릭하면 Results Show를 볼 수 있습니다
data:image/s3,"s3://crabby-images/1f871/1f8719b1200bfe567367b7a1d4982623b2cdfdf4" alt=""
이제 스크린 폴더에 ResultsShowScreen 구성 요소를 만듭니다.여기에서, 우리는 부모 구성 요소에서 id를 받아서, 식당의 상세한 정보를 얻기 위해zomatoapi에 대한 다른api 호출에 사용합니다.
data:image/s3,"s3://crabby-images/592ea/592eae7bf64ac4eb409c179246c0b4a21f4495b6" alt=""
이어서 우리는 식당의 세부 사항을 보여주기 위해 요소를 추가할 것이다.
data:image/s3,"s3://crabby-images/b3312/b3312a9c86b0eafdf3844c9e1c750ca69ef3a082" alt=""
다음으로, 우리는 이 요소들을 위해 양식을 추가할 것이다.
data:image/s3,"s3://crabby-images/4d730/4d7301144168ec06fc3b69af2be101590686306e" alt=""
지금 어떤 식당을 누르면 식당의 상세한 정보를 열 수 있습니다.
data:image/s3,"s3://crabby-images/f568f/f568fc273b1918b4690a44c972aec092d7aabefe" alt=""
githubhere에서 같은 코드를 찾을 수 있고 here에서 apk 파일을 다운로드할 수 있습니다.
Reference
이 문제에 관하여(Zomato API를 사용하는 레스토랑 검색 어플리케이션(React Native)), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://dev.to/nabendu82/restaurant-search-app-with-react-native-using-zomato-api-5g5b텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
우수한 개발자 콘텐츠 발견에 전념
(Collection and Share based on the CC Protocol.)