用vue3实现留言板功能

效果图:

代码:

html 复制代码
<script setup lang="ts">
import { ref } from 'vue';

interface Message {
  name: string;
  phone: string;
  message: string;
}

const name = ref<string>('');
const phone = ref<string>('');
const message = ref<string>('');
const messages = ref<Message[]>([]);

const submitMessage = () => {
  if (name.value && phone.value && message.value) {
    const phoneRegex = /^1[0123456789]\d{9}$/;
    if (!phoneRegex.test(phone.value)) {
      alert('请输入正确的手机号!');
      return;
    }
    messages.value.unshift({
      name: name.value,
      phone: phone.value,
      message: message.value
    });
    name.value = '';
    phone.value = '';
    message.value = '';
  } else {
    alert('请填写完整的信息!');
  }
};

const deleteMessage = (index: number) => {
  messages.value.splice(index, 1);
};

const editMessage = (index: number) => {
  const editedMessage = prompt('请输入编辑后的留言内容:', messages.value[index].message);
  if (editedMessage !== null) {
    messages.value[index].message = editedMessage;
  }
};
</script>

<template>
  <div id="app">
    <h1>留言板</h1>
    <div class="message-form">
      <label for="name">留言者姓名:</label>
      <input type="text" v-model="name" placeholder="留言者姓名">
      <label for="phone">手机号:</label>
      <input type="text" v-model="phone" placeholder="手机号">
      <label for="message">留言内容:</label>
      <textarea v-model="message" placeholder="留言内容"></textarea>
      <button @click="submitMessage">提交</button>
    </div>

    <div class="message-list" v-if="messages.length > 0">
      <div v-for="(msg, index) in messages" :key="index" class="message">
        <div>留言者姓名:{{ msg.name }}</div>
        <div>手机号:{{ msg.phone }}</div>
        <div>留言内容:{{ msg.message }}</div>
        <button @click="deleteMessage(index)">删除</button>
        <button @click="editMessage(index)">编辑</button>
      </div>
    </div>
  </div>
</template>

<style scoped>
#app {
  max-width: 600px;
  margin: 0 auto;
  padding: 20px;
  font-family: 'Roboto', sans-serif;
}

h1 {
  text-align: center;
  margin-bottom: 20px;
  color: #3498db;
}

.message-form {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  margin-bottom: 20px;
}
.message-form label {
  width: 100%; 
  margin-bottom: 10px;
}

.message-form input,
.message-form textarea {
  width: 100%;
  padding: 10px;
  margin-bottom: 15px;
  border: 1px solid #ddd;
  border-radius: 5px;
  font-size: 14px;
}

.message-form button {
  padding: 10px 20px;
  background-color: #3498db;
  color: white;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  font-size: 14px;
  transition: all 0.3s ease;
  display: block;
  margin: 0 auto;
}

.message-form button:hover {
  background-color: #2980b9;
}
.message-list {
  margin-top: 20px;
}

.message {
  background-color: #eef5f9;
  border-left: 4px solid #007bff;
  padding: 15px;
  margin-bottom: 10px;
  border-radius: 4px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
}

.message button {
  background-color: transparent;
  color: #007bff;
  border: 1px solid #007bff;
  margin-right: 10px;
  margin-top: 10px;
  transition: background-color 0.3s ease, color 0.3s ease;
}

.message button:hover {
  background-color: #007bff;
  color: white;
}
</style>
相关推荐
爱勇宝1 小时前
大多数人不是在使用 AI 赚钱,而是在帮 AI 公司赚钱
前端·后端·程序员
冬奇Lab2 小时前
每日一个开源项目(第143篇):page-agent - 纯 JS 的网页 GUI Agent,无需截图、无需插件、无需后端
前端·人工智能·agent
To_OC3 小时前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
IT_陈寒6 小时前
React的这个渲染问题连官方文档都没说清楚
前端·人工智能·后端
追逐时光者7 小时前
别再满网找零散工具了,腾讯 QQ 浏览器这个“帮小忙”工具箱真能省时间
前端·后端
如果超人不会飞7 小时前
脉络清晰的业务演进:TinyVue Timeline 时间线组件全方位实战指南
vue.js
如果超人不会飞7 小时前
从扁平到立体:掌握 TinyVue Grid 树形表格的高级实战指南
vue.js
To_OC9 小时前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode
Asmewill9 小时前
grep&curl命令学习笔记
前端
stringwu9 小时前
Flutter 开发必备:MVI 架构的高效实现指南
前端·flutter