vue2中用到了 vuex 实现一个 留言板效果

news2024/9/23 9:29:54

一.效果图展示:

在这里插入图片描述

二.静态网页(html)代码

<template>
    <div>
        <h1>班级留言板</h1>
        <ol>
            <li  v-for="(msg, index) in classmsgs" :key="index">{{ msg }} <a href="#" @click.prevent="delmsg(index)">删除</a></li>
        </ol>
        <textarea name="" id="" cols="35" rows="5"  v-model="addclassmsg" @keyup="inputchange"></textarea><button @click="sub">提交</button>
    </div>
</template>

这是一个使用Vue.js框架编写的班级留言板组件。以下是代码的详细解释:

  1. template标签内包含了整个组件的HTML结构。
  2. div是根元素,包含了一个标题(h1)和一个有序列表(ol)。
  3. 在有序列表中,使用了v-for指令来遍历名为classmsgs的数组,该数组存储了班级留言信息。每个留言都是一个列表项(li),其中包含留言内容和一个删除按钮(a)。
  4. **:key=“index”**为每个列表项分配一个唯一的键,以便Vue可以跟踪它们的变化。
  5. @click.prevent="delmsg(index)"是一个事件监听器,当点击删除按钮时,会调用名为delmsg的方法并传递当前索引作为参数。
  6. textarea元素用于输入新的留言内容,它与名为addclassmsg的数据属性绑定,这意味着它的值将随着数据属性的变化而变化。
  7. @keyup="inputchange " 是一个事件监听器,当在文本区域中按键时,会调用名为inputchange的方法。
    <button @click=“sub”>提交是一个按钮,当点击时,会调用名为sub的方法来提交新的留言。
    注意:这段代码仅展示了Vue组件的模板部分,实际使用时还需要添加对应的JavaScript代码来实现delmsg、inputchange和sub方法以及定义classmsgs和addclassmsg数据属性

三.javascript代码

import { mapState, mapActions } from 'vuex';
export default{
    data(){
        return{
            addclassmsg:""
        }
    },
    computed: {
     // 简化取state,getters
     ...mapState({
        addclassmsgx:state =>state.addclassmsgx,
        classmsgs:state => state.classmsgs
     }),
   },
   methods: {
     // 简化取action,mutation,建立一个对应关系
        ...mapActions({
        increment: 'increment',
        decrement: 'decrement',
        tijiao:'tijiao'
        }),
        inputchange(){
            this.$store.dispatch("savecalssmsg",this.addclassmsg)
        },
        sub(){
            console.log(this.addclassmsg)
            this.$store.dispatch("addclassmsg")
            this.addclassmsg = ''
        },
        delmsg(){
            // this.classmsgs.splic(index,1)
            this.$store.dispatch("delmsg")
        }
   },
}

这段代码是一个Vue组件,使用了Vuex进行状态管理。具体解释如下:

  1. 导入了mapState, mapGetters, mapActions这三个辅助函数,用于简化在组件中访问Vuex的状态、getter和action。

  2. 定义了一个名为addclassmsg的数据属性用来存储textarea标签中的值,初始值为空字符串。

  3. 使用computed属性来简化访问Vuex的state和getter。这里定义了两个计算属性:addclassmsgx和classmsgs,分别对应Vuex中的state.addclassmsgx和state.classmsgs

  4. 在methods中,使用mapActions简化了访问Vuex的action。这里定义了三个方法:increment、decrement和tijiao,分别对应Vuex中的actions.increment、actions.decrement和actions.tijiao

  5. 定义了一个名为inputchange的方法,用于将addclassmsg的值通过savecalssmsg这个mutation保存到Vuex的state中。

  6. 定义了一个名为sub的方法,用于提交表单。首先打印addclassmsg的值,然后通过调用addclassmsg这个action将其添加到Vuex的state中,最后清空addclassmsg的值。

  7. 定义了一个名为delmsg的方法,用于删除消息。通过调用delmsg这个action来实现删除操作

四.vuex知识部分:index.js对应的代码

import Vuex from 'vuex';
import Vue from 'vue'
Vue.use(Vuex)

let store =new Vuex.Store({
        state: {
            addclassmsgx:'',
            classmsgs:['好好学习','天天向上','力争上游']
        },
        mutations: {
            saveclass(state,data){
                console.log('mu')
                state.addmsgx=data
            },
            saveclasstask(state){
                state.classmsgs.push(state.addmsgx)
            },
            xdelmsg(state){
                let index = state.classmsgs.indexOf()
                state.classmsgs.splice(index,1)
            }
        },
        actions: {
            increment(context) {
                //其他操作(如异步操作等)
                // 修改数据的唯一方法,是提交mutation.
                // 的页面的话,先调用action,action再提交mutation.
                context.commit('increment');
            },
            decrement(context) {
               context.commit('decrement');
            },
            savecalssmsg(context,data){
                console.log('action')
                context.commit('saveclass',data);
            },
            addclassmsg(context){
                context.commit('saveclasstask')
            },
            delmsg(context,data){
                context.commit('xdelmsg',data)
            }
        }
    })
export default store;

这段代码是使用Vue.js和Vuex创建的一个状态管理库。Vuex是一个专门为Vue.js应用程序开发的状态管理模式和库。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。

  1. state:定义了应用的状态树,这里有两个状态属性:addclassmsgx 和 classmsgs。addclassmsgx 用于存储添加的班级信息,classmsgs 是一个数组,用于存储班级任务列表。

  2. mutations:定义了改变状态的方法。每个方法接收两个参数:state 和 payload。state 是当前的状态对象,payload 是调用该 mutation 时传递的数据。这里有四个 mutation:

    • saveclass:将传入的数据保存到 addclassmsgx 中。
    • saveclasstask:将 addclassmsgx 的内容添加到 classmsgs 数组中。
    • xdelmsg:删除 classmsgs 数组中的指定元素。注意,这里的代码有一个错误,indexOf() 函数缺少参数,应该是 indexOf(data)。
  3. actions:定义了异步操作,可以提交多个 mutation。每个 action 接收一个 context 对象,通过 context.commit() 方法提交 mutation。这里有五个 action:

    • increment 和 decrement:这两个 action 没有实际作用,是示例代码的一部分。
    • savecalssmsg:接收数据并将其传递给 saveclass mutation。
    • addclassmsg:提交 saveclasstask mutation,将 addclassmsgx 的内容添加到 classmsgs 数组中。
    • delmsg:接收数据并将其传递给 xdelmsg mutation,删除 classmsgs 数组中的指定元素。
  4. new Vuex.Store():创建一个 Vuex store 实例,并将上述定义的对象作为参数传入。这样,我们就可以在整个应用程序中使用这个 store 来管理状态。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2099923.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

折叠屏、曲面屏始终都是少数派,凭啥挑战iPhone16?

国内手机市场是一个很特别的市场&#xff0c;眼见着在处理器性能、拍照等方面都已无法再挑战苹果&#xff0c;国产手机这几年紧紧抓住折叠屏、曲面屏等差异化技术&#xff0c;试图与苹果掰手腕&#xff0c;然而从现实来看&#xff0c;这些技术其实都已失败了。 曲面屏基本可以说…

直接计算法计算CRC-32/MPEG-2

代码&#xff1a; #include<stdio.h>#define BUFFER_SIZE 114typedef unsigned int uint32_t; typedef unsigned char uint8_t;uint8_t output[BUFFER_SIZE*4]; static const uint32_t aDataBuffer[BUFFER_SIZE] {0x00001021, 0x20423063, 0x408450a5, 0x60c670e7, …

引领八亿人的“发现感”,深度旅游时代正式到来

原文链接&#xff1a;深度旅游新纪元已降临&#xff0c;我们正带领八亿旅行者开启探索之旅&#xff0c;发现世界的无限精彩 一些人在旅行时渴望探索全新的城市&#xff0c;体验那里独特的风情&#xff1b;而另一些人则被“必住榜”上的苏州平江华府酒店吸引&#xff0c;想要亲…

计算机毕业设计Spark+PyTorch股票推荐系统 股票预测系统 股票可视化 股票数据分析 量化交易系统 股票爬虫 股票K线图 大数据毕业设计 AI

《SparkPyTorch股票推荐与预测系统》开题报告 一、研究背景与意义 随着信息技术的飞速发展和全球金融市场的日益繁荣&#xff0c;股票投资已成为广大投资者的重要选择之一。然而&#xff0c;股票市场的复杂性和不确定性使得投资者在做出投资决策时面临巨大的挑战。传统的股票…

ceph中pg与pool关系

在Ceph中&#xff0c;PG&#xff08;Placement Group&#xff09;和Pool是非常重要的概念&#xff0c;它们在Ceph的存储架构中扮演着关键角色。理解这些概念有助于更好地管理和优化Ceph集群。下面详细介绍这两个概念及其相互关系。 Pool&#xff08;存储池&#xff09; 定义&am…

牧野机床采集数据

牧野于1958年研发出日本第一数控铣床,并于1966年研发成功日本第一台加工中心。我在市面上常见的到的加工中心P5、P6系统,其余的就是EDM数控系统。他们两个用的不是同一种系统,采集方式也有区别,大家要注意。 牧野机床(中国)有限公司,于2002年7月23日在江苏昆山成立,是一…

sqli-labs靶场通关攻略(六十一关到六十五关)

sqli-labs-master靶场第六十一关 步骤一&#xff0c;判断闭合方式 ?id1)) -- 步骤二&#xff0c;查看数据库 ?id1)) and updatexml(1,concat(1,(select database())),1) -- 步骤三&#xff0c;查看表名 ?id-1)) and updatexml(1,concat(1,(select group_concat(table_na…

【K8s】专题十三:Kubernetes 容器运行时之 Docker 与 Containerd 详解

本文内容均来自个人笔记并重新梳理&#xff0c;如有错误欢迎指正&#xff01; 如果对您有帮助&#xff0c;烦请点赞、关注、转发、订阅专栏&#xff01; 专栏订阅入口 Linux 专栏 | Docker 专栏 | Kubernetes 专栏 往期精彩文章 【Docker】&#xff08;全网首发&#xff09;Kyl…

记忆化搜索【上】

509. 斐波那契数 题目链接&#xff1a;斐波那契数 递归&#xff08;暴搜&#xff09; 斐波那契数列&#xff0c;最传统的解法&#xff0c;采用递归&#xff1a; class Solution { public:int fib(int n){return dfs(n);}int dfs(int n){if(n 0 || n 1)return n;return d…

搭建核心架构网络项目(局域网)

一个基础项目的搭建 一、项目简介 这个项目主要就是最基础的一个局域网&#xff0c;模拟现实企业的网络架构&#xff0c;确保网络的安全性&#xff0c;通过VLAN划分实现不同部门或用户组的隔离等。 下图是我们这次要搭建的局域网拓扑图。&#xff08;左边为财务部门&#xff0…

[Algorithm][综合训练][kotori和n皇后][取金币][矩阵转置]详细讲解

目录 1.kotori和n皇后1.题目链接2.算法原理详解 && 代码实现 2.取金币1.题目链接2.算法原理详解 && 代码实现 3.矩阵转置1.题目链接2.算法原理详解 && 代码实现 1.kotori和n皇后 1.题目链接 kotori和n皇后 2.算法原理详解 && 代码实现 解法&…

Yapi部署文档

Yapi是高效、易用、功能强大的API管理平台&#xff0c;旨在为开发、产品、测试人员提供更优雅的接口管理服务 官网地址&#xff1a;Yapi 环境&#xff1a; l Git l NodeJs&#xff08;7.6&#xff09; l Mongodb&#xff08;2.6&#xff09; 1、 NodeJs的安装 获取资源 …

嵌入式硬件-ARM处理器架构,CPU,SOC片上系统处理器

多进程空间内部分布图&#xff1a;注意&#xff1a;创建线程实际使用兑取空间&#xff0c;栈区独立 ARM处理器架构&#xff1a; 基于ARM920T架构的CPU:以下时哈佛结构ARM920T是ARM公司的32位RISC&#xff08;精简指令集计算机&#xff09;处理器内核。它具有以下特点&#xff1…

day-47 组合

思路 回溯&#xff1a;利用个dfs方法递归调用&#xff0c;每个元素有选或不选两种抉择&#xff0c;当选中元素个数等于k时&#xff0c;将链表p加入答案&#xff0c;当idsn且选中元素个数小于n时&#xff0c;直接返回 解题过程 每次选中元素调用dfs方法后记得还原 Code class…

【数据结构】顺序表和链表——顺序表(包含丰富算法题)

文章目录 1. 线性表2. 顺序表2.1 概念与结构2.2 分类2.2.1 静态顺序表2.2.2 动态顺序表 2.3 动态顺序表的实现2.4 顺序表算法题2.4.1 移除元素2.4.2 删除有序数组中的重复项2.4.3 合并两个有序数组 2.5 顺序表问题与思考 1. 线性表 线性表&#xff08;linear list&#xff09;…

vivado 定义时间约束

定义时间约束和 例外情况 在本实验中&#xff0c;您将学习两种为设计创建约束的方法。您必须使用 AMD Vivado™IDE中包含的AMD Kintex™7 CPU网表示例设计。 第一步&#xff1a;打开示例项目 1.打开Vivado IDE。 •在Linux上&#xff1a; 1.更改实验室材料的存储目录。 cd&…

HarmonyOS--后台代理提醒

一、概述 HarmonyOS提供后台代理提醒功能&#xff0c;在应用退居后台或退出后&#xff0c;计时和提醒通知功能被系统后台代理接管。后台代理提醒就是由系统后台进程代理应用的提醒功能。后台代理提醒服务通过reminderAgentManager模块提供提醒定义、创建提醒、取消提醒等能力。…

zdppy+vue3+onlyoffice文档管理系统实战 20240902 上课笔记 登录功能优化

遗留问题 1、登录以后跳转最近文档2、如果用户没有登录应该自动跳转登录页面3、如果用户的token校验失败&#xff0c;应该自动调整登录界面4、按回车键自动跳转登录页面 登录以后跳转最近文档 const router useRouter() router.push("/")实际代码&#xff1a; c…

C++篇:C向C++迈进(下)

目录 引言 缺省参数 1.缺省参数的概念 2.缺省参数的分类 2.1 全缺省 2.2 半缺省 3.注意事项 函数重载 1.函数重载的定义 2.函数重载的基本规则 3.函数重载的运用场景 引用 1.引用的概念 2.引用的主要特性 3.常引用 4.引用的使用场景 4.1 函数参数传递 4.2 函…

计算机网络-VRRP基础概念

回顾一下以前我们学习的网络通信基础&#xff0c;终端通过交换机可以相互进行通信&#xff0c;而如果是不同网段间的通信需要经过三层网关&#xff0c;网关进行路由寻址和转发&#xff0c;所以基本的网络结构就是终端--交换机--路由器网关--网络出口--Internet。 一、VRRP虚拟路…