Webpack从“配置到提速”,4步解决“打包慢、体积大”问题

一、数据绑定:别让模板变成“计算战场”

1. 复杂逻辑抽离到计算属性

问题:模板中写{{ user.age > 18 ? '成年' : '未成年' }}等复杂表达式,会导致模板臃肿且难以维护。
解决方案:用computed封装逻辑,兼具缓存特性(依赖不变则不重复计算)。

vue

<template> <p>{{ userStatus }}</p> </template> <script> export default { data() { return { user: { age: 20 } } }, computed: { userStatus() { // 逻辑抽离,模板更清晰 return this.user.age > 18 ? '成年' : '未成年' } } } </script>

2. v-model 绑定类型要“专一”

问题:输入框绑定number类型却意外赋值字符串,导致123 + 456 = "123456"等逻辑错误。
解决方案:指定v-model修饰符或在数据更新时强制类型转换。

vue

<!-- 输入框自动转为数字 --> <input v-model.number="age" type="number"> <script> export default { data() { return { age: 0 } }, // 初始化为 number 类型 watch: { age(newVal) { this.age = Number(newVal) } // 双重保险 } } </script>

---

二、父子组件通信:遵守“单向数据流”铁律

1. 子组件绝不直接修改 props

问题:子组件直接修改props数据(如this.message = '新内容'),会导致数据源头混乱,难以追溯。
正确流程:子组件通过$emit触发事件,父组件接收后更新数据。

vue

<!-- 子组件 Child.vue --> <template> <button @click="updateParent">修改标题</button> </template> <script> export default { props: ['title'], // 只读 props methods: { updateParent() { this.$emit('update-title', '新标题') // 触发事件传递数据 } } } </script> <!-- 父组件 Parent.vue --> <template> <Child :title="parentTitle" @update-title="parentTitle = $event" /> </template> <script> export default { data() { return { parentTitle: '旧标题' } } } </script>

2. 复杂数据传递用 .sync 或 v-model 语法糖

场景:父子组件频繁双向同步数据(如弹窗开关、表单输入)。

vue

<!-- 父组件:.sync 简化事件监听 --> <Child :visible.sync="isShow" /> <!-- 等价于 <Child :visible="isShow" @update:visible="isShow = $event" /> --> <!-- 子组件:触发 update:prop 事件 --> <script> methods: { close() { this.$emit('update:visible', false) } } </script>

---

三、跨组件通信:选对工具不“滥用”

1. 小型项目用事件总线(EventBus)

适用场景:非父子组件(如兄弟组件、祖孙组件)简单通信。

javascript

// 1. 创建事件总线(main.js) Vue.prototype.$bus = new Vue() // 2. 发送组件 this.$bus.$emit('user-login', { name: '小明' }) // 3. 接收组件(需在 beforeDestroy 解绑) created() { this.$bus.$on('user-login', (user) => { this.currentUser = user }) }, beforeDestroy() { this.$bus.$off('user-login') // 防止内存泄漏 }

2. 中大型项目用 Vuex/Pinia

核心优势:集中管理状态,避免事件总线“事件满天飞”难以维护。

javascript

// Vuex 示例:购物车数据共享 // store/index.js state: { cart: [] }, mutations: { addToCart(state, goods) { state.cart.push(goods) } } // 组件中调用 this.$store.commit('addToCart', { id: 1, name: '商品

3. 祖孙组件用 provide/inject

适用场景:深层嵌套组件(如爷爷→孙子)传递数据,避免 props 层层透传。

vue

<!-- 祖先组件 provide 数据 --> <script> export default { provide() { return { theme: 'dark' } } } </script> <!-- 后代组件 inject 接收 --> <script> export default { inject: ['theme'], // 直接使用 this.theme mounted() { console.log(this.theme) // 'dark' } } </script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1155796.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

机器人系统ros2期末速通2

6. Action&#xff08;动作&#xff09;&#xff1a;带反馈、可取消的长任务6.1 核心概念&#xff08;先搞懂是什么&#xff09;Action 是 ROS2 里专门处理耗时久、需要中间反馈、还能随时取消的任务的通信方式。专业名词拆解&#xff1a;Goal&#xff08;目标&#xff09;&…

拼多多春节加班费热议背后,近屿智能给出了另一份高薪答案

春节临近&#xff0c;你是否也正陷入“年后再说”的循环&#xff1f;当大多数人在为年终琐事分心时&#xff0c;有一群人&#xff0c;却在默默积累着“节后爆发”的资本——他们关注的不是加班补贴&#xff0c;而是如何让自己的技能&#xff0c;配得上更高的估值。一、高薪加班…

[特殊字符][特殊字符][特殊字符][特殊字符],拍一拍解锁快乐开挂版

拍了拍我的小肚子 &#x1f437;肥肉退退退₋₉₉₉拍了拍我的摸鱼手 &#x1f41f;带薪快乐10086拍了拍我的奶茶杯 &#x1f964;吨吨吨喝不胖✨拍了拍我的钱包 &#x1f911;空空如也但暴富在路上拍了拍我的闹钟 ⏰迟到不存在∞拍了拍我的老板说&#xff1a;放假啦快冲&#…

智能地板:AI Agent的室内活动模式分析

智能地板&#xff1a;AI Agent的室内活动模式分析关键词&#xff1a;智能地板、AI Agent、室内活动模式、数据分析、行为识别摘要&#xff1a;本文围绕智能地板与AI Agent的室内活动模式分析展开。详细介绍了智能地板的技术原理、AI Agent的工作机制&#xff0c;探讨了如何通过…

机器人系统ros2期末速通4

一、16. 调试工具链&#xff08;CLI rqt RViz2&#xff09;1. 核心概念&#xff08;系统里的实际样子&#xff09;CLI&#xff08;命令行工具&#xff09;&#xff1a;你在终端敲的 ROS 指令&#xff0c;是调试的 “基础武器”&#xff0c;比如查话题、查节点、查 TF 都靠它。…

夫妻间忌讳的9句话,烂在肚子也不要说

俗话说&#xff1a;百年修得同船渡&#xff0c;千年修得共枕眠。夫妻聊天别瞎聊&#xff0c;这9句话堪比“婚姻炸弹”&#xff0c;说了容易引发家庭“地震”&#xff0c;快烂在肚子里&#xff01;你这脑子&#xff0c;跟没带出门似的吧&#xff1f;就你这水平&#xff0c;还不如…

2026 版 “全国统一长辈口头禅”,听完 DNA 动了

少吃点外卖&#x1f961;&#xff0c;全是科技与狠活天天熬夜&#x1f319;&#xff0c;身体迟早熬垮穿这么少&#xff1f;不冷吗&#xff1f;赶紧加衣服&#x1f9e5;别老点奶茶&#x1f964;&#xff0c;又贵又不健康工资发了多少&#xff1f;存下来多少呀&#x1f4b0;处对象…

机器人系统ros2期末速通3

一、11. Composition&#xff08;组件化节点&#xff09;1. 核心概念&#xff08;先懂 “人话”&#xff09;进程&#xff1a;可以理解为 “一个独立的程序窗口”&#xff0c;比如你开的微信是一个进程&#xff0c;浏览器是另一个进程。组件化&#xff1a;把原本要开多个 “程序…

idea查看当前的数据源信息

项目使用的DS动态数据源方式一&#xff1a;1. 获取当前线程的数据源信息DynamicDataSourceContextHolder.peek() 方法可以用来获取当前线程正在使用的数据源名称。2.动态数据源切换如果需要在调试过程中切换数据源&#xff0c;可以使用以下代码&#xff1a;DynamicDataSourceCo…

PySide step by step系列

根据学习进度更新。 PySide基础 PySide系列-01-入门简介 PySide系列-02-信号与槽机制 PySide系列-03-QPushButton、QMessageBox

各位相加这道题,真不简单:从“循环暴力”到“数学直觉”的一次觉醒

各位相加这道题,真不简单:从“循环暴力”到“数学直觉”的一次觉醒 大家好,我是 Echo_Wish。 今天咱聊一道很多人第一眼会觉得—— “这不就是个新手题吗?” 对,就是 LeetCode 上的「各位相加(Add Digits)」。 题目短得不行,实现起来更是分分钟,但我一直觉得: 这道…

GRANT SELECT, DELETE ON 职工 TO USER1 WITH GRANT OPTION权限授予命令详解

一、语句结构分解 GRANT SELECT, DELETE ON 职工 TO USER1 WITH GRANT OPTION;各部分含义&#xff1a;部分含义GRANT授权命令关键字SELECT, DELETE授予的权限类型ON 职工权限作用的对象&#xff08;职工表&#xff09;TO USER1权限授予的用户WITH GRANT OPTION特殊权限选项 二、…

cocos 金色划过shader教程

视频教程 视频教程 vec4 o texture(cc_spriteTexture,uv);有图片获取图片 现在是用在label 获取字 透明部分不会获取 float beamPos mod(cc_time.x -0.3, 3.0) ; 设定圆心位置 将光柱想象成圆形 获取圆心位置 计算遍历所有像素点到圆心的距离 如果在glow代表圆的范围 如果在范…

简单理解:嵌入式开发中 BFTM、GPTM、MCTM 这三种定时器的含义、区别和应用场景

这三个都是嵌入式芯片&#xff08;尤其是 ARM Cortex-M 系列、国产 MCU 如华大 / 兆易创新等&#xff09;中常见的定时器外设&#xff0c;核心都是 “计时 / 定时”&#xff0c;但设计定位和功能侧重完全不同。一、逐个解析核心概念1. BFTM&#xff1a;基本功能定时器 (Basic F…

中小企业数据安全的“三座大山”,松鼠备份如何用一台旧电脑轻松化解?

对绝大多数中小企业来说&#xff0c;真正的数据危机往往来自三个日常隐患&#xff1a;第一座山&#xff1a;勒索病毒——文件被加密成 .locked&#xff0c;不给赎金就打不开&#xff1b;第二座山&#xff1a;人为误删或覆盖——手一滑&#xff0c;几天甚至几周的工作瞬间消失&a…

采用人工智能技术简化论文写作,7个专业站点提供LaTeX兼容及格式规范指导

工具快速对比排名&#xff08;前7推荐&#xff09; 工具名称 核心功能亮点 处理时间 适配平台 aibiye 学生/编辑双模式降AIGC 1分钟 知网、万方等 aicheck AI痕迹精准弱化查重一体 ~20分钟 知网、格子达、维普 askpaper AIGC率个位数优化 ~20分钟 高校检测规则通…

java学习--ArrayList

一、什么是 ArrayListArrayList 是 java.util 包下的类&#xff0c;实现了 List 接口&#xff0c;本质是动态扩容的数组&#xff08;相比普通数组&#xff0c;它的长度可以自动调整&#xff09;。底层基于数组实现&#xff0c;支持快速随机访问&#xff08;通过索引取值&#x…

借助AI技术高效撰写学术论文,这7个专业网站支持格式规范与LaTeX排版适配功能

工具快速对比排名&#xff08;前7推荐&#xff09; 工具名称 核心功能亮点 处理时间 适配平台 aibiye 学生/编辑双模式降AIGC 1分钟 知网、万方等 aicheck AI痕迹精准弱化查重一体 ~20分钟 知网、格子达、维普 askpaper AIGC率个位数优化 ~20分钟 高校检测规则通…

LLDB:现代化的开源调试器(LLVM Debugger)

LLDB&#xff1a;LLVM Debugger 现代化的开源调试器 LLDB是一个现代化的开源调试器&#xff0c;作为LLVM编译器项目的一部分&#xff0c;它被设计为高性能、可扩展&#xff0c;并且支持多种语言和平台。以下是对LLDB的详细解析&#xff1a; 1. 核心背景 所属项目&#xff1a;L…

51单片机——GPIO、按键、中断、定时器与PWM

目录 一、GPIO 1.1 核心概念 1.2 工作模式分类 1.2.1 输出模式&#xff1a;控制外设 1.2.2 输入模式&#xff1a;检测外设信号 二、独立按键 2.1 硬件连接原理 2.2 核心工作逻辑 2.3 消抖处理 三、中断系统 3.1 中断核心概念 3.2 中断源分类与关键参数 3.3 中断处…