Build Powerful App With Local Static Server Which Support Both Android And iOS Amazing ⚡️
IServer | |
---|---|
⚡️ | Powerful Kotlin android-side is build on scratch with kotlin |
😎 | Unzip Feature. unzip files through this module |
📱 | Multiplatform. iOS, Android |
⏱ | Fast. About TO Migrating to RN New Arch(JSI) |
Static typing Full-Support TypeScript |
Key capabilities
- Both android and ios are supported. ios-side is powered by GCDWebserver and android-side is build on scratch by myself, stable and reliable
- I'm also about to migrating this package to JSI or Turbomodule when it's ready to go
yarn add react-native-iserver
or
npm i --save react-native-iserver
ETC: you'd like to download a zip file and start local server to server these files
ETC: 比如你想下载一个压缩包、解压后并启动本地静态资源服务器来提供文件的访问
import RNFS from 'react-native-fs';
import IServer from 'react-native-iserver';
const serverPath = '';
const port = 8080;
async function execute() {
let url = ''
let path = ''
let { jobId, promise: task } = RNFS.downloadFile({
fromUrl: url,
toFile: path,
});
try {
let zipExists = await RNFS.exists(path)
if (!zipExists) {
await task
}
IServer.unzip({
zip: path,
dest: serverPath,
onError: (e) => {
//zip file is not valid
}
})
} catch (error) {
}
}
useEffect(() => {
IServer.listen({
onStart: () => {
//starting to unzip file
},
onSuccess: () => {
IServer.startWithPort({
directoryPath: serverPath,
port
}).then(started => {
console.log('the server start ' + (started ? 'success' :'failed'))
})
}
})
}, [])
启动本地静态资源服务
(options: {
directory: string;
port: number;
indexFileName?: string; // index.html
cacheAge?: number; // 3600 on ios and 0 on android
}) => void;
server是否正在运行
() => void;
停止本地server
() => void;
解压本地ZIP压缩包,解压状态需通过listen方法进行监听
(options: {
zip: string;
dest: string;
onError?: (e: string) => void;
}) => void;
解压本地ZIP压缩包,解压状态需通过listen方法进行监听
(configs?: {
onStart?: () => void;
onSuccess?: () => void;
onError?: (e) => void;
}) => void;
ReactNativeIServer was created by @yaaliuzhipeng
react-native-iserver is available under the MIT license. See the LICENSE file for more info.