vue3学习

  1. 响应式数据

    复制代码
     const searchFormState = reactive({})
     const searchFormRef = ref()

两者差不多,reactive()多用于复杂数据结构 ref()多用与简单数据结构

  1. 组件传值

    父传子

    属性传值 父组件给子组件传值属性aa值为data :aa="data"
    子组件接收数据方法 引入defineProps

    复制代码
    const props = defineProps({
    		// 可以拿到它的值
    		aa: {
    			type:Boolean,
    			default: false
    		},
    
    	})

    使用 const bb = props.aa

    子传父

    子组件使用事件触发 引入defineEmits

    复制代码
    	// 定义emit事件
    	const emit = defineEmits({ checkedItem: null, checkedGroupListItem: null })
    	....
    	///触发checkedItem事件,传递item数据
    	emit('checkedItem', item)

    父组件监听 <zujian @checkedItem="checkedItem" />

    复制代码
     const checkedItem=(item)=>{
     	...
     }

子组件中的方法需要暴露出去才能被父组件调用

复制代码
	```
	// 在子组件中抛出 onOpen方法
		defineExpose({
			onOpen
		})
	```
	
	```
	//父组件中可通过ref调用
	<zujian ref="aaRef" @checkedItem="checkedItem" />`
	const aaRef= ref()
	
	aaRef.onOpen(record)
	
	```
  1. 生命周期

    Vue3 的生命周期函数包括 beforeCreate、created、beforeMount、mounted、beforeUpdate、updated、beforeDestroy、destroyed 等。

    beforeCreate 函数是整个 Vue3 实例创建的第一个生命周期函数它会在实例初始化之前调用,可以用来对实例进行初始化,在这个函数里可以定义一些全局变量,以及添加一些指令、过滤器等

    created 函数会在 beforeCreate 函数之后调用,这个生命周期函数用于处理数据和事件,可以在这里做一些数据处理,如获取服务器数据,定义一些自定义事件,以及定义一些全局方法等

    beforeMount 函数会在 created 函数之后调用,它用于处理 DOM操作,在这个函数里可以检查 DOM 是否正确渲染,也可以定义一些 DOM 操作,比如给某个元素设置属性,添加一些事件等。

    mounted 函数会在beforeMount 函数之后调用,它是 Vue3实例挂载完成后调用的函数,可以在这里定义一些 DOM 操作,比如改变某个元素的样式,添加某个 class 等

相关推荐
王码码20359 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
发现一只大呆瓜9 小时前
深入浅出 AST:解密 Vite、Babel编译的底层“黑盒”
前端·面试·vite
天天鸭9 小时前
前端仔写了个 AI Agent,才发现大模型只干了 10% 的活
前端·python·ai编程
_李小白9 小时前
【OSG学习笔记】Day 2: Hello Cow
笔记·学习
ic爱吃蓝莓9 小时前
数据结构 | HashMap原理
数据结构·学习·算法·链表·哈希算法
发现一只大呆瓜9 小时前
前端模块化:CommonJS、AMD、ES Module三大规范全解析
前端·面试·vite
IT_陈寒9 小时前
一文搞懂JavaScript的核心概念
前端·人工智能·后端
IT_陈寒9 小时前
Java开发者必看!5个提升开发效率的隐藏技巧,你用过几个?
前端·人工智能·后端
鹭天9 小时前
Langchain学习笔记
笔记·学习·langchain
前端Hardy9 小时前
Wails v3 正式发布:用 Go 写桌面应用,体积仅 12MB,性能飙升 40%!
前端·javascript·go