语法:例:定义变为的属性为booler, string, number, number[], string[]等等
let isDone: boolean = false;
let isDone: any[]= [1, ‘aaa’];
数组的定义:
方法一: let list: number[] = [1, 2, 4];
方法二: let lsit:Array
元组定义:
let list: [string, number] = [‘aaa’, 20];
注:元组规定初始定义元素的类型和长度,但是在此后可以通过push等方法进行增减,但是增减类型必须满足定义类型的其中之一
例: list.push(‘bbb’)
打包体积减小,优化vdom使运行速度变快;更改了编写结构,使代码不会分散
import { ref, reactive, toRefs } from ‘vue’
都是将数据变成响应式数据;ref主要是用于定义基础数据类型,例:
const num1 = ref(10) // 取值则需要使用 num.value
reactive作用同ref,但是是用于定义复杂的数据类型比如数组和对象
const num2 = reactice({a: 10; b: ‘x’})
注:reactice无法直接将基础数据变成响应式数据,reactive并不会将它包装成porxy对象,
例const num3 = reactice(100) 无法将num3变成响应式数据。
ref 和 reactive 本质我们可以简单的理解为ref是对reactive的二次包装, ref定义的数据访问的时候要多一个.value
reactive也可以看做是vue2中的data函数
{{name}}
{{age}}
...
setup () {
const user = reactive({ name: "Alice", age: 12 });
const newUser = toRefs(user)
return {
...newUser
user,
}
}
import { ref, computed,} from 'vue'
setup () {
const count= ref(1)
const newValue = computed(() => {
return count.value * 2 })
// 一个监听写一条
watch(count, (newVal, oldVal) => {
console.log(newVal, oldVal)
})
// 同时监控多个参数;如果要监听的参数是对象中的某一个,需要通过函数返回,如果只是user.name是没有响应式属性的
watch([count, () => user.name], (newVal, oldVal) => {
console.log('oldvalue:' + oldVal + ' newValue: ' + newVal);
})
}
vue3使用proxy代替原来的Object.defineProperty;他可以对数组或对象的内部元素的修改进行响应式变化。