插槽、生命周期

购物车加减操作关键代码

```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.value[index].quantity --

}

const btnB = (index) =>{

products.value[index].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 的 \`\\` 元素和特殊的 \`is\` attribute 来实现组件的动态切换

<template>

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

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

</template>

```

生命周期钩子

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

  • 常用钩子:onMounted、onUpdated、onUnmounted

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

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

相关推荐
layman05289 分钟前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔11 分钟前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李11 分钟前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN13 分钟前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒15 分钟前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库17 分钟前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
方也_arkling24 分钟前
Element Plus主题色定制
javascript·sass
电商API_1800790524726 分钟前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫
晓晓莺歌27 分钟前
vue3某一个路由切换,导致所有路由页面均变成空白页
前端·vue.js
2601_949809591 小时前
flutter_for_openharmony家庭相册app实战+我的Tab实现
java·javascript·flutter