从渲染集合到模块学习

一、调试技巧:console.log的正确使用

  • 重要性 :有经验的程序员比新手更频繁地使用console.log进行调试。新手更需要通过调试来发现问题,而不是盲目猜测。

  • 正确用法 :使用逗号分隔参数,而不是用加号连接字符串和对象。例如:

    javascript 复制代码
    console.log('props value is', props);

    这样可以地清晰查看对象的内容,而不是得到[Object object]

二、Visual Studio Code片段(Snippets)

  • 作用:通过VS Code的片段功能,可以快速生成常用的代码片段,提高开发效率。

  • 示例 :创建一个console.log的片段(如clog),方便快速插入调试代码。

    json 复制代码
    {
      "console.log": {
        "prefix": "clog",
        "body": [
          "console.log('$1')"
        ],
        "description": "Log output to console"
      }
    }

三、JavaScript数组的函数式编程

  • 高阶函数 :如mapfilterreduce等,是函数式编程的核心工具。
  • map函数
    • 用途:对数组中的每个元素执行某种操作,并返回一个新数组。

    • 示例

      javascript 复制代码
      notes const = [
        { id: 1, content: 'HTML is easy' },
        { id: 2, content: 'Browser can execute only JavaScript' },
        { id: 3, content: 'GET and POST are the most important methods of HTTP protocol' }
      ];
      const result = notes.map(note => note.content);
      console.log(result); // 输出:['HTML is easy', 'Browser can execute only JavaScript', 'GET and POST are the most important methods of HTTP protocol']

四、React中的事件处理与集合渲染

(一)事件处理

  • 复习:事件处理是React中的一个重要概念,需要掌握如何将事件处理程序传递给子组件。
  • 资源:如果对事件处理有疑问,可以回顾上一章节的修订内容。

(二)渲染集合

  • 问题 :直接通过硬编码索引渲染数组元素(如notes[0].content)是不实用的。

  • 解决方案 :使用map函数从数组中生成React元素。

    javascript 复制代码
    const App = (props) => {
      const { notes } = props;
      return (
        <div>
          <h1>Notes</h1>
          <ul>
            {notes.map(note => <li>{note.content}</li>)}
          </ul>
        </div>
      );
    };

(三)Key属性

  • 重要性 :React要求列表项(由map生成的元素)必须有一个唯一的key属性。

  • 示例

    javascript 复制代码
    const App = (props) => {
      const { notes } = props;
      return (
        <div>
          <h1>Notes</h1>
          <ul>
            {notes.map(note => <li key={note.id}>{note.content}</li>)}
          </ul>
        </div>
      );
    };

五、模块化开发

(一)模块化的好处

  • 代码组织:将代码分解为独立的模块,便于维护和复用。

  • 示例 :将Note组件分离到单独的文件中(如Note.js),并在需要的地方导入它。

    javascript 复制代码
    // Note.js
    import React from 'react';
    const Note = ({ note }) => <li>{note.content}</li>;
    export default Note;
    
    // App.js
    import Note from './components/Note';
    const App = ({ notes }) => (
      <div>
        <h1>Notes</h1>
        <ul>
          {notes.map(note => <Note key={note.id} note={note} />)}
        </ul>
      </div>
    );

(二)模块化实践

  • 文件结构 :通常将组件放在src/components目录下,文件名与组件名一致。
  • 导入路径 :导入本地模块时,需要指定相对路径,例如import Note from './components/Note';

六、避免使用数组索引作为键

  • 问题 :虽然使用数组索引作为key可以消除警告,但这是一种反模式,可能会导致性能问题或错误。
  • 原因 :React依赖key来跟踪列表项的变化。如果列表项顺序发生变化,使用索引作为key会导致React无法正确识别哪些项被更新。
  • 建议 :尽量使用唯一标识符(如id)作为key

七、应用崩溃时的调试方法

  • 问题:动态语言(如JavaScript)容易因类型错误或逻辑问题导致应用崩溃。
  • 调试技巧
    • 使用console.log逐步检查代码的执行情况。
    • 如果组件是通过解构传递props,尝试去掉解构,直接打印props来查看其内容。
    • 如果问题仍未解决,继续在代码中插入更多的console.log语句,逐步缩小问题范围。
相关推荐
共享ui设计和前端开发人才7 分钟前
UI前端与数字孪生融合案例:智慧城市的智慧停车引导系统
前端·ui·智慧城市
福娃B9 分钟前
【React】React初体验--手把手教你写一个自己的React初始项目
前端·javascript·react.js
逆向APP9 分钟前
SwiftUI Bug记录:.sheet首次点击弹出空白视图,第二次才正常显示
前端
Yodame11 分钟前
webpack+vite前端构建工具全掌握(中篇)
前端
迪迪SAMA11 分钟前
不再死记硬背!帮你理解原型相关八股概念!
前端
用户15129054522012 分钟前
jQuery-ui源代码重点难点分析
前端
逆向APP15 分钟前
siwftui代码,.sheet不能跳转
前端
24kHT17 分钟前
2.3 前端-ts的接口以及自定义类型
java·开发语言·前端
追光的栗子17 分钟前
vue3+vite 项目中怎么引入 elementplus 组件库
前端·vue.js·element
我命由我1234524 分钟前
VSCode - VSCode 快速跳转标签页
开发语言·前端·ide·vscode·编辑器·html·js