最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

React Native预设占位placeholder的使用

来源:懂视网 责编:小采 时间:2020-11-27 22:28:42
文档

React Native预设占位placeholder的使用

React Native预设占位placeholder的使用:当我们首次打开一个app的时候会请求接口获取数据,那么获取数据的这段时间展示什么给用户呢?国内很多app都是千篇一律的用一个菊花代替(俗称loading),或者更有心一点的做一个好看一点的loading,但是这样当拿到数据渲染页面的时候会很生硬的切换,总感觉很
推荐度:
导读React Native预设占位placeholder的使用:当我们首次打开一个app的时候会请求接口获取数据,那么获取数据的这段时间展示什么给用户呢?国内很多app都是千篇一律的用一个菊花代替(俗称loading),或者更有心一点的做一个好看一点的loading,但是这样当拿到数据渲染页面的时候会很生硬的切换,总感觉很

当我们首次打开一个app的时候会请求接口获取数据,那么获取数据的这段时间展示什么给用户呢?国内很多app都是千篇一律的用一个菊花代替(俗称loading),或者更有心一点的做一个好看一点的loading,但是这样当拿到数据渲染页面的时候会很生硬的切换,总感觉很low。

facebook首页列表是用一个接近真实布局的骨架动画来代替loading,这东西可以称之为skeleton screen或者placeholder,但是翻译过来真不知道该翻译成什么合适,这么做的好处就是在内容加载完成后可以做到流畅无缝切换真实布局,细节决定产品的质量,我觉得facebook对用户体验,交互的细节做的挺不错。先上一张我的fb截图。


rn-placeholder是rn版本的placeholder,我在次基础上做了对flastlist,listview,SectionList的适配封装。先看一下在我的开源项目中的效果:


看完上面的效果是不是感觉比传统的loading要舒服多了,下面是example:

一:flastlist,listview,SectionList使用demo

 import { ListItem, ListParagraph } from 'components';
 export default class Zi extends Component {
 render() {
 const { loading } = this.props;
 return (
 <ListParagraph
 ParagraphLength={4} // 要渲染的条数
 isLoading={loading} // loading状态
 hasTitle // 是否需要title
 list={this.sectionList} // 这就是SectionList的函数
 />
 );
 }

 }

注:ListParagraph组件目前在我开源项目中,还没有添加到npm,有需要的到我项目中拿,项目地址在文章末尾

二:左图右内容布局

import Placeholder from 'rn-placeholder';
export default class Cheng extends Component {
 render() {
 return <Placeholder.ImageContent
 hasRadius //左边的方块是否需要圆角
 size={60} // 大小
 animate="fade" // 动画方式
 lineNumber={4} // 右边的线显示的数量
 lineSpacing={5} // 行间距的距离
 firstLineWidth=90% // 第一行的宽度
 lastLineWidth="70%" // 最后一行的宽度
 onReady={this.state.isReady} // 内容是否加载完毕,如果加载完毕会切换到你的真实内容布局
 >
 <Text>左图右内容布局</Text>
 </Placeholder.ImageContent>
 } 
 }

三:段落布局

 import Placeholder from 'rn-placeholder';
 export default class Cheng extends Component {
 render() {
 return <Placeholder.Paragraph
 size={60}
 animate="fade"
 lineNumber={4}
 lineSpacing={5}
 lastLineWidth="30%"
 onReady={this.state.isReady}
 >
 <Text>段落布局</Text>
 </Placeholder.Paragraph>
 } 
 }


四:还有Line(行布局),Media(图片布局),使用方法跟 三 一样。

完美收官!

项目demo地址:https://github.com/duheng/Mozi

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

React Native预设占位placeholder的使用

React Native预设占位placeholder的使用:当我们首次打开一个app的时候会请求接口获取数据,那么获取数据的这段时间展示什么给用户呢?国内很多app都是千篇一律的用一个菊花代替(俗称loading),或者更有心一点的做一个好看一点的loading,但是这样当拿到数据渲染页面的时候会很生硬的切换,总感觉很
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top