react-native-custom-dialog
React Native 自定义Dialog组件
组件样式
Dialog类别 | iOS | Android |
---|
图片头部 + 标题 | data:image/s3,"s3://crabby-images/52a09/52a097fbbe1da4ba00ff4d302e12389228743e31" alt="" | data:image/s3,"s3://crabby-images/b10ea/b10ea404dcb8eb2f647188fdb825cf7d45512a3e" alt="" |
图片头部 + 内容 | data:image/s3,"s3://crabby-images/21944/2194449fbb39e20ff9bbf8e9a10029de9c1e7615" alt="" | data:image/s3,"s3://crabby-images/c6c14/c6c149b6245d98bc0d7a0dfdc5cbfc504005a84a" alt="" |
标题 + 内容 | data:image/s3,"s3://crabby-images/f29c9/f29c97cd3b18c74f49d507c9b0dfedafb9ae1796" alt="" | data:image/s3,"s3://crabby-images/37e8f/37e8f28751d48f3dde6aa6fad1eeeeac3881a19f" alt="" |
只有标题 | data:image/s3,"s3://crabby-images/b2f81/b2f811616ba8746b70128591776122bc7ee088e2" alt="" | data:image/s3,"s3://crabby-images/670fb/670fb5d7427f82cfaa094401ddc0fde7969829cd" alt="" |
只有内容 | data:image/s3,"s3://crabby-images/f3820/f38208973b53aca2d32cb273d3a59781c141b8d3" alt="" | data:image/s3,"s3://crabby-images/32a97/32a97d17444fbf6034db11ac080470cc7e7f126c" alt="" |
标题 + 内容图片 + 内容 | data:image/s3,"s3://crabby-images/3c5e7/3c5e76fcf7896d2840d5f133b573e6264ec84b00" alt="" | data:image/s3,"s3://crabby-images/87533/87533ca9c3ac36fdf1dccebe385dae5426b00e5a" alt="" |
标题 + 内容 + 竖直排列按钮 | data:image/s3,"s3://crabby-images/d4550/d4550ac33de71e33da19a3470427eea1553d8bb4" alt="" | data:image/s3,"s3://crabby-images/3c8a8/3c8a851fe3dbc1f24c86faf429c7cb337019fa12" alt="" |
自定义内容 | data:image/s3,"s3://crabby-images/c168d/c168dba296953989c2981d3fdb1526e5891ac04b" alt="" | data:image/s3,"s3://crabby-images/4f676/4f676e486ec8b839dd7fc90eacdc2da32fc8441c" alt="" |
组件用法
- 安装组件
npm i react-native-custom-dialog --save
- 引入组件
import React, {Component} from 'react';
import CustomDialog from 'react-native-custom-dialog';
export default class index extends Component {
render() {
return (
<CustomDialog ref={customDialog => {this.customDialog = customDialog}}/>
)
}
}
- 显示组件
this.customDialog.show({
headerImg: require('顶部区域图片uri'),
title: "标题",
content: "内容",
actions: [
{name: "确定", func: () => {global.toast("确定") }, style: {color: "#0b80bb"}},
{name: "取消"},
],
horizontal: true/false,
cancelable: true/false,
contentImg: require('内容区域图片uri'),
contentStretch: true/false,
contentStyle: {},
titleStyle: {},
})
组件方法
show(option)
hide()
reset()
注意点
- 该组件使用自带的Model,自带一定的zIndex,使用时注意层级变换。
- 在同一界面时,由于使用同一个组件对象,若显示不同的Dialog(如:A显示title、B不显示title),则需要在
show()
之前先重置,调用 reset()
。