当前位置:首页 > VUE

vue公告通知页面实现

2026-02-24 02:30:55VUE

实现公告通知页面的基本思路

公告通知页面通常需要展示公告列表、公告详情,可能包含分页、未读标记等功能。Vue.js结合后端API可以实现动态数据交互。

页面结构设计

使用Vue单文件组件结构,通常包含以下部分:

  • 公告列表区域
  • 分页控件
  • 公告详情弹窗
  • 状态标记(如未读红点)
<template>
  <div class="notice-container">
    <h3>公告列表</h3>
    <ul class="notice-list">
      <li v-for="item in notices" :key="item.id" @click="showDetail(item)">
        <span :class="{ 'unread': !item.isRead }">{{ item.title }}</span>
        <span class="date">{{ formatDate(item.createTime) }}</span>
      </li>
    </ul>
    <el-pagination
      layout="prev, pager, next"
      :total="total"
      :page-size="pageSize"
      @current-change="handlePageChange">
    </el-pagination>
    <el-dialog :title="currentNotice.title" :visible.sync="dialogVisible">
      <div v-html="currentNotice.content"></div>
    </el-dialog>
  </div>
</template>

数据获取与处理

通过axios调用后端API获取公告数据,处理分页和状态更新:

<script>
import axios from 'axios';

export default {
  data() {
    return {
      notices: [],
      currentPage: 1,
      pageSize: 10,
      total: 0,
      currentNotice: {},
      dialogVisible: false
    }
  },
  created() {
    this.fetchNotices();
  },
  methods: {
    async fetchNotices() {
      const res = await axios.get('/api/notices', {
        params: {
          page: this.currentPage,
          size: this.pageSize
        }
      });
      this.notices = res.data.list;
      this.total = res.data.total;
    },
    showDetail(item) {
      this.currentNotice = item;
      this.dialogVisible = true;
      if (!item.isRead) {
        this.markAsRead(item.id);
      }
    },
    async markAsRead(id) {
      await axios.patch(`/api/notices/${id}/read`);
      const index = this.notices.findIndex(item => item.id === id);
      this.$set(this.notices[index], 'isRead', true);
    },
    handlePageChange(page) {
      this.currentPage = page;
      this.fetchNotices();
    },
    formatDate(date) {
      return new Date(date).toLocaleDateString();
    }
  }
}
</script>

样式设计

使用CSS或SCSS美化公告列表:

<style lang="scss" scoped>
.notice-container {
  padding: 20px;

  .notice-list {
    list-style: none;
    padding: 0;

    li {
      padding: 12px 16px;
      border-bottom: 1px solid #eee;
      cursor: pointer;
      display: flex;
      justify-content: space-between;

      &:hover {
        background-color: #f5f5f5;
      }

      .unread {
        color: #f56c6c;
        font-weight: bold;
      }

      .date {
        color: #999;
        font-size: 12px;
      }
    }
  }
}
</style>

功能扩展建议

  1. 分类筛选:添加公告类型筛选功能
  2. 搜索功能:实现标题关键字搜索
  3. 置顶公告:区分普通公告和置顶公告
  4. 批量操作:添加批量标记已读功能
  5. 实时推送:集成WebSocket实现新公告实时提醒

后端接口建议

典型RESTful接口设计:

  • GET /api/notices - 获取公告列表
  • GET /api/notices/:id - 获取公告详情
  • PATCH /api/notices/:id/read - 标记为已读
  • POST /api/notices - 创建新公告(管理员用)

可根据实际需求调整接口参数和返回数据结构。

vue公告通知页面实现

标签: 页面通知
分享给朋友:

相关文章

php实现页面跳转

php实现页面跳转

PHP实现页面跳转的方法 在PHP中,可以通过多种方式实现页面跳转,以下是几种常用的方法: header函数跳转 header("Location: target_page.php"); ex…

h5实现页面切换

h5实现页面切换

h5实现页面切换的方法 在H5中实现页面切换可以通过多种方式完成,包括使用原生HTML链接、JavaScript动态加载、框架路由等。以下是几种常见的方法: 使用原生HTML的<a>标签…

vue实现引导页面

vue实现引导页面

实现引导页面的方法 在Vue中实现引导页面通常需要结合用户交互和页面跳转逻辑,以下是几种常见的实现方式: 使用路由守卫控制访问权限 在router.js中配置全局前置守卫,检查用户是否首次访问:…

vue 实现页面注册

vue 实现页面注册

Vue 实现页面注册功能 在 Vue 中实现用户注册功能通常需要以下步骤: 创建注册表单组件 使用 Vue 的单文件组件结构创建一个注册表单,包含必要的输入字段如用户名、邮箱、密码等。 <…

h5页面如何实现

h5页面如何实现

实现H5页面的方法 H5页面是基于HTML5技术的网页,通常用于移动端和响应式设计。以下是实现H5页面的关键步骤和技术要点。 基础结构 使用HTML5的DOCTYPE声明作为页面的起始。HTML5简…

vue实现页面手写

vue实现页面手写

Vue 实现手写功能 在 Vue 中实现手写功能通常需要使用 HTML5 的 Canvas 元素,结合鼠标或触摸事件来捕捉用户的绘制动作。以下是实现步骤和代码示例: 基础实现步骤 创建一个 Vue…