P04:通过List组件制作博客列表页
左右两边的基本布局完成后,需要对列表的单元项进行制作,也就是首页列表中的每一项。这个制作起来涉及的内容不多,因为以后要解析Markdown
代码,所以这里只是先模拟一下,把基本的样式完成。因为基础知识点我们都讲过了,所以这里就以实践为主了。
编写列表项的基本结构
由于Ant Design
本身就有列表相关的组件,所以我们不用把这部分独立出去,而是使用Ant Design
本身所有的 List 组件。
打开 index.js,引入List
,代码如下:
import {Row, Col, List, Space} from 'antd'
然后把useState
也引入过来,以后要进行使用。
import React,{useState} from 'react'
icon 图标创建方法
const IconText = ({ icon, text }) => ( <Space> {React.createElement(icon)} {text} </Space> );
用useState
伪造一些假数据,然后在jsx
中进行使用。
const [mylist,setMylist] = useState( [ {title:'Vue3.x 的生命周期和钩子函数',context:'Vue3 版本的生命周期和 Vue2 比有了些变化,所以我先站在一个初学者的角度(没有学过 Vue2 版本的新手),从新讲一下 Vue3.x 的生命周期,等你完全理解之后,我们再来和 Vue2.x 的生命周期作一个对比。'}, {title:'前端 js 代码规范总结',context:'如果你关心代码的本身以及编写方式,而只是担心代码是否有效的,你可以说你实践并且关心代码的规范性。专业的开发人员总是会考虑到自己便于将来还能可读和其他的团队人员,并不是仅仅考虑到运行的结果。你写的任何代码并不是只写一次,总会有其他的开发人员来做你写的代码,如果你写的不规范,而他则会痛苦不堪。希望这个人不是你。'}, {title:'Redis + NodeJS 实现一个能处理海量数据的异步任务队列系统',context:'在最近的业务中,接到了一个需要处理约十万条数据的需求。这些数据都以字符串的形式给到,并且处理它们的步骤是异步且耗时的(平均处理一条数据需要 25s 的时间)。如果以串行的方式实现,其耗时是相当长的:'}, ] )
有了数据后,我们就可以用这些数据来构建 List 布局了。代码如下:
<List header={<div>最新日志</div>} itemLayout="vertical" dataSource={mylist} renderItem={item => ( <List.Item> <div className="list-title">{item.title}</div> <div className="list-icon"> <IconText icon={ClockCircleOutlined} text="2020-12-01" key="list-vertical-star-o" /> <IconText icon={VideoCameraOutlined} text="前端教程" key="list-vertical-like-o" /> <IconText icon={FireOutlined} text="5498 人" key="list-vertical-message" /> </div> <div className="list-context">{item.context}</div> </List.Item> )} />
列表页 CSS 样式的编写
在/pages
文件夹下,新建立一个index.css
文件。 这里给出了 CSS 样式的代码。
.list-title{ font-size:1.3rem; color: #1e90ff; padding: 0 0.5rem; } .list-context{ color:#777; padding:.5rem; } .list-icon{ padding:.5rem 0; color:#AAA; } .list-icon span{ display: inline-block; padding: 0 10px; }
写完后记得引入到_app.js
里边。
import '../styles/index.css'
这时候进行预览,应该就可以出现比较好看的列表样式效果了。
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
码云笔记 » P04:通过List组件制作博客列表页
码云笔记 » P04:通过List组件制作博客列表页