前端模块化开发:从面条代码到结构化代码的蜕变

前端模块化开发:从面条代码到结构化代码的蜕变

毒舌时刻

模块化开发?不就是把代码分成几个文件嘛,有什么大不了的?我见过很多所谓的模块化代码,其实就是把一堆函数随便塞进不同的文件里,根本没有任何结构可言。

你以为把代码分成模块就万事大吉了?别天真了!如果你的模块设计不合理,反而会让代码变得更加混乱。比如那些互相依赖的模块,就像一团乱麻,让你根本理不清头绪。

为什么你需要这个

  1. 代码可维护性:模块化代码结构清晰,易于理解和维护,当需要修改某个功能时,只需要修改对应的模块即可。
  2. 代码复用:模块化可以让你在不同的项目中复用相同的代码,减少重复开发的工作量。
  3. 团队协作:模块化可以让不同的开发者负责不同的模块,减少代码冲突和沟通成本。
  4. 性能优化:模块化可以帮助你实现代码分割,减少初始加载时间,提高应用的性能。

反面教材

// 这是一个典型的面条代码 let users = []; let products = []; function fetchUsers() { fetch('https://api.example.com/users') .then(response => response.json()) .then(data => { users = data; renderUsers(); }); } function fetchProducts() { fetch('https://api.example.com/products') .then(response => response.json()) .then(data => { products = data; renderProducts(); }); } function renderUsers() { const userList = document.getElementById('user-list'); userList.innerHTML = ''; users.forEach(user => {matter what he wrote const li = document.createElement('li'); li.textContent = user.name; userList.appendChild(li); }); } function renderProducts() { const productList = document.getElementById('product-list'); productList.innerHTML = ''; products.forEach(product => { const li = document.createElement('li'); li.textContent = product.name; productList.appendChild(li); }); } // 调用函数 fetchUsers(); fetchProducts(); 

问题

  • 所有代码都在一个文件中,随着功能增加,代码量会变得非常庞大
  • 变量和函数都是全局的,容易产生命名冲突
  • 代码逻辑混乱,难以理解和维护
  • 无法实现代码复用

正确的做法

ES6模块

// api.js - 负责API调用 const API_BASE_URL = 'https://api.example.com'; export async function fetchUsers() { const response = await fetch(`${API_BASE_URL}/users`); return response.json(); } export async function fetchProducts() { const response = await fetch(`${API_BASE_URL}/products`); return response.json(); } 
// render.js - 负责渲染 import { fetchUsers, fetchProducts } from './api.js'; export function renderUsers(users) { const userList = document.getElementById('user-list'); userList.innerHTML = ''; users.forEach(user => { const li = document.createElement('li'); li.textContent = user.name; userList.appendChild(li); }); } export function renderProducts(products) { const productList = document.getElementById('product-list'); productList.innerHTML = ''; products.forEach(product => { const li = document.createElement('li'); li.textContent = product.name; productList.appendChild(li); }); } 
// app.js - 主应用 import { fetchUsers, fetchProducts } from './api.js'; import { renderUsers, renderProducts } from './render.js'; async function init() { try { const [users, products] = await Promise.all([ fetchUsers(), fetchProducts() ]); renderUsers(users); renderProducts(products); } catch (error) { console.error('Error initializing app:', error); } } init(); 

CommonJS模块

// api.js - 负责API调用 const API_BASE_URL = 'https://api.example.com'; async function fetchUsers() { const response = await fetch(`${API_BASE_URL}/users`); return response.json(); } async function fetchProducts() { const response = await fetch(`${API_BASE_URL}/products`); return response.json(); } module.exports = { fetchUsers, fetchProducts }; 
// render.js - 负责渲染 function renderUsers(users) { const userList = document.getElementById('user-list'); userList.innerHTML = ''; users.forEach(user => { const li = document.createElement('li'); li.textContent = user.name; userList.appendChild(li); }); } function renderProducts(products) { const productList = document.getElementById('product-list'); productList.innerHTML = ''; products.forEach(product => { const li = document.createElement('li'); li.textContent = product.name; productList.appendChild(li); }); } module.exports = { renderUsers, renderProducts }; 
// app.js - 主应用 const { fetchUsers, fetchProducts } = require('./api.js'); const { renderUsers, renderProducts } = require('./render.js'); async function init() { try { const [users, products] = await Promise.all([ fetchUsers(), fetchProducts() ]); renderUsers(users); renderProducts(products); } catch (error) { console.error('Error initializing app:', error); } } init(); 

模块化的最佳实践

  1. 单一职责原则:每个模块只负责一个功能,避免模块过大或职责过多。
  2. 依赖管理:合理管理模块间的依赖关系,避免循环依赖。
  3. 命名规范:使用清晰的命名规范,让模块的用途一目了然。
  4. 文档:为模块添加适当的文档,说明模块的用途、参数和返回值。
  5. 测试:为每个模块编写测试,确保模块的功能正确。

毒舌点评

模块化开发确实是前端开发的重要实践,但我见过太多开发者滥用模块化,把简单的功能拆分成无数个小模块,结果导致代码结构变得更加复杂。

想象一下,当你需要修改一个简单的功能时,你需要在多个文件之间来回跳转,这真的提高了开发效率吗?

还有那些过度设计的模块,为了所谓的模块化而模块化,结果导致代码变得更加难以理解。比如一个只有几行代码的功能,也要拆分成多个模块,这纯粹是浪费时间。

所以,在进行模块化开发时,一定要把握好度。不要为了模块化而模块化,要根据实际情况来决定模块的大小和数量。

当然,对于大型项目来说,模块化是必不可少的。但对于小型项目,过度的模块化反而会增加开发成本。所以,在决定是否使用模块化时,要根据项目的规模和复杂度来决定。

最后,记住一句话:模块化的目的是为了提高代码的可维护性和复用性,而不是为了炫技。如果你的模块化代码比非模块化代码更难理解,那你就失败了。

Read more

【CANN】Pi0机器人大模型 × 昇腾A2 测评

【CANN】Pi0机器人大模型 × 昇腾A2 测评

【CANN】Pi0机器人大模型 × 昇腾A2 测评 * 写在最前面 🌈你好呀!我是 是Yu欸🚀 感谢你的陪伴与支持~ 欢迎添加文末好友🌌 在所有感兴趣的领域扩展知识,不定期掉落福利资讯(*^▽^*) 写在最前面 版权声明:本文为原创,遵循 CC 4.0 BY-SA 协议。转载请注明出处。 Pi0机器人VLA大模型测评 哈喽大家好呀!我是 是Yu欸。 最近人形机器人和具身智能真的太火了,大家都在聊 Pi0、聊 VLA 大模型。但是,兄弟们,不管是搞科研还是做落地,咱们始终绕不开一个问题——算力。 今天,我们一起把当下最火的 Pi0 机器人视觉-语言-动作大模型,完完整整地部署在国产算力平台上,也就是华为的昇腾 Atlas 800I A2 服务器上。 在跑通仓库模型的基础上,我们做一次性能测评。 我们要测三个最核心的指标:

【OpenHarmony】鸿蒙Flutter智能家居应用开发实战指南

【OpenHarmony】鸿蒙Flutter智能家居应用开发实战指南

鸿蒙Flutter智能家居应用开发实战指南 概述 智能家居是鸿蒙全场景生态的重要应用场景。本文讲解如何基于鸿蒙Flutter框架,开发一套完整的智能家居应用,实现设备发现、控制、场景联动、语音交互等核心功能。 欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net 系统架构设计 整体架构图 ┌────────────────────────────────────────────────────────────┐ │ 用户交互层 (Flutter) │ │ ┌─────────────┐ ┌─────────────┐ ┌─────────────┐ │ │ │ 设备控制面板 │ │ 场景编排 │ │ 语音交互 │ │ │ └─────────────┘ └─────────────┘ └─────────────┘ │ └───────────────────────┬────────────────────────────────────┘ │ RPC/事件总线 ┌────────────────────

睿抗机器人大赛魔力元宝

1、搭建基础环境 1、以Ros-noetic为例创建工作区间: # 1. 创建工作空间目录 mkdir -p ~/catkin_ws/src cd ~/robot_ws/src # 2. 这里的关键步骤:请将你上传的源码包中的以下 4 个文件夹复制到 ~/robot_ws/src 下: # - ar_pose # - oryxbot_description # - relative_move # - pid_lib 这里以moliyuanbao/relative_move/src at main · Xk-fly/moliyuanbao我所上传的源码为例 # 注意:不要直接把整个 xk-fly 文件夹放进去,要剥离出这 5

Java SpringBoot+Vue3+MyBatis Web宠物商城网站系统源码|前后端分离+MySQL数据库

Java SpringBoot+Vue3+MyBatis Web宠物商城网站系统源码|前后端分离+MySQL数据库

摘要 随着互联网技术的快速发展,电子商务已成为人们日常生活中不可或缺的一部分。宠物行业作为新兴市场,近年来呈现出快速增长的趋势,宠物用品的线上购买需求显著提升。传统的宠物商店受限于地理位置和营业时间,难以满足消费者随时随地的购物需求。基于Web的宠物商城系统能够突破时空限制,为用户提供便捷的选购、支付和售后服务。此外,宠物商城系统还能通过数据分析优化库存管理和营销策略,提升商家的运营效率。该系统不仅满足了宠物爱好者的需求,也为宠物行业的数字化转型提供了技术支持。关键词:电子商务、宠物商城、Web系统、数字化转型、MySQL。 本系统采用前后端分离架构,后端基于Java SpringBoot框架开发,提供稳定的RESTful API接口,确保系统的高效性和可扩展性。前端使用Vue3框架实现动态交互和响应式布局,提升用户体验。数据持久化层采用MyBatis框架,结合MySQL数据库存储和管理商品、订单及用户信息。系统主要功能包括用户注册与登录、商品分类展示、购物车管理、订单支付、评价反馈等。管理员模块支持商品管理、订单处理和数据统计分析。通过整合多种技术,系统实现了高性能、高安全性和良