在react Native开发中,如果要实现弹窗效果,通常的方案是使用官方的Modal组件。不过,官方的Modal组件会有一些缺陷,比如在Android端无法全屏显示,而在iOS端中,当打开一个新的ViewController时会被Modal 组件给覆盖掉等。因此,在React Native应用开发中,为了屏蔽这些兼容性问题,我们可以使用react-native-root-siblings插件提供的RootSiblings组件来实现。
事实上,RootSiblings组件是对官方Modal组件的进一步的封装,能够有效的解决Modal组件的一些显示问题,使用方式也和Modal组件差不多,如下所示。
import RootSiblings from 'react-native-root-siblings';
const alertShare = (onItemPress, onCancel, title) => {
if (global.siblingShare) {
global.siblingShare.destroy();
onCancel();
global.siblingShare = undefined;
} else {
global.siblingShare = new RootSiblings( (
<SharePanel
onItemPress={onItemPress}
onCancel={onCancel}
title={title}/>
) ); }
};
//调用分享方法
alertShare(onItemPress, () => {
startAnimation(setShow(false));
})
可以看到,只需要使用RootSiblings组件包裹需要分享的内容即可完成分享功能。
除此之外,我们还可以使用react navigation来实现购物车弹窗,原理是react navigation的路由页面背景的透明化。下面直接上代码,如果还不清楚React Navigation使用的,可以参考React Navigation 5.x基本使用,最新的6.x版本使用方式大体类似。
首先,我们来看一下navigation的index.js的代码。
const RootStack = createStackNavigator();
const Navigator = () => {
return (
<>
<NavigationContainer ref={navigationRef}>
<RootStack.Navigator mode="modal" initialRouteName="Main">
<RootStack.Screen
name="Main"
component={MainStackScreen}
options={{headerShown: false}} />
<RootStack.Screen
name="MyModal"
component={ModalScreen}
options={{
headerShown: false,
cardStyle: {
backgroundColor: 'transparent',
shadowColor:'transparent'
},
cardStyleInterpolator: ({current: {progress}}) => {
return {
overlayStyle: {
opacity: progress.interpolate({
inputRange: [0, 1],
outputRange: [0, 0.5],
extrapolate: 'clamp',
}),
},
}
},
}}
/>
</RootStack.Navigator>
</NavigationContainer>
</>
);
};
export default Navigator;
可以看到,为了使用路由的方式实现透明效果,我们在配置RootStack.Screen的options参数,特别需要注意cardStyle和cardStyleInterpolator两个参数,建议直接将options里面的内容可以直接拷贝过去。接下来就是ModalsScreen.js的代码:
const ModalStack = createStackNavigator()
export default function ModalsScreen() {
return (
<ModalStack.Navigator headerMode='none'>
<ModalStack.Screen name='ShopingCartScreen' component={ShopingCartScreen} options={{
headerShown: false,
cardStyle: { backgroundColor: 'transparent' },
cardOverlayEnabled: true,
}}/>
</ModalStack.Navigator>
)
}
除了需要将ModalScreen的背景设置为透明外,还需要将具体的业务页面的背景也设置为透明。可以看到,在上面的代码中,我们将ShopingCartScreen页面的背景也设置为了透明。接下来,在需要跳转的地方使用navigate执行跳转即可。
navigate('MyModal', {screen: 'ShopingCartScreen'})
接下来就可以看到效果了。
来源:https://segmentfault.com/a/1190000041738326
在react-native上是怎么写样式的吧,和传统的web不一样的是,在react-native上面是没有css代码,不过得益于Yoga,我们可以在客户端上像写css一样的去书写我们的样式。
初始化 wkwebview,设置 message handler,native 端注册了 testecho 的messageHandler,实现 WKScriptMessageHandler协议,执行JS 代码 ,所以 JS 可以通过 window.webkit.messageHandlers.testecho.postMessage 来回调客户端,和文档中说的一样
因为js语言的特性,使用node开发程序的时候经常会遇到异步处理的问题。对于之前专长App开发的我来说,会纠结node中实现客户端API请求的“最佳实践”。下面以OAuth2.0为场景,需要处理的流程:获取access token、使用获取到的token,发起API请求、处理API数据
GraphQL是一个API查询语言,他可以将使用PostgreSQL写的server代码自动生成Query或者Mutation,非常的方便。而Apollo Client就是一个强大的JavaScript GraphQL客户端。对于cache,在Apollo Client中有着强大的管理策略。
React Native 是 Facebook 2015年开源的 Javascript 框架,旨在使用 Javascript 高效开发手机端 App。根据大众的需求,我们列出了一个有用的React-Native UI库列表,可以帮助你更好地入门React Native。
在React Native 中由于业务的需要, 我们往往要在诸多的页面间,组件之间做一些参数的传递与管理, 在这里我总结了几大经过验证,稳定好用的方式给大家
随着 H5 标准的发布以及推广,使得移动应用的开发也受到了很大影响,出于效率、成本等原因,移动应用的开发不再完全依赖于 “原生”。近日越发火热的混合应用(Hybrid App)介于 Web 应用和原生应用之间
react-native打包安卓apk的时候,报错Cannot get property packageName on null object,完全没有头绪,研究了半天才发现竟然是因为package.json里面scripts自定了命令导致的,无法理解为何会影响安卓打包并且报错packageName null
之前写的项目都是人家编写好的脚手架,里面包含项目所需的环境文件,但由于有些东西用不到打包增加软件体积,所以自己从头搭建个环境。是基于 Native Base + react-navigation + Redux 的 React Native 脚手架,现在项目环境如下
Flutter作为备受关注的跨平台的开发框架,长远来看,前景肯定是比较好的,在其基础组件还未完善与成熟之前,能够高效的复用现有的native组件,是比较合适的方案。官方提供了Plugin的方式,允许将一个成熟的native组件(比如mapview)
内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!