element-plus坑总结

reactive和ref对比

在这里插入图片描述

// 定义变量
import { reactive } from 'vue';
const person = reactive({name: "John",age: 25,
});// 赋值修改
person.name = "Tom";
person.age = 26;// 使用变量
<div>{{ person.name }}</div>
<button @click="person.age++">Increase Age</button>console.log(person.name); // 输出当前名称
person.age++; // 增加年龄// 使用toRefs
let { name, age} = toRefs(person)
<div>{{ name }}</div>
console.log(name.value); // 输出当前名称
// 定义变量
import { ref } from 'vue';
const name = ref("John");
const age = ref(25);// 赋值修改
name.value = "Tom";
age.value = 26;// 使用变量
<div>{{ name }}</div>
<button @click="age++">Increase Age</button>console.log(name.value); // 输出当前名称
age.value++; // 增加年龄

form表单inline横向布局时,input加了clearable属性后,鼠标移入输入内容宽度会发生变化,失去焦点恢复原始宽度

  • 原因:el-input是没有宽度的,实际渲染出来的 el-input宽度 = 原生input宽度 + 前缀图标宽度 + 后缀图标宽度
  • 解决:input 的 width设置为215px,刚好等于select框
<el-input v-model="formInline.user" placeholder="Approved" clearable style="width:215px" />

button 默认是middle,但是比vue2的大很多

  • ruoyi.scss 覆盖样式
 .el-button--middle,.el-button--default {height: 28px;font-size: 12px;}

form表单重置,必须在form-item上添加props属性,否则不起作用

table数据赋值,视图不更新

问题原因
tableData不是代理对象,使用直接将新的值赋给tableData,视图不会更新
后来将table定义为代理对象,还是失败的原因是数组的改变有些情况vue3响应监测不到
vue3 使用proxy,对于对象和数组都不能直接整个赋值

失败案例:获取接口数据赋值给列表arr

const arr = reactive([]); 
const load = (res) => {arr = res; // 方法1 失败,直接赋值丢失了响应性arr.concat(res); // 方法2 这样也是失败
};

解决方法:成功案例

// 方案1:创建一个响应式对象,对象的属性是数组
const data = reactive({arr: []
});
data.arr = res// 方案2: 使用ref函数定义
const arr= ref([])
arr.value = res// 方案3: 使用数组的push方法
const arr = reactive([])
arr.push(...res)

数组对象的TS写法——继上述成功案例

  • 方案1:创建一个响应式对象,对象的属性是数组
interface List {date: string,name: string,address: string
}
interface Table {tableData: List[]
}
let table: Table = reactive({tableData: []
})
let getList = (data) => {table.tableData = data
}
  • 方案2: 使用ref函数定义
interface List {date: string,name: string,address: string
}
// const userList = ref<any>();
let userList = ref<List[]>([]) 
let getList = (data) => {userList.value = data
}
  • 方案3: 使用数组的push方法
interface List {date: string,name: string,address: string
}
let tableData: List[] = reactive([])
let getList = (data) => {tableData.push(...data)
}

使用reactive定义的数组,使用push之后,原来push的内容都会变为最后一次的数据

原因
因为push的并不是一个值,而是一个地址,数组都指向同一个地址
每一次push就等同于改变了数组的地址,所以会导致每次都变成了最后push的内容。

解决方法:将push的内容深拷贝一份再push

let table: Table = reactive({tableData: []
})
let add = ()=>{table.tableData.push(JSON.parse(JSON.stringify(addForm)))
}

总结:reactive及接口使用场景

interface Option {username: string;phone: string;
}
interface Op {visible: boolean;user: Option[];
}
let addOption: Op = reactive({visible: false,user: [{username: "",phone: "",},],
});

?的使用

在这里插入图片描述

对于props的类型定义

在这里插入图片描述

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

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

相关文章

java用 postman输入 数字 会加上单引号 和逗号,方便查询

java用 postman输入 数字 会加上单引号 和逗号&#xff0c;方便查询 /*** 输入12575726* 891006* 12575726* 891006* 返回* 12575726,* 891006,* 12575726,* 891006* 方便查询数据* param data* return*/RequestMapping(value "l…

MySQL八股学习记录5MySQL锁from小林coding

MySQL八股学习记录5MySQL锁from小林coding 锁的总览全局锁表级锁表锁元数据锁意向锁AUTO-INC锁 行级锁Record LockGap LockNext-Key-Lock插入意向锁行级锁是如何作用的唯一索引等值查询 唯一索引范围查询非唯一索引等值查询 锁的总览 MySQL锁分为三种,分别是全局锁,表级锁,行级…

从零开始学习 Java:简单易懂的入门指南(一)

Java基础语法 1. 人机交互1.1 什么是cmd&#xff1f;1.2 如何打开CMD窗口&#xff1f;1.3 常用CMD命令1.4 CMD练习1.5 环境变量 2. Java概述1.1 Java是什么&#xff1f;1.2下载和安装1.2.1 下载1.2.2 安装1.2.3 JDK的安装目录介绍 1.3 HelloWorld小案例1.3.1 Java程序开发运行…

RK3588+FPGA视频实时处理与双屏显示、存储解决方案

主板平台的主要功能电路示意图 在ARM端: 脚踏开关是电平输入10 口&#xff0c;双路。 触摸面板与主板的连接方式为 UART 外加12V 电源。 键盘为自开发产品&#xff0c;通过USB透传 UART&#xff0c;并传递12V电源USB、千兆网络为主板上的接口&#xff0c;USB 为3.0版本host 接口…

【iOS】编译与链接

前言 计算机语言分为机器语言、汇编语言和高级语言。 可以将高级语言分为两种&#xff1a;编译语言和解释型语言&#xff08;直译式语言&#xff09;。 解释型语言&#xff08;逐步进行解释执行&#xff09; 解释语言编写的程序在每次运行时都需要通过解释器对程序进行动态…

23.AOP

AOP AOP&#xff08;Aspect Oriented Programming&#xff09;是一种设计思想&#xff0c;是软件设计领域中的面向切面编程&#xff0c;它是面向对象编程的一种补充和完善&#xff0c;它以通过预编译方式和运行期动态代理方式实现在不修改源代码的情况下给程序动态统一添加额外…

postgresql导入导出数据库的一些问题

新建一个数据库 别忘了添加空间数据的扩展 备份之前的数据库 注意一定要自定义表&#xff0c;去掉 spatial_ref_sys &#xff0c;要不然需要先drop在创建&#xff0c;可能会报错。 一般不会去导函数&#xff0c;如果有个别自己创建的函数可以手动复制一下&#xff0c;全部导的话…

音视频技术开发周刊 | 302

每周一期&#xff0c;纵览音视频技术领域的干货。 新闻投稿&#xff1a;contributelivevideostack.com。 ChatGPT神器Code Interpreter终于开放&#xff0c;到底怎么用&#xff1f;这里有一份保姆级教程 Code Interpreter 已经正式开放。 上海世界AI大会&#xff1a;MidJourney…

加水印用什么软件你知道吗?告诉你加水印的app哪个好用吧

笑笑是一个热爱生活的女孩&#xff0c;她经常会随手拍下生活的瞬间&#xff0c;并且在社交媒体上分享自己的开心时刻。然而&#xff0c;最近她发现自己的照片被未经授权地使用在其他网站和博客上。这让她感到非常生气。为了保护自己的作品权益&#xff0c;她决定寻找一个好用的…

Qt6 Qt Quick UI Prototype学习QML第一篇

Qt6 Qt Quick UI原型学习QML第一篇 开始创建项目Qt Quick UI原型简介.qmlproject文件举例Window平台小例子运行效果QML语法 了解语法 开始创建项目 创建一个具有QML入口点的Qt Quick 2 UI项目。要使用它&#xff0c;您需要设置一个QML运行时环境&#xff0c;例如gmlscene。 仅当…

【C语言】Sleep()函数----详解

&#x1f341; 博客主页:江池俊的博客 &#x1f341;收录专栏&#xff1a;C语言——探索高效编程的基石 &#x1f341; 如果觉得博主的文章还不错的话&#xff0c;请点赞&#x1f44d;收藏&#x1f31f; 三连支持一下博主&#x1f49e; 目录 前言 &#x1f4cc;C语言sleep函…

群雄逐鹿,全球 “电竞之都”将花落谁家?

提到深圳&#xff0c;你会想到什么&#xff1f; 四十多年前的小渔村、改革开放排头兵&#xff0c;还是由科技驱动的经济特区&#xff1f; 这些头衔都已经司空见惯了&#xff0c;接下来深圳预计还将有个最新名号——国际电竞之都&#xff0c;这是一个让无数年轻人听到就会兴奋…