小码哥HTML5培训—文章持续更新中......
实现首页中间的内容栏
今天实现首页中间的内容栏,原效果如下:
data:image/s3,"s3://crabby-images/06d1f/06d1f741c9b2dde1cc841a65f91854044727c030" alt=""
红框就是今天需要实现的内容
这里可以拆解成四个部分,每个部分都是由相同组件,填充不同内容来实现。
简单布局的实现
在homebean首页json数据中,设置了一个itemBeans的集合数据,存放着我们需要实现的四个部分组件的数据。
data:image/s3,"s3://crabby-images/ed0cb/ed0cb0e8ed6c29c16544aee6a6b14c85003ed33d" alt=""
在homepage中遍历itemBeans这个集合数据,并简单的创建四个View组件,预先占位,后面再逐一实现。
data:image/s3,"s3://crabby-images/d4d19/d4d193b8169df5d196f7755a797636db0155342f" alt=""
定义一个CenterBar组件
创建CenterBar的组件,这个组件就是四个部分的组件了。
data:image/s3,"s3://crabby-images/d56d3/d56d38691bc37ff9e73653d90051d321a5462e39" alt=""
使用CenterBar这个组件
在homepage中使用CenterBar这个组件替换掉遍历创建的View组件
data:image/s3,"s3://crabby-images/2f512/2f512bb037b3f5ffd52c51cb660771ecee689262" alt=""
传数据到CenterBar组件中
1.传递数据到CenterBar中
CenterBar设置一个属性了itemBean来接收itemBeans数据中对应item对象内容。
data:image/s3,"s3://crabby-images/29afb/29afbe2c4166c2df6ec738823789ce36c7fc56a4" alt=""
2.CenterBar接收数据
在CenterBar通过this.props.itemBean来获取接受到的itemBean数据
//接收数据
var itemBean=this.props.itemBean;
data:image/s3,"s3://crabby-images/a5199/a5199cc1f236c2e1e3b62c3413648aba19c77856" alt=""
实现CenterBar布局
1.布局的搭建
接收完数据,开始CenterBar布局搭建,这里拆分下结构,如图:
data:image/s3,"s3://crabby-images/2b04d/2b04d0ff0a149e340639179f582d0d66e8ca638c" alt=""
分为左中右结构,中间和右边部分又分为上下结构。
data:image/s3,"s3://crabby-images/46f3a/46f3a15970a5d8fc2149c9b3da1852a6ef1139b3" alt=""
设置属性flexDirection为横向布局row,给左中右三部分设置对应的样式,设置flex属性(类似权重属性),宽度比例为1:1:1。
data:image/s3,"s3://crabby-images/dac6a/dac6a36fd6abd99442ce6ed936ffbeca64b5243c" alt=""
2.完善中间和右边布局
给每一项填充对应数据。
data:image/s3,"s3://crabby-images/2e534/2e5342f34f83de10266f900478071e4ee394860a" alt=""
因为中间和右边代码一致,抽取重复的代码,只需传入对应的index值,获取对应数据即可。
data:image/s3,"s3://crabby-images/55693/556936a5bb408efc1b27d28a7ad2decd407faada" alt=""
3.完善中、右布局对应的样式
- 给每一项添加背景,这里通过itemBean数据中有个bgColor的值,给不同item设置不同背景颜色
data:image/s3,"s3://crabby-images/78325/7832584fb1bdd6d58086a97b85bc88776af4de56" alt=""
- 设置字体居中和大小
data:image/s3,"s3://crabby-images/0f79f/0f79f63a9dd959ae1d553e3b69e48d96a71bbc28" alt=""
- 添加白色边框
data:image/s3,"s3://crabby-images/6b2d9/6b2d9c1dfb7837fc790559a1696a87ebda4bf33d" alt=""
4.完善左边内容
在itembean数据有个type的值用来区分两种类型的item,用来区分item左边部分不同的布局。
data:image/s3,"s3://crabby-images/5400e/5400e00215a23ba5bea64ef0b1b08f90f82c7eb4" alt=""
- 添加左边的布局结构
data:image/s3,"s3://crabby-images/12a5f/12a5fe882f983fba122e64880561ced305da1016" alt=""
- 完善左边的布局
data:image/s3,"s3://crabby-images/7c553/7c55374b393d6119b1accd0ca1dd57fae13b55ca" alt=""
- 修改布局样式
data:image/s3,"s3://crabby-images/e2636/e2636c513460205fe15b03c52cd021e60b39e99e" alt=""
- 修改图片和文字样式
data:image/s3,"s3://crabby-images/0751e/0751ef3152b314614f894414b22278e2adba49f4" alt=""
最终效果如下:
data:image/s3,"s3://crabby-images/8742b/8742b2781868a5fbfb671001693fbf2422222b24" alt=""
最后附上项目地址
网友评论