• 工作这么久了,你还没有重构过代码?


    为什么要重构代码

    代码重构是在不改变代码功能的前提下,对现有代码进行改进和优化。这是编程的核心部分之一,不能忽视。重构代码可以增强代码的可读性、可维护性和可扩展性。它的主要目的是提高性能并提高开发人员的能力。

    提取代码

    该方法是将部分代码块转换为单独的函数。这是为了改善代码的结构和可读性。它会将长且复杂的代码块提取到更小且更易于管理的函数中。

    要提取代码,我们首先需要找到执行特定任务的代码块,该任务的执行代码是相对复杂。找到后,我们将代码提取并放置到新函数中。还要确保函数的命名是好理解的。然后,在需要执行任务的地方调用它们。

    例如:

    重构前

    function calculateInvoiceTotal(items) {
    let total = 0;
    for (let i = 0; i < items.length; i++) {
    const item = items[i];
    if (!item.quantity || !item.price) {
    console.error('Invalid item', item);
    continue;
    }
    const itemTotal = item.quantity * item.price;
    total += itemTotal;
    }
    return total;
    }
    

    重构后:

    function calculateInvoiceTotal(items) {
    let total = 0;
    for (let i = 0; i < items.length; i++) {
    const item = items[i];
    const itemTotal = calculateItemTotal(item);
    total += itemTotal;
    }
    return total;
    }
    
    function calculateItemTotal(item) {
    if (!item.quantity || !item.price) {
    console.error('Invalid item', item);
    return 0;
    }
    return item.quantity * item.price;
    }
    

    用字符常量代替number

    例子:
    这样的做法为了提高代码的可维护性和可读性。方便后续接收的程序员更好的理解代码,也方便后续在修改值时,只需要修改常量值就可以需要改多出引用了常量的地方。

    重构前

        if (temperature > 0) {
            //如果温度高于结冰点,我们就会执行一些措施
    

    重构后

        const int FREEZING_POINT = 0;
           //FREEZING_POINT =冰点
           
        if (temperature > FREEZING_POINT) {
           //如果温度高于结冰点,我们就会执行一些措施
        }
    

    合并重复代码

    重复代码或类似的代码可能出现在不同的位置。这些代码可能不是完全相同,但是他们的功能是类似。重复代码可能会导致多种问题,包括增加维护成本、难以对代码进行更改以及引入错误的风险。

    在重构代码时,您必须注意重复代码。找到这样的代码后,处理方法是将这些代码转换为单个可重用的函数/方法。
    例子:

    重构前

        function calculateTotal(numbers) {
          let total = 0;
          for (let i = 0; i < numbers.length; i++) {
            total += numbers[i];
          }
          return total;
        }
    
        function calculateAverage(numbers) {
          let total = 0;
          for (let i = 0; i < numbers.length; i++) {
            total += numbers[i];
          }
          const average = total / numbers.length;
          return average;
        }
    

    重构后

        function calculateSum(numbers) {
          let total = 0;
          for (let i = 0; i < numbers.length; i++) {
            total += numbers[i];
          }
          return total;
        }
    
        function calculateTotal(numbers) {
          return calculateSum(numbers);
        }
    
        function calculateAverage(numbers) {
          const total = calculateSum(numbers);
          const average = total / numbers.length;
          return average;
        }
    

    在上面的代码示例中,我们对总和进行了计算,然后再对平均值进行了计算。在改进后的代码中,我们用一个计算总和的函数代替了它们

    简化函数

    简化函数的目的是简化代码的逻辑或使其更易读、更整洁。它可以帮助你减少代码行数。

    下面是一些常用的简化函数的方法

    • 删除多余的变量和表达式:有些变量或表达式可能只是在调试时才使用的,但是忘记移除,例如在 JavaScript 中使用的 console.log。请将其删除,这样可以缩短代码长度。
    • 使用内置函数:有时,使用JavaScript的内置函数可以更好地完成相同的功能,且代码量更少。
    • 简化条件语句:如果方法具有复杂的条件语句,请考虑通过组合条件或使用三元运算符进行简化。

    优化代码的性能

    使用延迟加载技术是一种常见的优化性能的方法,它只在需要时加载对象。这可以通过减少内存使用量来提高应用程序性能,从而加快应用程序的加载速度。

    这种技术在Web开发中非常流行,特别是在像React这样的JavaScript框架中,可以通过延迟加载导入不同的组件。它还可以用于根据需要加载图像。

    举个例子:
    重构前

        import React from 'react';
        import MyComponent from './MyComponent';
    
        const App = () => {
          return (
            <div>
              <h1>My App</h1>
              <MyComponent />
            </div>
          );
        }
    
        export default App;
    

    重构后:

        import React, { lazy, Suspense } from 'react';
    
        const MyComponent = lazy(() => import('./MyComponent'));
    
        const App = () => {
          return (
            <div>
              <h1>My App</h1>
              <Suspense fallback={<div>Loading...</div>}>
                <MyComponent />
              </Suspense>
            </div>
          );
        }
    
        export default App;
    

    在重构后的代码中,我们使用了lazy函数异步导入了MyComponent组件。这意味着只有在实际需要时才会加载该组件,从而提高了应用程序的整体性能。我们还使用了Suspense组件,在组件加载时显示一个回退UI。

    总结

    重构是任何开发者想要提高代码质量、性能和可维护性的必要步骤。通过花时间分析和优化你的代码,你可以消除冗余、减少复杂性,并创建一个更高效、可扩展的应用程序。

    通过不断地审查和改进你的代码,你可以创建一个更强大和更强健壮性的网站

  • 相关阅读:
    【Django中运行scrapy框架,并将数据存入数据库】
    开放式运动耳机排行榜哪个好用,排行靠前的五款运动耳机分享
    Nginx
    Hazelcast系列(三):hazelcast集成(服务器/客户端)
    Spring Cloud:四 【详细】
    Python | 武理刷题2
    单链表(1)
    git 把master分支代码合并到自己分支(常用git 命令)
    TX12 + ExpressLRS 915MHz RC控制链路配置及问题汇总
    DP之字符串算法
  • 原文地址:https://blog.csdn.net/weixin_45215308/article/details/139757568