目录setup语法糖 setup语法糖独有 自定义指令相关 setup语法糖 最大好处就是所有声明部分皆可直接使用,无需return出去 注意:部分功能还不完善
最大好处就是所有声明部分皆可直接使用,无需return出去
注意:部分功能还不完善,如:name、render还需要单独加入script标签按compositionapi方式编写
// setup 下还可以附加<script>
<script setup>
import { ref ,Reactive,toRefs } from 'Vue'
const a = 1;
const num = ref(99) // 基本数据类型
const user = reactive({ // 引用数据类型
age:11
})
// 解构能获取响应式属性 {}解构 toRefs保留响应式
const { age } = toRefs(user)
// 导出
defineExpose({
a
})
// props
const props = defineProps({
foo: String
})
// 事件
const emit = defineEmits(['change', 'delete'])
// 自定义指令
const vMyDirective = {
created(el, binding, vnode, prevVnode) {
// 下面会介绍各个参数的细节
console.log('创建了')
},
}
</script>
defineProps defineEmits与组件应用
// 子组件
<template>
<div class="hello">
<h1>{{ msg }}</h1>
<slot name="btn">
</slot>
<button @click="chickMe"></button>
</div>
</template>
<script setup>
import { useSlots, useAttrs } from 'vue';
const slots = useSlots()
const attrs = useAttrs()
const props = defineProps({
msg: String
})
const emit = defineEmits(['change'])
console.log(slots, attrs)
const chickMe = ()=>{
emit('change','abc')
}
</script>
// 父组件
<template>
<div class="home" >
<HelloWorld msg="hello" atr="attrs" @change="changeP ">
<template #btn>
<div>我是 btn:{{ obj.text }}</div>
</template>
</HelloWorld>
</div>
</template>
<script setup>
import HelloWorld from '../components/HelloWorld.vue';
import { ref ,reactive,toRefs } from 'vue'
const obj = reactive({
id: 0,
text: '小红'
})
const changeP=(e)=>{
console.log(e)
}
</script>
、
defineExpose与组件应用
// 子组件
<template>
<div class="hello">
123
</div>
</template>
<script setup>
const testPose =()=>{
console.log('子组件暴露方法')
}
defineExpose({
testPose
})
</script>
// 父组件
<template>
<div class="home" v-test>
<HelloWorld ref="helloSon"></HelloWorld>
<button @click="testEpose"></button>
</div>
</template>
<script setup>
import HelloWorld from '../components/HelloWorld.vue';
import { ref } from 'vue'
// setup函数的话可以从context上查找
const helloSon = ref(null);
const testEpose = () => {
helloSon.value.testPose();
}
</script>
import { createApp } from 'vue';
const Test = createApp();
Test.directive('my-directive', {
// 在绑定元素的 attribute 前
// 或事件监听器应用前调用
created(el, binding, vnode, prevVnode) {
// 下面会介绍各个参数的细节
console.log('创建了')
},
// 在元素被插入到 DOM 前调用
beforeMount(el, binding, vnode, prevVnode) { },
// 在绑定元素的父组件
// 及他自己的所有子节点都挂载完成后调用
mounted(el, binding, vnode, prevVnode) { },
// 绑定元素的父组件更新前调用
beforeUpdate(el, binding, vnode, prevVnode) { },
// 在绑定元素的父组件
// 及他自己的所有子节点都更新后调用
updated(el, binding, vnode, prevVnode) { },
// 绑定元素的父组件卸载前调用
beforeUnmount(el, binding, vnode, prevVnode) { },
// 绑定元素的父组件卸载后调用
unmounted(el, binding, vnode, prevVnode) { }
})
export default Test.directive('my-directive');
el
:指令绑定到的元素。这可以用于直接操作 DOM。binding
:一个对象,包含以下属性。value
:传递给指令的值。例如在 v-my-directive="1 + 1"
中,值是 2
。oldValue
:之前的值,仅在 beforeUpdate
和 updated
中可用。无论值是否更改,它都可用。arg
:传递给指令的参数 (如果有的话)。例如在 v-my-directive:foo
中,参数是 "foo"
。modifiers
:一个包含修饰符的对象 (如果有的话)。例如在 v-my-directive.foo.bar
中,修饰符对象是 { foo: true, bar: true }
。instance
:使用该指令的组件实例。dir
:指令的定义对象。vnode
:代表绑定元素的底层 VNode。prevNode
:之前的渲染中代表指令所绑定元素的 VNode。仅在 beforeUpdate
和 updated
钩子中可用。应用
<template>
<div class="home" v-test>
</div>
</template>
//setup 外部调用
<script>
// 指令必须 vXxx 这样书写
import vTest from './TestDirective'
export default defineComponent({
directives: {
test:vTest,
},
setup(props) {
// console.log('Test',vTest)
return {
};
}
})
</script>
//或者 setup内部
<script setup>
import vTest from './TestDirective'
</script>
对象字面量
<div v-demo="{ color: 'white', text: 'hello!' }"></div>
app.directive('demo', (el, binding) => {
console.log(binding.value.color) // => "white"
console.log(binding.value.text) // => "hello!"
})
到此这篇关于vue3 关于setup与自定义指令的文章就介绍到这了,更多相关Vue3 setup内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Vue3中关于setup与自定义指令详解
本文链接: https://lsjlt.com/news/209618.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
2024-01-12
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
2023-05-20
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0