封装类与封装函数

目录结构

src/

├── utils/

│ ├── test.js

│ ├── Calculator.js

├── views/

│ ├── Home.vue

├── App.vue

共同点:模块导出与模块引入

封装函数

场景

简单、轻量级和性能敏感的场景,适合快速开发和维护。

  1. 可维护性: 相关的功能和数据集中在一个单元内,使得修改和维护代码更加容易,降低了修改一处代码可能引发的连锁错误风险
  2. 可读性: 封装将复杂的逻辑隐藏在内部,通过清晰的接口提供简洁的使用方式,提高了代码的可读性
  3. **灵活性:**封装可以通过修改内部实现而不影响外部调用,为代码的扩展和修改提供了灵活性。

  1. 缺乏封装性: 函数封装难以将相关的功能和数据组织在一起,代码的模块化程度较低。
  2. 扩展性差: 函数封装的代码在扩展时可能需要大量修改,不如类封装灵活。

实战

javascript 复制代码
// utils-test.js
// 定义一个函数来计算两个数的和
export function addNumbers(a, b) {
    return a + b;
}
javascript 复制代码
//home.vue
<template>
  <h1>调用封装函数,5+3的结果:{{ result }}</h1>
</template>

<script setup>
import { addNumbers } from '引入路径'
import { onMounted, ref } from "vue";

const result =ref(null);
onMounted(() => {
  console.log("组件挂载,开始执行函数");
  result.value=addNumbers(5, 3); //页面输出  调用封装函数,5+3的结果:8
})

</script>

<style></style>

实战效果

封装类:

场景

高度封装、模块化和面向对象编程的场景,适合处理复杂的功能和数据。

  1. 数据隐藏: 封装类可以将类的内部数据成员设为私有,只通过公共方法进行访问和修改,实现数据的隐藏和保护。
  2. 代码组织和复用: 将相关的功能和数据组织在一个类中,便于代码的管理和复用。
  3. 解耦和独立性: 封装类使得类与外部的依赖减少,提高了类的独立性,降低了不同部分代码之间的耦合度。
  4. 接口规范: 封装类通过定义明确的公共接口,规范了外部与类的交互方式。

  1. 复杂性: 学习难度也高**,** 编写过渡抽象**,**代码难以理解和维护。
  2. 过度设计: 可能会导致代码过于复杂冗余,反而降低了可维护性。

实战

javascript 复制代码
// Calculator.js
// 定义一个类来计算两个数的和
class Calculator {
    constructor() {
        // 可以在这里初始化一些属性
    }

    // 定义一个方法来计算两个数的和
    addNumbers(a, b) {
        return a + b;
    }
}
export default Calculator;
javascript 复制代码
//home.vue
<template>
  <h1>调用封装类,5+3的结果:{{ result }}</h1>
</template>

<script setup>
import Calculator from '引入路径'
import { onMounted, ref } from "vue";

const result =ref(null);
onMounted(() => {
  const calculator = new Calculator();
  result.value=calculator.addNumbers(5, 3); //页面输出  调用封装类,5+3的结果:8
})

</script>

<style></style>

实战效果

相关推荐
郝学胜-神的一滴6 分钟前
线程同步:并行世界的秩序守护者
java·linux·开发语言·c++·程序人生
superman超哥7 分钟前
Rust 移动语义(Move Semantics)的工作原理:零成本所有权转移的深度解析
开发语言·后端·rust·工作原理·深度解析·rust移动语义·move semantics
青茶3609 分钟前
【js教程】如何用jq的js方法获取url链接上的参数值?
开发语言·前端·javascript
superman超哥18 分钟前
Rust 所有权转移在函数调用中的表现:编译期保证的零成本抽象
开发语言·后端·rust·函数调用·零成本抽象·rust所有权转移
xiaowu08018 分钟前
C# 把dll分别放在指定的文件夹的方法
开发语言·c#
脩衜者23 分钟前
极其灵活且敏捷的WPF组态控件ConPipe 2026
前端·物联网·ui·wpf
mg66826 分钟前
0基础开发学习python工具_____用 Python + Pygame 打造绚丽烟花秀 轻松上手体验
开发语言·python·学习·pygame
Mike_jia28 分钟前
Dockge:轻量开源的 Docker 编排革命,让容器管理回归优雅
前端
GISer_Jing35 分钟前
前端GEO优化:AI时代的SEO新战场
前端·人工智能
CodeOfCC37 分钟前
C++ 实现ffmpeg解析hls fmp4 EXT-X-DISCONTINUITY并支持定位
开发语言·c++·ffmpeg·音视频