当前位置: 首页 > news >正文

第一个Vue项目笔记(待更新)

项目初始化

在这里插入图片描述

compisiton api中的setup函数

为什么setup取代了两个钩子函数1.在 beforeCreate 阶段,组件实例尚未初始化,几乎无法进行有意义的操作(无法访问 data、methods 等)。绝大多数场景下,开发者不需要使用它。2.created 的核心作用是在数据观测完成后执行初始化逻辑,但这一逻辑完全可以在 setup() 中通过同步代码实现,无需额外生命周期钩子。3.this指向undefined
但是对于setup的返回值和export default的问题 用setup语法糖

对ref的误解

1.支持所有数据类型
2.因为vue的响应式系统依赖proxy(只能代理对象),ref会创建一个包含value属性的对象来包装基本数据类型,所以会.value
3.ref处理引用数据类型时,还是会.value,因为其实是.value包装的一个reactive对象
4.对于对象的属性都要在一开始初始化的时候写好?
Vue 3 的响应式系统(基于 Proxy)默认只能追踪已存在的属性,但可以通过 替换整个对象 触发响应式更新:

const form=ref({})
const addProperty=()=>{
form.value={...form.value,newProp:'新增加的值'}
}

底层封装?refiml和proxy?

vue3 的监听属性

watch监听的对象有三类

整个对象(此时不用.value) (但是要注意watch只能浅层监听 如果想深层监听的话 要在最后加{deep:true}
多个数据源 例如[a1,a2]
箭头函数返回对象的某个属性(不用深层监听但是必须要写为箭头函数的形式 例如()=>state.value.age

生命周期钩子

1.生命周期钩子的触发是自动的,但具体逻辑的实现或配置需要开发者显式完成。
2.同一个可以写很多一样的不影响

挂载引用

ref内的名字要一样
组件挂载完毕之后才能访问

//组件的挂载引用
const child =ref(null)
<children ref="child"/>
//父组件访问子组件,子组件中必须defineExpose暴露想暴的
defineExpose({
})
//对于其他标签也可以挂载引用
const pp=ref(null)
<input ref="pp"/>

如何理解子传父?

子组件某个事件监听中,如果需要父组件的做出相应的变化就emit的写法就行了

//子组件编译器宏函数
const emit=defineEmits({})
//子组件的事件监听中
emit('名','可以传递相关参数')
//父组件中
<子组件 @名="相关逻辑"/>

props和ref+expose对比

特性 props ref + expose
数据方向 父 → 子(单向) 父 ↔ 子(双向,但需显式暴露)
适用场景 数据传递、状态同步、展示型组件 命令式操作、访问子组件内部
代码侵入性 低(子组件需声明 props) 高(子组件需 defineExpose)
组件耦合度 低(通过接口约定) 高(依赖具体方法名)
典型用例 配置传递、表单初始值 打开弹窗、调用子组件方法

创建项目遇到的坑

JSX vitest end-end prettier都是no!??不过这几个都有什么用??
创建好要依次执行三条指令(不执行的话就无法使用,这个同样适用于clone别人的项目)


http://www.mrgr.cn/news/92852.html

相关文章:

  • 250301-OpenWebUI配置DeepSeek-火山方舟+硅基流动+联网搜索+推理显示
  • C语言学习笔记-初阶(19)猜数字游戏:分支、循环结构的应用
  • 大数据学习(51)-MySQL数据库学习
  • IP-----双重发布
  • ConcurrentHashMap
  • 初始化列表
  • 详解:事务注解 @Transactional
  • 安装 Open WebUI
  • 【HarmonyOS NEXT】控制 WebP 格式动图播放次数的实现方案
  • Redis---缓存穿透,雪崩,击穿
  • MySQL慢查询分析与处理
  • C++:类和对象(下篇)
  • 实验环境搭建集锦(docker linux ros2+强化学习环境+linux上单片机串口调试)
  • nuxt常用组件库html-validator、@nuxtjs/i18n、@nuxt/image、@unocss/nuxt使用解析
  • dj算法与分层图最短路径
  • LeetCode 解题思路 6(Hot 100)
  • 机器学习:线性回归,梯度下降,多元线性回归
  • 入门基础项目(SpringBoot+Vue)
  • AI辅助学习vue第十四章
  • 进程的状态 ─── linux第11课