热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

黑马头条项目:Vue文章详情模块与交互功能实现

本文详细介绍了如何在黑马头条项目中配置文章详情模块的路由、获取和展示文章详情数据,以及实现关注、点赞、不喜欢和评论功能。通过这些步骤,您可以全面了解如何开发一个完整的前端文章详情页面。

文章详情模块配置


在本项目中,我们首先需要配置文章详情模块的路由,以确保用户能够正确访问文章详情页面。


import Detail from '@/views/detail/index.vue'
{
path: '/detail',
component: Detail
}

为了控制路由跳转,我们使用了 Vant 组件库中的 van-cell 组件:






获取文章详情数据


接下来,我们需要封装接口调用方法来获取文章详情数据,并将其动态渲染到页面上。



export const getDetailById = (articleId) => {
return request({
method: 'get',
url: `v1_0/articles/${articleId}`
})
}

在组件中调用该接口并处理返回的数据:



data() {
return {
article: {}
}
},
methods: {
async getDetailById() {
try {
const ret = await getDetailById(this.$route.query.id)
this.article = ret.data
} catch (error) {
console.error('获取文章详情失败', error)
}
}
},
created() {
this.getDetailById()
}

关注与取消关注功能


为了实现关注与取消关注功能,我们封装了两个接口:



export const followArticle = (userId) => {
return request({
method: 'post',
url: 'v1_0/user/followings',
data: { target: userId }
})
}

export const unFollowArticle = (userId) => {
return request({
method: 'delete',
url: `v1_0/user/followings/${userId}`
})
}

在组件中实现点击事件绑定和逻辑处理:




{{article.is_followed ? '已关注' : '+ 关注'}}



async toggleFocus() {
if (this.article.is_followed) {
try {
await unFollowArticle(this.article.aut_id)
this.article.is_followed = !this.article.is_followed
} catch (error) {
this.$toast('取消关注失败')
}
} else {
try {
await followArticle(this.article.aut_id)
this.article.is_followed = !this.article.is_followed
} catch (error) {
this.$toast('关注失败')
}
}
}

点赞与不喜欢功能


点赞与不喜欢功能的实现也需要封装相应的接口:



export const likes = (articleId) => {
return request({
method: 'post',
url: 'v1_0/article/likings',
data: { target: articleId }
})
}

export const unlikes = (articleId) => {
return request({
method: 'delete',
url: `v1_0/article/likings/${articleId}`
})
}

export const dislikes = (articleId) => {
return request({
method: 'post',
url: 'v1_0/article/dislikes',
data: { target: articleId }
})
}

export const undislikes = (articleId) => {
return request({
method: 'delete',
url: `v1_0/article/dislikes/${articleId}`
})
}

在组件中实现点击事件绑定和逻辑处理:




点赞
    
不喜欢



async toggleStatus(type) {
if (type === 1) {
if (this.article.attitude === 1) {
try {
await unlikes(this.article.art_id.toString())
this.article.attitude = -1
} catch (error) {
this.$toast('取消点赞失败')
}
} else {
try {
await likes(this.article.art_id.toString())
this.article.attitude = 1
} catch (error) {
this.$toast('点赞失败')
}
}
} else {
if (this.article.attitude === 0) {
try {
await undislikes(this.article.art_id.toString())
this.article.attitude = -1
} catch (error) {
this.$toast('取消不喜欢失败')
}
} else {
try {
await dislikes(this.article.art_id.toString())
this.article.attitude = 0
} catch (error) {
this.$toast('不喜欢失败')
}
}
}
}

评论模块


评论组件拆分


为了实现评论功能,我们首先需要拆分评论组件并进行布局设计:










一阵清风


10


评论的内容...



两天内 
4 回复








提交




评论列表渲染


为了动态加载评论列表数据,我们封装了一个接口来获取评论数据:



export const getComments = (articleId, offset) => {
return request({
method: 'get',
url: 'v1_0/comments',
params: {
type: 'a', // a表示文章的评论;c表示回复评论的数据
source: articleId, // 评论的文章的id或者,回复的评论的id
offset: offset, // 分页参数(评论的id)
limit: 10 // 每页的条数
}
})
}

在组件中调用该接口并处理返回的数据:



async onLoad() {
try {
const ret = await getComments(this.articleId, this.offset)
this.list.push(...ret.data.results)
this.loading = false
if (ret.data.last_id === ret.data.end_id) {
this.finished = true
} else {
this.offset = ret.data.last_id
}
} catch (error) {
console.error('加载评论失败', error)
}
}

评论功能实现


最后,我们实现了评论功能,包括发表评论和评论回复:



export const comment = (options) => {
return request({
method: 'post',
url: 'v1_0/comments',
data: {
target: options.target,
content: options.content,
art_id: options.articleId
}
})
}

在组件中绑定提交事件并实现评论提交逻辑:



提交


async sendComment() {
try {
await comment({
target: this.articleId,
content: this.value
})
this.list = []
this.offset = null
await this.onLoad()
this.value = ''
} catch (error) {
this.$toast('评论文章失败')
}
}

推荐阅读
  • 深入理解Vue.js:从入门到精通
    本文详细介绍了Vue.js的基础知识、安装方法、核心概念及实战案例,帮助开发者全面掌握这一流行的前端框架。 ... [详细]
  • 本文介绍如何使用 Angular 6 的 HttpClient 模块来获取 HTTP 响应头,包括代码示例和常见问题的解决方案。 ... [详细]
  • 本文探讨了在 Vue 2.0 项目中使用 Axios 获取数据时可能出现的错误,并提供详细的解决方案和最佳实践。 ... [详细]
  • TCP长连接设备管理平台:架构与功能概览
    本文介绍了基于TCP长连接的设备管理平台的设计理念、技术选型及主要功能模块。最初,项目旨在实现简单的协议测试,但随着需求扩展,逐步演变为一个完整的前后端分离系统。 ... [详细]
  • 作为一名 Ember.js 新手,了解如何在路由和模型中正确加载 JSON 数据是至关重要的。本文将探讨两者之间的差异,并提供实用的建议。 ... [详细]
  • 本文总结了优化代码可读性的核心原则与技巧,通过合理的变量命名、函数和对象的结构化组织,以及遵循一致性等方法,帮助开发者编写更易读、维护性更高的代码。 ... [详细]
  • 云函数与数据库API实现增删查改的对比
    本文将深入探讨使用云函数和数据库API实现数据操作(增删查改)的不同方法,通过详细的代码示例帮助读者更好地理解和掌握这些技术。文章不仅提供代码实现,还解释了每种方法的特点和适用场景。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • 本文详细介绍了Java中org.eclipse.ui.forms.widgets.ExpandableComposite类的addExpansionListener()方法,并提供了多个实际代码示例,帮助开发者更好地理解和使用该方法。这些示例来源于多个知名开源项目,具有很高的参考价值。 ... [详细]
  • 本文详细介绍了Java中org.w3c.dom.Text类的splitText()方法,通过多个代码示例展示了其实际应用。该方法用于将文本节点在指定位置拆分为两个节点,并保持在文档树中。 ... [详细]
  • 探讨如何优化 npm 构建过程,提升开发效率,减少构建时间,并介绍自动化部署的最佳实践。 ... [详细]
  • 在项目部署后,Node.js 进程可能会遇到不可预见的错误并崩溃。为了及时通知开发人员进行问题排查,我们可以利用 nodemailer 插件来发送邮件提醒。本文将详细介绍如何配置和使用 nodemailer 实现这一功能。 ... [详细]
author-avatar
立行谏圣
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有