vue3及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的类型定义

在这里插入图片描述

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: vue3-element-plus-admin是一个基于Vue3和Element Plus的后台管理系统模板。它提供了丰富的界面组件和功能,可以快速搭建起一个功能完善的后台管理系统。 首先,vue3-element-plus-admin使用了Vue3作为核心框架,Vue3相比于Vue2在性能和开发体验上有很大的提升。Vue3采用了更先进的响应式机制,使得数据更新更高效;新的组合式API让开发者可以更灵活地组织代码和复用逻辑。 其次,vue3-element-plus-admin还使用了Element Plus作为UI组件库。Element Plus是一套基于Element UI的升级版本,提供了更丰富的UI组件和更好的自定义性。通过Element Plus的组件,我们可以轻松实现表格、表单、弹窗、导航等常见的后台管理功能。 此外,vue3-element-plus-admin还提供了一些常用的功能模块,比如权限管理、用户管理、角色管理等。通过这些功能模块,我们可以方便地进行用户身份验证和权限控制。同时,vue3-element-plus-admin还提供了数据可视化的功能,可以将后台数据以图表的形式展示,帮助我们更好地理解和分析数据。 总的来说,vue3-element-plus-admin是一个功能强大、易于使用和可定制化的后台管理系统模板。它使用了Vue3和Element Plus的最新技术,并提供了丰富的界面组件和功能模块,帮助开发者快速搭建起一个现代化的后台管理系统。无论是个人项目还是企业应用,vue3-element-plus-admin都是一个值得选择的工具。 ### 回答2: Vue3-Element Plus-Admin是一个基于Vue3和Element Plus的后台管理系统模板。它提供了一套完整的UI组件库,以及丰富的功能和布局样式,方便开发者快速搭建和定制自己的后台管理系统。 Vue3是Vue.js的最新版本,它在性能和开发体验上做了很多改进。相比于之前的版本,Vue3使用了更加高效的响应式系统,并且在编译和渲染方面也做了优化,提升了应用的性能。同时,Vue3还引入了新的特性和语法糖,让开发更加简洁方便。 Element Plus是一套基于Element UI的UI组件库,它提供了丰富的UI组件,包括按钮、表单、表格、弹窗等,使用起来非常直观和方便。Element Plus的组件也支持按需加载,可以根据项目需求来引入需要的组件,减小项目的体积。 Vue3-Element Plus-Admin结合了Vue3和Element Plus的优势,为开发者提供了一套完整的后台管理系统模板。开发者可以通过这个模板快速搭建后台管理系统,并根据自己的需求来进行自定义。模板提供了常见的功能和布局样式,包括登录、主页、菜单导航、表单、表格等,开发者只需根据具体业务需求进行修改和扩展即可。 总结来说,Vue3-Element Plus-Admin是一个基于Vue3和Element Plus的后台管理系统模板,它提供了一套完整的UI组件库和丰富的功能和布局样式,方便开发者快速搭建和定制自己的后台管理系统。 ### 回答3: vue3-element-plus-admin 是一个基于 Vue3 和 Element Plus 的后台管理系统框架。它使用了最新的 Vue3 版本,具有更高的性能和更好的开发体验。Element Plus 是一套基于 Vue3 的 UI 组件库,提供了丰富的组件来构建前端界面。 vue3-element-plus-admin 提供了一套完整的后台管理系统解决方案。它包括了常见的登录、权限管理、用户管理、角色管理、菜单管理等功能。使用它可以快速搭建一个功能完善的后台管理系统。 该框架采用模块化的开发方式,将各个功能模块拆分成独立的组件,有利于代码的复用和维护。同时它还使用了响应式设计,可以根据屏幕大小自动适应不同的设备,提供更好的用户体验。 在界面设计上,vue3-element-plus-admin 内置了 Element Plus 的样式,提供了整洁美观的界面效果。同时,它还支持自定义主题,可以根据需求进行样式的定制,满足不同项目的需求。 该框架还提供了丰富的插件和工具,如富文本编辑器、数据可视化图表、国际化支持等,方便开发者快速添加各种功能和扩展。 总之,vue3-element-plus-admin 是一个强大的 Vue3 后台管理系统框架,具有丰富的功能和灵活的扩展性,适用于各种中小型项目的快速开发。它提供了优秀的开发体验和用户体验,帮助开发者轻松搭建出优秀的后台管理系统。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小曲曲

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值