全部
常见问题
产品动态
精选推荐

vue3 常用的知识点汇总

管理 管理 编辑 删除

setup:容许在script当中书写组合式API 并且vue3的template不再要求唯一的根元素

<script setup>

const name = 'app';

</script>

组合式API的用法:

可以直接在script标签中定义变量或者函数,然后直接在template当中使用

<template>

 {{message}}

 <button @click="logMessage">log</button>

</template>

<script setup>

const message = 'this is message'

const logMessage = () =>{

console.log("logMessage")

}

</script>

响应式变量reactive的使用:

<template>

 <button @click="setCount">{{state.count}}</button>

</template>

<script setup>

//导入函数

import {reactive} from 'vue'

//执行函数 传入一个对象类型的参数

const state = reactive({

count:0

})

const setCount = () =>{

state.count++

}

</script>

响应式变量ref的使用:

<template>

 <button @click="setCount">{{count}}</button>

</template>

<script setup>

//导入函数

import {ref} from 'vue'

//执行函数 传入一个对象类型或者简单数据类型的参数

const count= ref(0)

const setCount = () =>{

count.value++

}

</script>

computed计算属性

<template>

 <div>

 原始响应式数据:{{list}}

 </div>

 <div>

 计算属性数组{{computedList}}

 </div>

</template>

<script setup>

//原始响应式

import { ref } from 'vue'

//导入computed

import { computed } from 'vue'

const list = ref([1,2,3,4,5,6,7,8])

//执行计算函数

const computedList = computed(()=>{

return list.value.filter(item=>item>2)

})

setTimeout(()=>{

list.value.push(9,10)

},3000)

</script>

watch函数:侦听一个或者多个数据的变化,数据变化时执行的函数。两个额外的参数1.immediate (立即触发) 2.deep(深度监听)

<template>

 <div>

 <button @click="setCount">+{{count}}</button>

 </div>

</template>

<script setup>

import {ref,watch} from 'vue'

const count = ref(0)

const setCount = () => {

 count.value++

}

watch(count,(newVal,oldVal)=>{

console.log('count变化了',newVal,oldVal);

})

</script>

watch监听对象数据的某一个属性:

<template>

 <div>

 <button @click="changeName">name:{{state.name}}</button>

 <button @click="changeAge">age:{{state.age}}</button>

 </div>

</template>

<script setup>

import {ref,watch} from 'vue'

const state = ref({

name:'cc',

age:18

})

const changeName = () => {

 state.value.name='aa'

}

const changeAge = ()=>{

state.value.age=20

}

//当只有age属性发生变化时才会触发回调函数

watch(

() => state.value.age,

() => {

console.log('age变化了');

}

)

</script>

生命周期函数:

cc6e220240729091448354.png

父组件给子组件传值:
1.父组件给子组件绑定属性
2.子组件内部通过props选项接收

父组件

<template>

<div class="fathher">

<h2>父组件</h2>

<!-- 传入想要传的值 message为固定的值,count为响应式的值-->

<son :count="count" message="father message"></son>

</div>

</template>

<script setup>

//setup语法糖下局部组件无需注册直接可以使用

import Son from './son.vue'

import {ref} from 'vue'

const count = ref(100)

setTimeout(()=>{

count.value = 200

},3000)

</script>

子组件:

<template>

<div class="son">

<h3>子组件Son</h3>

父组件传入的数据:{{message}}-{{count}}

</div>

</template>


<script setup>

//用defineProps接收父组件传的值

   const  props = defineProps({

message:String,

count:Number

})

console.log(props);

</script>

组合式API下的子传父:
1.父组件中给子组件标签通过@绑定事件
2.子组件内部通过$emit方法触发事件

父组件:

<template>

<div class="fathher">

<h2>父组件</h2>

<!-- 1.绑定事件 -->

<son @get-message="getMessage"></son>

</div>

</template>

<script setup>

//setup语法糖下局部组件无需注册直接可以使用

import Son from './son.vue'

const getMessage = (msg) => {

console.log(msg)

}

</script>

子组件:

<template>

<div class="son">

<h3>子组件Son</h3>

<button @click="sendMsg">触发自定义事件</button>

</div>

</template>

<script setup>

//2.通过defineEmits() 定义事件

const emit = defineEmits(['get-message'])

const sendMsg = () =>{

emit('get-message','this is son message')

}

</script>



请登录后查看

小码二开 最后编辑于2024-07-29 09:17:58

快捷回复
回复
回复
回复({{post_count}}) {{!is_user ? '我的回复' :'全部回复'}}
排序 默认正序 回复倒序 点赞倒序

{{item.user_info.nickname ? item.user_info.nickname : item.user_name}} LV.{{ item.user_info.bbs_level }}

作者 管理员 企业

{{item.floor}}# 同步到gitee 已同步到gitee {{item.is_suggest == 1? '取消推荐': '推荐'}}
{{item.is_suggest == 1? '取消推荐': '推荐'}}
沙发 板凳 地板 {{item.floor}}#
{{item.user_info.title || '暂无简介'}}
附件

{{itemf.name}}

{{item.created_at}}  {{item.ip_address}}
{{item.like_count}}
{{item.showReply ? '取消回复' : '回复'}}
删除
回复
回复

{{itemc.user_info.nickname}}

{{itemc.user_name}}

回复 {{itemc.comment_user_info.nickname}}

附件

{{itemf.name}}

{{itemc.created_at}}
{{itemc.like_count}}
{{itemc.showReply ? '取消回复' : '回复'}}
删除
回复
回复
查看更多
897
{{like_count}}
{{collect_count}}
添加回复 ({{post_count}})

相关推荐

快速安全登录

使用微信扫码登录
{{item.label}} 加精
{{item.label}} {{item.label}} 板块推荐 常见问题 产品动态 精选推荐 首页头条 首页动态 首页推荐
取 消 确 定
回复
回复
问题:
问题自动获取的帖子内容,不准确时需要手动修改. [获取答案]
答案:
提交
bug 需求 取 消 确 定

微信登录/注册

切换手机号登录

{{ bind_phone ? '绑定手机' : '手机登录'}}

{{codeText}}
切换微信登录/注册
暂不绑定
CRMEB客服

CRMEB咨询热线 咨询热线

400-8888-794

微信扫码咨询

CRMEB开源商城下载 源码下载 CRMEB帮助文档 帮助文档
返回顶部 返回顶部
CRMEB客服