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 等

相关推荐
北海-cherish2 小时前
vue中的 watchEffect、watchAsyncEffect、watchPostEffect的区别
前端·javascript·vue.js
AALoveTouch2 小时前
网球馆自动预约系统的反调试
javascript·网络
@小博的博客3 小时前
【Linux探索学习】第二篇Linux的基本指令(2)——开启Linux学习第二篇
linux·运维·学习
2501_915909063 小时前
HTML5 与 HTTPS,页面能力、必要性、常见问题与实战排查
前端·ios·小程序·https·uni-app·iphone·html5
white-persist4 小时前
Python实例方法与Python类的构造方法全解析
开发语言·前端·python·原型模式
新中地GIS开发老师5 小时前
Cesium 军事标绘入门:用 Cesium-Plot-JS 快速实现标绘功能
前端·javascript·arcgis·cesium·gis开发·地理信息科学
Superxpang5 小时前
前端性能优化
前端·javascript·vue.js·性能优化
左手吻左脸。5 小时前
解决el-select因为弹出层层级问题,不展示下拉选
javascript·vue.js·elementui
左手吻左脸。5 小时前
Element UI表格中根据数值动态设置字体颜色
vue.js·ui·elementui
李白的故乡5 小时前
el-tree-select名字
javascript·vue.js·ecmascript