用智能插件(Fitten Code: Faster and Better AI Assistant)修改好了可以持久保存的vue3留言板

天际

 第一修改是选项式:

<!-- 模板结构 -->
<template><div><textarea  placeholder="请输入备注内容" v-model="newItem"></textarea><button @click="addItem">添加</button><hr><div class="text"><div v-for="(item, index) in items" :key="index" :class="{ 'finish': item.finish }"><button @click="removeItem(index)">删除</button><button @click="toggleFinish(index)">{{ item.finish ? '取消' : '完成' }}</button><span class="content">{{ item.name }}</span></div></div></div>
</template>
<!-- 脚本行为 -->
<script>
export default {data() {return {newItem: '',items: []};},mounted() {this.loadTodo();},methods: {addItem() {this.items.push({ name: this.newItem, finish: false });this.saveTodo();this.newItem = '';},removeItem(index) {this.items.splice(index, 1);this.saveTodo();},toggleFinish(index) {this.items[index].finish = !this.items[index].finish;this.saveTodo();},saveTodo() {localStorage.setItem('mylogs', JSON.stringify(this.items));},loadTodo() {const savedItems = JSON.parse(localStorage.getItem('mylogs'));if (savedItems) {this.items = savedItems;}}}
};
</script>
<!-- 组件样式 -->
<style>
.finish {text-decoration: line-through;text-shadow: 2px 2px 2px LightslateGray;box-shadow: 0 0 10px 5px rgba(255, 255, 255, 0.916);
}
</style>

第2次修改

<template><div><textarea      placeholder="请输入备注内容"v-model="newItem"></textarea><button @click="addItem">添加</button><hr /><div class="text"><divv-for="(item, index) in items":key="index":class="{ finish: item.finish }"><button @click="removeItem(index)">删除</button><button @click="toggleFinish(index)">{{ item.finish ? "取消" : "完成" }}</button><span class="content">{{ index + 1 }}.{{ item.name }}{{ item.finish ? "(已完成)" : "" }}</span></div></div></div>
</template><script >import { ref, onMounted } from "vue";export default {setup() {const newItem = ref("");const items = ref([]);const addItem = () => {items.value.push({ name: newItem.value, finish: false });saveTodo();newItem.value = "";};const removeItem = (index) => {items.value.splice(index, 1);saveTodo();};const toggleFinish = (index) => {items.value[index].finish = !items.value[index].finish;saveTodo();};const saveTodo = () => {localStorage.setItem("mylogs", JSON.stringify(items.value));};const loadTodo = () => {const savedItems = JSON.parse(localStorage.getItem("mylogs"));if (savedItems) {items.value = savedItems;}};onMounted(() => {loadTodo();});return {newItem,items,addItem,removeItem,toggleFinish,saveTodo,loadTodo};}};
</script><style scoped>.finish {text-decoration: line-through;text-shadow: 2px 2px 2px LightslateGray;box-shadow: 0 0 10px 5px rgba(255, 255, 255, 0.916);}
</style>

 第3次修改

<template><div class="view"><!-- 左侧按钮 --><div class="view_left"><button class="btn_checkbox">操作<input type="checkbox" v-model="showInput" value="操作" /></button><button class="del_checkbox">删除 <input type="checkbox" v-model="showInput2" value="删除" /></button></div><!-- 中间内容 --><div class="view_content"><!--  --><div class="textarea_div"><textareaclass="text-input-box"placeholder="请输入备注内容"v-model="newItem"v-if="showInput"></textarea><button @click="addItem" v-if="showInput">添加</button></div><!--  --><div class="div_list"><div class="text"><div v-for="(item, index) in items" :key="index" :class="{ finish: item.finish }"><button @click="removeItem(index)" v-if="showInput2">删除</button><button @click="toggleFinish(index)">{{ item.finish ? '取消' : '完成' }}</button><button v-if="showInput" @click="edit(index)">编辑</button><span class="content"><button class="numb">{{ index + 1 }}</button> {{ item.name }}{{ item.finish ? '(已完成)' : '' }}</span><span v-show="oindex == index ? true : false" class="textarea_div"><textarea v-model="newItem"></textarea><button @click="csu">提交</button></span></div></div></div></div><!-- 右侧按钮 --><div class="view_right"></div></div>
</template><script setup>
// import '@/assets/styles/view.scss'
// import '@/assets/styles/jottings_memo.scss'
// import '../../assets/styles/input_checkbox.scss'
import { ref, onMounted } from 'vue'
const showInput = ref(false)
const showInput2 = ref(false)
const newItem = ref('')
const items = ref([])
const oindex = ref(-1)const addItem = () => {items.value.push({ name: newItem.value, finish: false })saveTodo()newItem.value = ''
}
const removeItem = (index) => {items.value.splice(index, 1)saveTodo()
}
const edit = (index) => {if (newItem.value === '' || false) {newItem.value = items.value[index].nameoindex.value = index} else {newItem.value = ''oindex.value = -1}
}
const csu = () => {if (oindex.value === -1) {return}items.value[oindex.value].name = newItem.valueoindex.value = -1newItem.value = ''saveTodo()
}const toggleFinish = (index) => {items.value[index].finish = !items.value[index].finishsaveTodo()
}const saveTodo = () => {try {localStorage.setItem('jottings', JSON.stringify(items.value))} catch (error) {console.error('Failed to save todo items to localStorage:', error)// 可以添加适当的错误处理逻辑,比如向用户显示错误信息}
}const loadTodo = () => {try {const savedItems = JSON.parse(localStorage.getItem('jottings'))if (savedItems) {items.value = savedItems}} catch (error) {console.error('Failed to load todo items from localStorage:', error)// 可以添加适当的错误处理逻辑,比如向用户显示错误信息}
}onMounted(() => {loadTodo()
})
</script><style scoped>
.btn_checkbox,
.del_checkbox {box-shadow:inset -2px -2px 3px rgba(255, 255, 255, 0.589),inset 2px 2px 3px rgba(0, 0, 0, 0.6);border-radius: 50px;font-size: 20px;margin: 0px 0 0 0px;width: 40px;transform: translate(20px, 0px);input[type='checkbox'] {top: 3px;left: -4px;}
}
.del_checkbox {color: #ff0000;background-color: #f56c6c;margin-left: 10px;
}
button {background-color: #67c23a;color: #e6a23c;border-radius: 3px;border: 2px solid#ccc;
}
.div_list {overflow-x: auto;overflow-y: auto;display: flex;flex-wrap: wrap;border-radius: 10px;width: 84vw;height: 90vh;padding: 20px;border: 2px solid #ccc;.content {word-wrap: break-word;user-select: text;color: #8ac5ff93;font-size: 20px;&:hover {color: hsla(160, 100%, 37%, 1);text-shadow: 1px 1px 1px #000000;box-shadow: 0 0 10px 5px rgba(255, 255, 255, 0.916);border-radius: 50px;background-color: rgb(191, 210, 255);}}
}
.textarea_div {display: flex;textarea {background-color: #144756;color: #fff;font-size: 20px;height: 21px;}
}
.view_content .textarea_div {position: absolute;
}
.text {display: flex;flex-wrap: wrap;align-content: flex-start;gap: 20px;
}
.finish {text-decoration: line-through;box-shadow: 0 0 10px 5px rgba(255, 255, 255, 0.916);background-color: rgb(191, 210, 255);border-radius: 50px;text-shadow: 1px 1px 1px #030303;box-shadow:inset -2px -2px 3px rgba(255, 255, 255, 0.6),inset 2px 2px 3px rgba(0, 0, 0, 0.6);
}
.numb {border-radius: 50px;color: hsla(160, 100%, 37%, 1);text-shadow: 1px 1px 1px #000000;
}</style>

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

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

相关文章

TypeScript-搭建编译环境

搭建编译环境 TypeScript 编写的代码是无法直接在js引擎( 浏览器 / Nodejs )中运行的&#xff0c;最终还需要经过编译成js代码才可以正常运行 搭建手动编译环境 1️⃣ 全局安装 typescript 包&#xff08;编译引擎&#xff09; -> 注册 tsc 命令 npm i -g typescript 2…

下拉框操作/键鼠操作/文件上传

在我们做UI自动化测试的时候&#xff0c;会有一些元素需要特殊操作&#xff0c;比如下拉框操作/键鼠操作/文件上传。 下拉框操作 在我们很多页面里有下拉框的选择&#xff0c;这种元素怎么定位呢&#xff1f;下拉框分为两种类型&#xff1a;我们分别针对这两种元素进行定位和…

2024最新 Jenkins + Docker 实战教程(五)- 配置Gitee Webhooks实现自动构建部署

&#x1f604; 19年之后由于某些原因断更了三年&#xff0c;23年重新扬帆起航&#xff0c;推出更多优质博文&#xff0c;希望大家多多支持&#xff5e; &#x1f337; 古之立大事者&#xff0c;不惟有超世之才&#xff0c;亦必有坚忍不拔之志 &#x1f390; 个人CSND主页——Mi…

Packet Tracer-HSRP+DHCPv4+VLAN间路由+以太通道综合实验

实验拓扑&#xff1a; 实验内容&#xff1a; VLAN及VLAN间路由的配置&#xff0c;以太通道的配置&#xff0c;STP的根调整&#xff0c;DHCPv4的配置&#xff0c;首跳冗余HSRP的配置。 实验最终结果&#xff1a; PC可以自动获取到DHCP-Server分配的IP地址&#xff0c;实现首跳…

Web3革命:探索科技与物联网的无限可能

引言 Web3时代正在悄然而至&#xff0c;带来了对互联网的彻底颠覆和改变。作为互联网的下一代&#xff0c;Web3不仅是技术革新的延续&#xff0c;更是对传统互联网模式的重新构想。在这个新时代&#xff0c;科技与物联网的结合将迎来无限的可能性&#xff0c;将探索到一片全新…

iOS系统故障怎么办?这三种苹果手机系统修复方法你一定要知道

随着苹果手机使用时间越长&#xff0c;苹果手机有时也会出现系统问题&#xff0c;如卡顿、崩溃、无法启动等。这些问题不仅影响用户的使用体验&#xff0c;还可能导致数据丢失。因此&#xff0c;掌握苹果手机系统修复方法显得尤为重要。本文将详细介绍苹果手机系统修复的常见方…

大模型之Ollama:在本地机器上释放大型语言模型的强大功能

LlaMA 3 系列博客 基于 LlaMA 3 LangGraph 在windows本地部署大模型 &#xff08;一&#xff09; 基于 LlaMA 3 LangGraph 在windows本地部署大模型 &#xff08;二&#xff09; 基于 LlaMA 3 LangGraph 在windows本地部署大模型 &#xff08;三&#xff09; 基于 LlaMA…

实战Java虚拟机-实战篇

一、内存调优 1.内存溢出和内存泄漏 内存泄漏&#xff08;memory leak&#xff09;&#xff1a;在Java中如果不再使用一个对象&#xff0c;但是该对象依然在GC ROOT的引用链上&#xff0c;这个对象就不会被垃圾回收器回收&#xff0c;这种情况就称之为内存泄漏。内存泄漏绝大…

一番赏小程序开发,为玩家带来线上抽赏魅力

随着人们对娱乐消费的增加&#xff0c;以及二次元文化的快速发展&#xff0c;以动漫IP为主的一番赏受到了越来越多的年轻人关注&#xff0c;一番赏市场迎来了黄金发展期&#xff01; 一番赏的运营模式是以“限量”为主&#xff0c;不管什么商品数量都是有限的&#xff0c;因此…

微软刚发布的Copilot+PC为什么让Intel和AMD尴尬?2024 AI PC元年——产业布局及前景展望

美国东部时间5月20日在微软位于华盛顿的新园区举行的发布会上&#xff0c;宣布将旗下AI助手Copilot全面融入Windows系统&#xff0c;能够在不调用云数据中心的情况下处理更多人工智能任务。 “将世界作为一个提示词就从Windows系统开始”。微软的新PC将是“CopilotPC”&#xf…

[Algorithm][回溯][记忆化搜索][最长递增子序列][猜数字大小Ⅱ][矩阵中的最长递增路径]详细讲解

目录 1.最长递增子序列1.题目链接2.算法原理详解3.代码实现 2.猜数字大小 II1.题目链接2.算法原理详解3.代码实现 3.矩阵中的最长递增路径1.题目链接2.算法原理详解3.代码实现 1.最长递增子序列 1.题目链接 最长递增子序列 2.算法原理详解 题目解析&#xff1a;从每个位置&am…

内部类知识点

什么是内部类&#xff1f; 内部类何时出现&#xff1f;B类是A类的一部分&#xff0c;且B单独存在无意义 内部类分类 成员内部类&#xff1a; 当内部类被private修饰后&#xff0c;不能用方法2 调用外部类成员变量 内部类里面有隐藏的outer this来记录 静态内部类 创建对象&…

水电集中抄表是什么?

1.定义分析&#xff1a;水电集中抄表 水电集中抄表是一种现代化能源管理体系方法&#xff0c;它利用先进的信息科技&#xff0c;如物联网技术、云计算等&#xff0c;完成对水电表数据的远程智能采集与处理。这种方法改变了传统的人工上门服务抄表方式&#xff0c;提高了效率&a…

Biome-BGC生态系统模型与Python融合技术实践应用

Biome-BGC是利用站点描述数据、气象数据和植被生理生态参数&#xff0c;模拟日尺度碳、水和氮通量的有效模型&#xff0c;其研究的空间尺度可以从点尺度扩展到陆地生态系统。 在Biome-BGC模型中&#xff0c;对于碳的生物量积累&#xff0c;采用光合酶促反应机理模型计算出每天…

ECharts实现地图飞线

echarts版本&#xff1a;https://echarts.apache.org/zh/changelog.html v5.x.x版本&#xff1a;不提供china.js和china.json文件 v4.x.x版本&#xff1a;使用npm安装echarts&#xff0c;默认包含china.js和china.json文件 目录 一、Html工程 二、vue工程 三、vue工程 四、矢…

c/c++ 编译过程

C的编译过程通常可以分为四个阶段&#xff1a;预处理、编译、汇编和链接。下面是这四个阶段的详细说明&#xff1a; 预处理&#xff08;Preprocessing&#xff09;&#xff1a;在这个阶段&#xff0c;预处理器&#xff08;cpp&#xff09;会处理源代码文件中的预处理指令&#…

【科普知识】伺服电机中的内置制动器

在工业自动化和机器人技术快速发展的今天&#xff0c;伺服电机作为核心驱动元件&#xff0c;其性能与功能直接影响整个系统的运行效率与稳定性。 近年来&#xff0c;一体化伺服电机技术不断融合创新&#xff0c;并逐步加入了许多新的硬件和软件的功能&#xff0c;为工业自动化领…

【施磊】C++语言基础提高:深入学习C++语言先要练好的内功

课程总目录 文章目录 一、进程的虚拟地址空间内存划分和布局二、函数的调用堆栈详细过程三、程序编译链接原理1. 编译过程2. 链接过程 一、进程的虚拟地址空间内存划分和布局 任何的编程语言 → \to → 产生两种东西&#xff1a;指令和数据 编译链接完成之后会产生一个可执行…

Linux备份服务及rsync企业备份架构(应用场景)

备份服务概述 备份服务:需要使用到脚本,打包备份,定时任务. 备份服务:rsyncd服务,不同主机之间数据传输. 特点&#xff1a; rsync是个服务也是命令使用方便&#xff0c;具有多种模式传输数据的时候是增量传输 增量与全量&#xff1a; 全量 &#xff1a;无论多少数据全部推…