最近有个需求是新闻时间排序与点击量排序,数据库中存储的新闻是按照时间顺序排序的,从后台数据中取出数据,在前端进行页面展示即可。
我用到了ant-design中的Tabs切换页,样式大概如下图。
data:image/s3,"s3://crabby-images/4910a/4910abafcc7a6f0b62a76c76fd0b75db4d3fc4ce" alt=""
其实这个项目里面最令我欣喜的是reducer中间件的封装,无需通过fetch请求数据这些,而是使用另外的封装中间件的方式
当然在store里面有引用redux-thunk
data:image/s3,"s3://crabby-images/a7c7e/a7c7e279da190f11abd5ae0f1b5c42f7c121ba1c" alt="")
data:image/s3,"s3://crabby-images/a14d2/a14d2d1dddb789fde3a431c0ea388311a4e8bffe" alt=""
项目首先是使用了三种请求方式
data:image/s3,"s3://crabby-images/fbf8a/fbf8adabf685773becb4dc4e5948a5ed954682b1" alt=""
data:image/s3,"s3://crabby-images/8499b/8499bfd1bc0406dfa736214e8f3102e980f64e0c" alt=""
在中间件中使用这三种方式,并且封装了callApi
data:image/s3,"s3://crabby-images/e4c2d/e4c2d4847f4217ec5d142814aa1569217ef9668d" alt=""
data:image/s3,"s3://crabby-images/3d797/3d797ba0251b3e3b5053416ea914d2b608a2b1bf" alt=""
data:image/s3,"s3://crabby-images/edc78/edc78ef44c768530b526a06efd786aea12fda021" alt=""
data:image/s3,"s3://crabby-images/e6152/e6152d6348949b6d272805172ce448b6ce0830b7" alt=""
我们将方法写在action中,callAPI就是我们请求的后端的数据
data:image/s3,"s3://crabby-images/5fe5d/5fe5d69a0e155098c5b2a4ba8fe149d38ecd9126" alt=""
data:image/s3,"s3://crabby-images/acbf2/acbf2a92463df592634756c40f4259fae34bcb4f" alt=""
在我们的reducer中,我们会通过type暴露这些数据,并且返回我们的请求结果
data:image/s3,"s3://crabby-images/6d089/6d089775f97c0e76098035ab912224fc481e1c6a" alt=""
data:image/s3,"s3://crabby-images/a8d50/a8d500ab9c3fd0818a683b46ce8c90639d87fb86" alt=""
不要忘记合并我们的reducer方法
data:image/s3,"s3://crabby-images/dd903/dd90360182b8192279ddcd4e3c483cca9cc544a4" alt=""
data:image/s3,"s3://crabby-images/f96ec/f96ec378fc825dc1186a551a485e2d0ac6102246" alt=""
在我们的文件中别忘了使用我们的这些方法
data:image/s3,"s3://crabby-images/46f6a/46f6ad1231d35d6b9c7d1711ae7048d0a39aa002" alt=""
data:image/s3,"s3://crabby-images/d8117/d811717aeb85178169caa189033d3fa5c2a9fffe" alt=""
再说说我在这个数据中用到的方法吧
通过map循环数据,通过es7的Decorators语法拿到请求数据
data:image/s3,"s3://crabby-images/68bc0/68bc08ea58014776cd7444db7937e5b71bd5f9d3" alt=""
如何求那些值呢
我们要求的是展示最新的5条新闻
接下来的是点击详情事件进入详情页