插槽、生命周期

购物车加减操作关键代码

```vue

<template>

<tr v-for="(item,index) in products">

<input type="button" value="-" @click="btnA(index)">

<input type="text" v-model="item.quantity">

<input type="button" value="+" @click="btnB(index)">

<input type="button" value="移除" @click="btnRemove(index)">

</tr>

</template>

<script>

let totlaAmount = computed(()=>{

let tmp = products.value.reduce((a,b)=>{

return a += b.price * b.quantity

},0)

return tmp

})

const btnA = (index) =>{

products.valueindex.quantity --

}

const btnB = (index) =>{

products.valueindex.quantity ++

}

const btnRemove = (index) =>{

products.value.splice(index,1)

}

</script>

```

笔记

插槽(Slots)

  1. 概念:在组件中使用 `<slot>` 元素作为占位符,可将父组件传递进来的内容渲染到指定位置。

```vue

<template>

<ButtonCounter>

8888

<Profile></Profile>

</ButtonCounter>

</template>

<script setup>

import ButtonCounter from './components/ButtonCounter.vue'

import Profile from './components/Profile.vue';

import {ref, shallowRef} from 'vue'

// let cc = ref(ButtonCounter)

let cc = shallowRef(ButtonCounter)

let count = 1

function btn(){

count ++

if(count % 2 === 0){

cc.value = Profile

}else{

cc.value = ButtonCounter

}

}

</script>

```

  1. 动态组件实现方式:通过 Vue 的 `<component>` 元素和特殊的 `is` attribute 来实现组件的动态切换

```vue

<template>

<component :is="cc"></component>

<input type="button" value="点下" @click="btn">

</template>

```

生命周期钩子

  • 概念:每个 Vue 组件实例在创建时会经历一系列初始化步骤,在此过程中会运行生命周期钩子函数,让开发者有机会在特定阶段运行自己的代码

  • 常用钩子:onMounted、onUpdated、onUnmounted

  • 注册方式:在组件初始化时同步注册生命周期钩子。例如,在 `<script setup>` 中调用 `onMounted()` 等钩子函数

  • 注意事项:不要在异步函数中注册生命周期钩子,否则可能导致当前组件实例丢失,钩子无法正常工作

相关推荐
该用户已成仙6 分钟前
vue3 使用 vuedraggable 报错 TypeError: isFunction2 is not a function
前端·javascript·vue.js
aidou13147 分钟前
Kotlin中实现星级评价选择功能(仅支持整数)
前端·kotlin·自定义view·imageview·ontouchevent·customratingbar
良逍Ai出海10 分钟前
我用 Codex 搭了一个 WordPress 独立站
前端
TPBoreas12 分钟前
前端面试问题打把-场景题
开发语言·前端·javascript
问心无愧051312 分钟前
ctf show web入门159
前端·笔记
San813_LDD12 分钟前
[Vue/HTML]ECharts 使用指南:从入门到绘制各种常用图表
vue.js·html·echarts
恋猫de小郭16 分钟前
Flutter 又为 AI 时代添砖加瓦:全新 ComponentLibrary 提议
android·前端·flutter
就叫_这个吧18 分钟前
HTML或JSP页面链接CSS,link标签没问题,但不显示样式问题解决
java·前端·css·html·intellij-idea·jsp
IT_陈寒22 分钟前
SpringBoot这个坑差点让我加班到天亮
前端·人工智能·后端
小小龙学IT27 分钟前
Rust Web 框架 Axum:轻量级异步的下一代后端利器
前端·驱动开发·rust