news 2026/3/21 14:16:11

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

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
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>

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/15 10:22:11

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 中断处…

作者头像 李华
网站建设 2026/3/19 13:17:17

论文初稿难产?10款AI工具助你高效降重与生成,大幅提升写作效率

&#xfffd;&#xfffd; AI工具性能速览表 工具名称 核心功能 处理时间 AI生成率控制 适配检测平台 askpaper 降AIGC率降重同步 20分钟 个位数 知网/格子达/维普 秒篇 AI痕迹深度弱化 20分钟 个位数 知网/格子达/维普 aicheck 全学科初稿生成 20-30分钟 低…

作者头像 李华
网站建设 2026/3/17 10:52:38

【开题答辩全过程】以 基于springbootvue图书馆选座系统设计与实现为例,包含答辩的问题和答案

个人简介 一名14年经验的资深毕设内行人&#xff0c;语言擅长Java、php、微信小程序、Python、Golang、安卓Android等 开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。 感谢大家…

作者头像 李华
网站建设 2026/3/13 7:47:58

子数列求积【牛客tracker 每日一题】

子数列求积 时间限制&#xff1a;1秒 空间限制&#xff1a;256M 网页链接 牛客tracker 牛客tracker & 每日一题&#xff0c;完成每日打卡&#xff0c;即可获得牛币。获得相应数量的牛币&#xff0c;能在【牛币兑换中心】&#xff0c;换取相应奖品&#xff01;助力每日有…

作者头像 李华
网站建设 2026/3/17 0:30:42

Java性能优化实战技术文章大纲性能优化的基本原则

Java性能优化实战技术文章大纲性能优化的基本原则理解性能优化的核心目标&#xff1a;减少资源消耗、提高响应速度、增强系统稳定性 避免过度优化&#xff0c;基于实际业务场景和数据驱动决策 采用可量化的指标评估优化效果&#xff08;如TPS、RT、GC频率等&#xff09;JVM层优…

作者头像 李华
网站建设 2026/3/16 21:14:39

预装智能办公软件,打造企业专属数字工作台

数据成为新生产要素&#xff0c;算法成为新生产力&#xff0c;这场由技术驱动的深层经济逻辑变革&#xff0c;影响着这个时代的每一个人&#xff0c;迫使每一个组织重新审视自己的价值链条与核心竞争力。每个企业需要深化技术与业务流程的结合应用&#xff0c;如何在保障数据主…

作者头像 李华