Rumah >hujung hadapan web >tutorial js >Beralih daripada React.js kepada React Native
Sebagai pembangun bahagian hadapan dengan pengalaman dalam React.js, mengembangkan set kemahiran anda untuk memasukkan React Native boleh membuka peluang menarik dalam pembangunan apl mudah alih. Walaupun pembangunan web dan mudah alih berkongsi beberapa persamaan, terdapat perbezaan utama yang boleh membentuk cara kami mendekati setiap platform. Artikel ini akan merangkumi perbezaan utama antara pembangunan web dan mudah alih, perbezaan antara React.js dan React Native, dan, yang paling penting, bagaimana pengetahuan anda tentang React.js boleh membantu anda beralih kepada React Native dengan lancar.
Sebelum menyelami butiran React.js dan React Native, adalah penting untuk memahami cara pembangunan web dan mudah alih berbeza.
React.js dan React Native kedua-duanya dibina oleh Facebook dan berkongsi falsafah yang sama, tetapi ia berbeza dalam beberapa cara.
// React.js Example of Virtual DOM Rendering import React, { useState } from 'react'; const Counter = () => { const [count, setCount] = useState(0); return ( <div> <h1>Count: {count}</h1> <button onClick={() => setCount(count + 1)}>Increment</button> </div> ); }; export default Counter;
import React, { useState } from 'react'; import { View, Text, Button } from 'react-native'; const Counter = () => { const [count, setCount] = useState(0); return ( <View> <Text>Count: {count}</Text> <Button title="Increment" onPress={() => setCount(count + 1)} /> </View> ); }; export default Counter;
// React.js Example import React from 'react'; import './App.css'; const App = () => { return ( <div className="container"> <h1 className="title">Hello, React.js!</h1> </div> ); }; export default App; // App.css .container { padding: 20px; text-align: center; } .title { font-size: 2rem; color: #333; }
// React Native Example import React from 'react'; import { View, Text, StyleSheet } from 'react-native'; const App = () => { return ( <View style={styles.container}> <Text style={styles.title}>Hello, React Native!</Text> </View> ); }; const styles = StyleSheet.create({ container: { padding: 20, justifyContent: 'center', alignItems: 'center', }, title: { fontSize: 24, color: '#333', }, }); export default App;
// React.js Example using React Router import React from 'react'; import { BrowserRouter as Router, Route, Switch, Link } from 'react-router-dom'; const Home = () => <h1>Home</h1>; const About = () => <h1>About</h1>; const App = () => ( <Router> <nav> <Link to="/">Home</Link> <Link to="/about">About</Link> </nav> <Switch> <Route exact path="/" component={Home} /> <Route path="/about" component={About} /> </Switch> </Router> ); export default App;
// React Native Example using React Navigation import React from 'react'; import { NavigationContainer } from '@react-navigation/native'; import { createStackNavigator } from '@react-navigation/stack'; import { Button, Text, View } from 'react-native'; const HomeScreen = ({ navigation }) => ( <View> <Text>Home Screen</Text> <Button title="Go to About" onPress={() => navigation.navigate('About')} /> </View> ); const AboutScreen = () => ( <View> <Text>About Screen</Text> </View> ); const Stack = createStackNavigator(); const App = () => ( <NavigationContainer> <Stack.Navigator initialRouteName="Home"> <Stack.Screen name="Home" component={HomeScreen} /> <Stack.Screen name="About" component={AboutScreen} /> </Stack.Navigator> </NavigationContainer> ); export default App;
, dsb., dan API penyemak imbas.
// React.js Button Example import React from 'react'; const App = () => { return ( <div> <button onClick={() => alert('Button clicked!')}>Click Me</button> </div> ); }; export default App;
// React Native Button Example import React from 'react'; import { View, Text, TouchableOpacity } from 'react-native'; const App = () => { return ( <View> <TouchableOpacity onPress={() => alert('Button clicked!')}> <Text>Click Me</Text> </TouchableOpacity> </View> ); }; export default App;
Contoh ini menunjukkan cara React Native boleh mengakses kamera peranti dengan mudah—ciri yang tidak begitu mudah tersedia dalam pembangunan web tanpa API khusus penyemak imbas.
// React Native Example using the Camera import React, { useState, useEffect } from 'react'; import { View, Text, Button } from 'react-native'; import { Camera } from 'expo-camera'; const CameraExample = () => { const [hasPermission, setHasPermission] = useState(null); const [cameraRef, setCameraRef] = useState(null); useEffect(() => { (async () => { const { status } = await Camera.requestPermissionsAsync(); setHasPermission(status === 'granted'); })(); }, []); if (hasPermission === null) { return <Text>Requesting camera permission...</Text>; } if (hasPermission === false) { return <Text>No access to camera</Text>; } return ( <View> <Camera ref={ref => setCameraRef(ref)} style={{ height: 400 }} /> <Button title="Take Picture" onPress={async () => { if (cameraRef) { let photo = await cameraRef.takePictureAsync(); console.log(photo); } }} /> </View> ); }; export default CameraExample;
Pembangunan React.js:
Untuk React.js, anda biasanya menggunakan alat seperti create-react-app atau Next.js untuk memutarkan persekitaran pembangunan. Tiada SDK khusus mudah alih diperlukan.
React NativeDevelopment:
Untuk React Native, anda sama ada memerlukan Expo CLI (lebih mudah untuk pemula) atau tetapan pembangunan asli langsung seperti Android Studio atau Xcode.
Seperti yang anda lihat, struktur komponen adalah serupa, tetapi komponen sebenar adalah berbeza. Ini kerana React Native menggunakan komponen asli yang memetakan terus ke paparan khusus platform, manakala React.js menggunakan elemen HTML yang dipaparkan dalam penyemak imbas.
Berita baik untuk pembangun React.js ialah peralihan kepada React Native adalah perkembangan semula jadi. Banyak konsep dan prinsip yang anda sudah kenali dibawa ke pembangunan mudah alih.
React Native berkongsi seni bina dipacu komponen React.js, bermakna idea untuk memecahkan apl anda kepada komponen boleh guna semula tetap sama. Anda masih akan menggunakan komponen berfungsi dan kelas, bersama-sama dengan cangkuk seperti useState dan useEffect.
Jika anda telah menggunakan Redux, Context API atau mana-mana perpustakaan pengurusan negeri lain dalam React.js, prinsip yang sama digunakan dalam React Native. Anda akan mengendalikan keadaan dan aliran data dengan cara biasa, yang memudahkan keluk pembelajaran.
Dengan React Native, anda boleh menggunakan semula sebahagian besar logik JavaScript anda yang sedia ada. Walaupun komponen UI berbeza, kebanyakan logik perniagaan anda, panggilan API dan pengurusan keadaan boleh digunakan semula merentas kedua-dua apl web dan mudah alih.
JSX ialah asas bagi kedua-dua React.js dan React Native. Jadi, jika anda selesa menulis JSX untuk mencipta antara muka pengguna, anda akan berasa selesa dalam React Native.
Ekosistem React yang lebih luas—perpustakaan seperti React Navigation, React Native Paper dan juga alatan seperti Expo—membolehkan penyepaduan yang lancar dan pembangunan yang lebih pantas. Jika anda telah bekerja dengan perpustakaan web, anda akan dapat memanfaatkan rakan sejawat mudah alih atau alatan serupa dalam React Native.
Pembangunan Merentas Platform: Salah satu kelebihan terbesar React Native ialah anda boleh membina untuk kedua-dua iOS dan Android dengan pangkalan kod tunggal, mengurangkan keperluan untuk pasukan pembangunan khusus platform.
Prestasi: Apl React Native sangat berprestasi, kerana ia berinteraksi dengan API asli dan menjadikan komponen UI asli, menjadikannya tidak dapat dibezakan daripada apl yang dibina dengan Swift atau Java/Kotlin.
Komuniti Aktif: React Native mempunyai komuniti yang besar dan aktif. Banyak sumber, perpustakaan pihak ketiga dan alatan tersedia untuk mempercepatkan proses pembelajaran dan pembangunan anda.
Masa Lebih Cepat untuk Memasarkan: Dengan sifat merentas platform React Native dan kebolehgunaan semula kod, pembangun boleh mengurangkan dengan ketara masa yang diperlukan untuk melancarkan apl.
Peralihan daripada React.js kepada React Native ialah langkah yang bermanfaat untuk mana-mana pembangun bahagian hadapan yang ingin mengembangkan kepakaran mereka kepada pembangunan mudah alih. Walaupun aplikasi web dan mudah alih berbeza dalam interaksi pengguna, penggunaan dan reka bentuk, prinsip yang dikongsi antara React.js dan React Native, terutamanya dari segi struktur komponen, pengurusan keadaan dan sintaks JSX, menjadikan peralihan lebih lancar. Dengan mempelajari React Native, anda bukan sahaja akan meningkatkan set kemahiran anda tetapi juga membuka pintu untuk membina apl mudah alih merentas platform dengan lebih cekap.
Atas ialah kandungan terperinci Beralih daripada React.js kepada React Native. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!