No104.精选前端面试题,享受每天的挑战和学习(小米)

news2024/11/6 7:34:48

在这里插入图片描述

文章目录

    • 聊一下vue和react的区别
    • react生命周期有哪些
    • hooks解决了什么问题
    • 小程序跳转传参怎么传
    • 附录:「简历必备」前后端实战项目(推荐:⭐️⭐️⭐️⭐️⭐️)

📈「作者简介」:前端开发工程师 | 蓝桥云课签约作者 | 技术日更博主 | 已过四六级
📚「个人主页」:阿珊和她的猫
🕐「简历必备」前后端实战项目(推荐:⭐️⭐️⭐️⭐️⭐️)

  • Vue.js 和 Egg.js 开发企业级健康管理项目
  • 带你从入门到实战全面掌握 uni-app

聊一下vue和react的区别

下面是一个简单的表格,对比Vue和React的一些主要区别:

VueReact
生态系统完整的生态系统,带有官方维护的路由器和状态管理库快速增长的生态系统,丰富的第三方库支持
学习曲线相对较低的学习曲线,易于上手和理解相对较高的学习曲线,需要更多的时间和精力来掌握
组件化开发单文件组件(SFC)结构,模板、逻辑和样式都在同一文件中分离的JSX语法,组件逻辑和样式可以在不同文件中
数据绑定双向数据绑定,可以实时响应数据的变化单向数据流,通过Props和State管理数据的传递和更新
事务处理和更新通过Vue的响应式系统自动进行事务处理和更新通过虚拟DOM进行高效的批量更新和渲染
社区支持和发展大型且活跃的社区,持续的更新和改进也有庞大的社区,但React的开发公司(Facebook)提供强大的支持。
移动开发支持原生的移动端支持,有Vue Native和Weex等框架React Native提供跨平台移动开发支持

需要注意的是,这些区别只是表面上的差异,并不代表Vue或React的优劣。选择使用哪个框架取决于个人或项目的需求,以及开发团队的技术背景和偏好。

react生命周期有哪些

React 16之前的版本,组件生命周期分为三个阶段:挂载阶段、更新阶段和卸载阶段
每个阶段都有对应的生命周期方法,用于在特定的时刻执行特定的操作。

在React 16及之后的版本,生命周期方法已经有了一些变化,被分为挂载、更新、错误处理和卸载等四个阶段。
下面是React组件的生命周期方法列表:

挂载阶段:

  1. constructor:组件被创建时调用,用于初始化状态和绑定事件处理程序。

  2. static getDerivedStateFromProps:在组件创建和更新过程中调用,用于从props中派生一些新的状态。

  3. render:根据当前的props和state,渲染组件的UI。

  4. componentDidMount:组件已经被渲染到DOM中后调用,适合执行依赖DOM的初始化操作。

更新阶段:

  1. static getDerivedStateFromProps:在更新过程中调用,用于从props中派生一些新的状态。

  2. shouldComponentUpdate:在更新之前调用,用于控制组件是否进行更新。

  3. render:根据当前的props和state,重新渲染组件的UI。

  4. getSnapshotBeforeUpdate:在render之后、更新DOM之前调用,用于获取更新前的DOM状态。

  5. componentDidUpdate:组件完成更新后调用,适合执行DOM操作或发起网络请求等更新相关的操作。

错误处理:

  1. static getDerivedStateFromError:在子组件发生错误时调用,用于在错误边界中优雅地处理错误。

  2. componentDidCatch:在子组件发生错误后调用,用于捕获和记录错误信息。

卸载阶段:

  1. componentWillUnmount:组件即将被卸载或销毁时调用,适合执行一些清理工作,如取消定时器、取消订阅等。

以上是React 16之前和16及之后的版本中常见的生命周期方法。但需要注意的是,在React 17后,一些生命周期方法已被标记为过时,建议使用新的替代方法或钩子函数,如使用新的effect钩子函数来替代componentDidMount和componentDidUpdate。

hooks解决了什么问题

Hooks 是 React 16.8 版本引入的特性,它旨在解决 React 中以下几个常见问题:

  1. 组件之间逻辑复用的问题: 在 React 之前,为了在组件之间共享逻辑,开发者需要使用高阶组件(Higher-Order Components)或 Render Props 等模式。这导致了组件层级的嵌套和复杂性增加。Hooks 通过提供可复用的状态逻辑和副作用逻辑(例如:处理订阅、定时器等)的方式,使逻辑复用更加简单和直接。

  2. 在组件之间难以复用状态逻辑的问题: 在 React 中,状态逻辑通常是与组件绑定的,而不是与具体的视图层级绑定。这导致了在组件之间复用和共享状态逻辑变得困难和容易出错。Hooks 提供了可以在组件之间复用状态逻辑的方式,例如使用 useState 钩子函数,从而使状态逻辑更加直接、简化和可复用。

  3. 复杂组件变得难以理解和维护的问题: 当业务逻辑复杂时,组件的生命周期函数会变得庞大而难以理解和维护。Hooks 的引入使得组件的生命周期被逻辑相关的片段所替代,提供了更清晰简洁的代码结构,使得组件的逻辑更易于理解和维护。

  4. 类组件带来的学习曲线和抽象度的问题: 使用类组件需要理解和掌握类的概念和语法,对于初学者来说可能增加了学习曲线和理解难度。而且使用类组件时需要注意 this 的指向等问题。Hooks 提供了以函数形式编写组件的选项,使得学习曲线降低,代码更加简洁。

总体而言,Hooks 使得在 React 中编写组件更简单、直观和灵活,解决了组件之间逻辑复用、状态复用、组件维护性和类组件的学习曲线等问题,提供了更好的开发体验。

小程序跳转传参怎么传

在小程序中,可以通过以下几种方式实现跳转页面并传递参数:

  1. URL参数传递: 在跳转链接的URL中携带参数。在原页面中使用wx.navigateTowx.redirectTo方法跳转到目标页面时,可以在URL中添加参数。目标页面可以通过options.query获取到参数值。例如:

    // 原页面跳转到目标页面并传递参数
    wx.navigateTo({
      url: '/pages/target/target?param1=value1&param2=value2'
    });
    

    在目标页面的onLoad生命周期函数中,可以通过options.query来获取参数:

    onLoad: function(options) {
      const param1 = options.query.param1;
      const param2 = options.query.param2;
      // 使用参数进行相关操作
    }
    
  2. 全局数据传递: 在原页面中使用getApp().globalData或全局单例模式来设置全局数据,在目标页面中可以直接访问该全局数据。例如:

    // 原页面设置全局数据
    getApp().globalData.param1 = value1;
    getApp().globalData.param2 = value2;
    
    // 目标页面直接访问全局数据
    const param1 = getApp().globalData.param1;
    const param2 = getApp().globalData.param2;
    // 使用参数进行相关操作
    

    需要注意的是,全局数据是共享的,可能会影响整个小程序的状态,谨慎使用。

  3. Storage存储传递: 使用wx.setStorageSync方法在原页面存储参数,在目标页面中使用wx.getStorageSync来获取参数值。例如:

    // 原页面存储参数
    wx.setStorageSync('param1', value1);
    wx.setStorageSync('param2', value2);
    
    // 目标页面获取参数
    const param1 = wx.getStorageSync('param1');
    const param2 = wx.getStorageSync('param2');
    // 使用参数进行相关操作
    

    需要注意的是,Storage的数据存储在本地,需要手动清除或更新。

以上是几种常见的小程序跳转页面传递参数的方式。选用哪种方式取决于具体的需求和场景。

附录:「简历必备」前后端实战项目(推荐:⭐️⭐️⭐️⭐️⭐️)

Vue.js 和 Egg.js 开发企业级健康管理项目
带你从入门到实战全面掌握 uni-app

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/807295.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

CenOS设置启动级别

背景知识 init一共分为7个级别,这7个级别的所代表的含义如下 0:停机或者关机(千万不能将initdefault设置为0)1:单用户模式,只root用户进行维护2:多用户模式,不能使用NFS(Net File S…

Banana Pi BPI-CM4 评测(计算模块 4),更快性能,旨在替换树莓派CM4

如果您正在寻找可靠的单板计算机来提升您的下一个项目,但无法找到满足您需求的 Raspberry Pi,请看看我是否可以提供帮助。在这篇详细的评论中,我将向您介绍 Banana Pi CM4,这是一款适用于各种任务的多功能且强大的解决方案。从经验…

Blazor前后端框架Known-V1.2.8

V1.2.8 Known是基于C#和Blazor开发的前后端分离快速开发框架,开箱即用,跨平台,一处代码,多处运行。 Gitee: https://gitee.com/known/KnownGithub:https://github.com/known/Known 概述 基于C#和Blazor…

太强了~ 这份《23 种设计模式加强版》宝典,阿里 P8 都得细细研究

说在前面的话 Java 作为老牌纯正的编程语言,在规范性上有着天然优势。因此本版的设计模式讲解全部用 Java 语言来描述,并针对 Java 语言的特性对讲解内容做了相当大的改动。 不知道大家是否听过编程界的一段话:掌握设计模式相当于华山派的&…

信号和槽函数的扩展

信号和槽函数的扩展 一个信号连接多个槽函数一个槽函数连接多个信号信号连接信号 一个信号可以连接多个槽函数, 发送一个信号有多个处理动作 需要写多个connect()连接槽函数的执行顺序和信号的发射顺序相同(QT5中)信号的接收者可…

C#实现读写CSV文件的方法详解

目录 CSV文件标准 文件示例RFC 4180简化标准读写CSV文件 使用CsvHelper使用自定义方法总结 项目中经常遇到CSV文件的读写需求,其中的难点主要是CSV文件的解析。本文会介绍CsvHelper、TextFieldParser、正则表达式三种解析CSV文件的方法,顺带也会介绍一…

SpringBoot中MongoDB的使用

SpringBoot中MongoDB的使用 MongoDB 是最早热门非关系数据库的之一,使用也比较普遍,一般会用做离线数据分析来使用,放到内网的居 多。由于很多公司使用了云服务,服务器默认都开放了外网地址,导致前一阵子大批 MongoD…

骨传导耳机是什么?为什么不用塞到耳朵里?

骨传导耳机其实就跟它的名字一样,用骨传导声音的耳机,整个声音传导过程都是开放双耳的,不接触耳膜,佩戴非常舒适的耳机。 为什么不需要塞进耳朵里,首先咱们要先知道骨传导的原理: 如上图所示,骨…

【Linux命令200例】less强大的文件内容查看工具

🏆作者简介,黑夜开发者,全栈领域新星创作者✌,2023年6月csdn上海赛道top4。 🏆本文已收录于专栏:Linux命令大全。 🏆本专栏我们会通过具体的系统的命令讲解加上鲜活的实操案例对各个命令进行深入…

项目实战 — 消息队列(1) {需求分析}

一、什么是消息队列 消息队列(Message Queue ,MQ),就是将阻塞队列的数据结构,提取成了一个程序,独立进行部署。也就是实现一个生产者消费模型。 有关生产者消费者模型,参考多线程 — 阻塞队列_多线程阻塞…

redis基本架构:一个键值数据库包含什么?(这篇文章主要是一个引导的作用)

我们设计一个简单的smpliekv数据库,来体验简直数据库包含什么 体来说,一个键值数据库包括了访问框架、索引模块、操作模块和存储模块四部分(见 下图)。接下来,我们就从这四个部分入手,继续构建我们的 Simpl…

【MyBatis】MyBatis 3.5+版本报错合集(持续更新)

报错:BindingException 1. org.apache.ibatis.binding.BindingException: Type interface xxx is not known to the MapperRegistry. 2. org.apache.ibatis.binding.BindingException: Invalid bound statement (not found): xxx 解决方案 在pom.xml中添加如下代码…

NetApp FAS控制器的启动过程详解

了解NetApp FAS存储系统的控制器启动过程对于控制器故障的诊断分析非常重要,最近在给几个小朋友培训NetApp,顺便把这个启动过程总结了一下,分享给大家,遇到控制器故障,就可以照方抓药了,如果还是搞不懂&…

自学网络安全(黑客)的注意事项

自学网络安全是一项重要而复杂的任务,以下是一些注意事项: 确定学习目标:网络安全是一个广泛的领域,包括密码学、网络防御、漏洞利用等多个方面。在自学之前,确定你感兴趣的领域,并设定明确的学习目标。 寻…

自动化测试如何管理测试数据

前段时间,知识星球里有同学问到:自动化case越多,测试数据越多,数据的管理成本也越来越高,是否需要一个数据池来专门管理测试数据?这是一个好问题,也是很多测试同学在自动化测试实践中必须面对的…

RWEQ模型土壤风蚀模拟与风蚀模数估算、数据支持、参量提取、归因分析、相关SCI论文撰写技巧

目录 专题一 理论基础 专题二 平台基础 专题三 RWEQ模型数据支持 专题四 RWEQ模型参量提取 专题五 归因分析 专题六 RWEQ模型相关的SCI论文撰写技巧 结合案例讲解RWEQ模型的运行及相关的归因分析,从原理、数据、方法、归因分析方面对土壤风蚀情况进行实战讲解…

绝不多花一分钱,IT老兵的云上省钱之旅

相信很多网友感觉今年的日子不好过,各方面都在缩减支出,尤其是部分IT设备还在不断涨价,像今年的英伟达的40系桌面级显卡和A/H系列的商用显卡,动辙价格跳涨30%,让广大开发者苦不堪言。所幸在省钱方面,笔者有…

【c++底层结构】AVL树红黑树

【c底层结构】AVL树&红黑树 1.AVL树1.1 AVL树的概念1.2 AVL树结点的定义1.3 AVL树的插入1.4 AVL树的旋转1.5 AVL树的验证1.6 AVL树的性能 2. 红黑树2.1 红黑树的概念2.2 红黑树的性质2.3 红黑树节点的定义2.4 红黑树的插入操作2.5 红黑树的验证2.6 红黑树与AVL树的比较2.7 …

linux之iptables的理解与使用

1. 前言 iptables是一个用于Linux操作系统的防火墙软件,它可以对网络流量进行过滤、修改和重定向,从而控制网络通信。iptables是Linux内核中的一个子系统,它可以通过在命令行输入规则来配置网络防火墙。iptables可以对入站和出站的流量进行控…

初识mysql数据库之事务的隔离性

目录 一、理解隔离性 二、隔离级别 1. 不同的隔离级别的简单概述 2. 查看隔离级别 2.1 查看全局隔离级别 2.2 查看会话隔离级别 3. 设置隔离界别 4. 读未提交(Read Uncommitted) 4.1 读未提交测试 5. 读提交(Read Committed&#x…