当前位置: 首页 > news >正文

新整理的前端面试题

pinia和vuex的区别

(1)pinia它没有mutation,他只有state,getters,action【同步、异步】使用他来修改state数据

(2)pinia他默认也是存入内存中,如果需要使用本地存储,在配置上比vuex麻烦一点

(3)pinia语法上比vuex更容易理解和使用,灵活。

(4)pinia没有modules配置,没一个独立的仓库都是definStore生成出来的

(5)pinia state是一个对象返回一个对象和组件的data是一样的语法

Vuex 和 Pinia 的优缺点

Pinia的优点

完整的 TypeScript 支持:与在 Vuex 中添加 TypeScript 相比,添加 TypeScript 更容易

极其轻巧(体积约 1KB)

store 的 action 被调度为常规的函数调用,而不是使用 dispatch 方法或 MapAction 辅助函数,这在 Vuex 中很常见

支持多个Store

支持 Vue devtools、SSR 和 webpack 代码拆分

Pinia的缺点

不支持时间旅行和编辑等调试功能

Vuex的优点

支持调试功能,如时间旅行和编辑

适用于大型、高复杂度的Vue.js项目

Vuex的缺点

从 Vue 3 开始,getter 的结果不会像计算属性那样缓存

Vuex 4有一些与类型安全相关的问题

何时使用Pinia,何时使用Vuex

个人感觉:,由于Pinea是轻量级的,体积很小,它适合于中小型应用。它也适用于低复杂度的Vue.js项目,因为一些调试功能,如时间旅行和编辑仍然不被支持。

将 Vuex 用于中小型 Vue.js 项目是过度的,因为它重量级的,对性能降低有很大影响。因此,Vuex 适用于大规模、高复杂度的 Vue.js 项目。

pinia和vuex在vue2和vue3都可以使用,一般来说vue2使用vuex,vue3使用pinia。

vue、小程序、uniapp优缺点

vue

优点

组件化开发,提升效率,方便复用,便于协同开发

单页面路由

双向数据绑定

易于结合其他的第三方库

丰富的api方法

轻量高效

MVVM,数据驱动视图

轻量级的框架

渐进式

缺点

缺少高阶教程和文档

生态环境不如angular和react

社区不大

不支持ES5的浏览器无法使用,如ie8

vue的响应系统无法检测属性的添加和删除,以及某些数组的修改

报错不明显,适合单人开发或者中小型项目

不利于SEO优化

小程序

优点

开发门槛低,难度比app小

克服了不同系统、不同手机版本的不兼容性

自带推广,如附近的小程序

触手可及、用完即走

小程序码

成本更低,相对于app

使用即是用户

打开速度快

小程序名称是唯一的

用户基量大

缺点

无法大型开发,只有2M大小(现已经在测试20M大小的,另可以使用分包解决)

局限性,必须依赖于微信才可以运行

不能跳转外链网址

框架不稳定成熟,需经常维护

用户留存率低

不能直接分享到朋友圈

上架需审核,比H5即做即用麻烦

uniapp

优点

是一套可以适用于多端的开源框架,一套代码可以编译成多端使用

学习成本低,语法是vue的,组件和api是小程序的

扩展能力强

使用HbuildX开发,丰富的语法提示,开发速度较快

突破了系统对原生H5调用功能的限制

缺点

问世时间短,有很多地方不完善

官方反馈不及时

文件命名受限制

兼容性,在Android平台比微信小程序和iOS差

社区不大

什么是webview

一 WebView到底是什么

  1 WebView是一种控件,它基于webkit引擎,因此具备渲染Web页面的功能。  

  2 基于Webview的混合开发,就是在 Anddroid os(安卓)/I os(苹果)原生APP里,通过WebView控件嵌入Web页面。

  你手机里有淘宝软件吧?

  就是外边是个原生APP的壳,内容是H5页面(基于html+css+js的Web页面)。

  包括淘宝app,阿里云app(笔者目前做阿里云app组件库的开发)等等在内,现在的移动端混合开发软件,如果对于交互渲染要求不是特别高的项目,基本都是这么玩的。

3、webview与H5是相辅相成的,webview可以理解为我们手机上内嵌的一种浏览器,可以加载一些网页的页面,而H5可以理解成是html5,html5可以简单的理解成它是html的一种技术,webview可以加载html5

二、Webview常用方法

1、加载URL

可以根据资源分为三种:

//方式1. 加载一个网页:

webView.loadUrl(“百度一下,你就知道“);

//方式2:加载apk包中的html页面

webView.loadUrl(“file:///android_asset/test.html”);

//方式3:加载手机本地的html页面

webView.loadUrl(“content://com.android.htmlfileprovider/sdcard/test.html”);

// 方式4: 加载 HTML 页面的一小段内容

WebView.loadData(String data, String mimeType, String encoding)

// 参数说明:

// 参数1:需要截取展示的内容

// 内容里不能出现 ’#’, ‘%’, ‘\’ , ‘?’ 这四个字符,若出现了需用 %23, %25, %27, %3f 对应来替代,否则会出现异常

// 参数2:展示内容的类型

// 参数3:字节码

严格模式this指向谁

1.在严格模式下,普通的this指向,指向的是window

2.在严格模式下,函数中的this指向,指向的是undefined

3.对象中的this,指向的实例出来的对象

4.构造函数中的this,指向的是实例出来的对象

5、事件中的对象this,指向的是触发该事件的对象

6、定时器中的this,指向的是window

相关文章:

新整理的前端面试题

pinia和vuex的区别(1)pinia它没有mutation,他只有state,getters,action【同步、异步】使用他来修改state数据(2)pinia他默认也是存入内存中,如果需要使用本地存储,在配置上比vuex麻烦…...

数据仓库-数仓分层

层级 全拼 职责划分 ODS(源数据层) Operational DataStore ODS层存储最原始的数据, 对数据不做任何加工处理; 源数据主要来自业务数据库和日志,这些数据是用户操作业务系统产生,所以叫操作型数据(Operational Data) 。 DWD(…...

【Linux】Linux根文件系统扩容

场景:根文件系统需要至少100GB的剩余空间,但是目前就剩余91GB。因此,我们需要对根文件系统进行扩容。# df -h 文件系统 容量 已用 可用 已用% 挂载点 devtmpfs 3.9G 0 3.9G 0% /dev tmpfs …...

RPC编程:Hessian RPC一个老的RPC框架(一)

RPC编程:Hessian RPC一个老的RPC框架一:Hessian RPC1:Hession RPC一个老的RPC框架2:老,为什么还要研究?3:Hession RPC概念二:Hessian RPC设计思想1:Hession依赖于服务器2…...

逆向 x蜂窝 zzzghostsigh

逆向 x蜂窝 zzzghostsigh 版本 9.3.7 新版本是64位的so charles 抓包 目标字段 zzzghostsigh frida java function hook_xPreAuthencode() {Java.perform(function() {var helper Java.use("com.mfw.tnative.AuthorizeHelper");helper.xPreAuthencode.implemen…...

QML 鼠标事件

作者: 一去、二三里 个人微信号: iwaleon 微信公众号: 高效程序员 QML 中有一些元素本身是不具备交互能力的(例如:Rectangle、Text、Image 等),那么如何通过鼠标来控制它们的行为呢?这里就需要用到 MouseArea 元素了,它继承于 Item 且不可见,通常需要与可见元素结合使…...

极智项目 | 实战pytorch arcface人脸识别

欢迎关注我的公众号 [极智视界],获取我的更多经验分享 大家好,我是极智视界,本文介绍 实战pytorch arcface人脸识别,并提供完整项目源码。 本文介绍的实战arcface人脸识别项目,提供完整的可以一键训练、测试的项目工程…...

【IP技术】ipv4和ipv6是什么?

IPv4和IPv6是两种互联网协议,用于在互联网上标识和寻址设备。IPv4(Internet Protocol version 4)是互联网协议的第四个版本,是当前广泛使用的互联网协议。IPv4地址由32位二进制数构成,通常表示为4个十进制数&#xff0…...

linux基本功系列之uniq命令实战

文章目录前言一. uniq的命令介绍二. 语法格式及常用选项三. 参考案例3.1 统计行数3.2 对文本进行去重3.3 显示不重复的行3.4 仅显示重复的行,且显示重复的行的所有行3.5 忽略字母大小写总结前言 大家好,又见面了,我是沐风晓月,本…...

六、SpringBoot项目搭建

日志 Java 主流日志工具库 统一接口 什么是 REST? Representational State Transfer——“表现层状态转化”。可以总结为一句话:REST 是所有 Web 应用都应该遵守的架构设计指导原则。面向资源是 REST 最明显的特征,对于同一个资源的一组不…...

【LeetCode】2363. 合并相似的物品

2363. 合并相似的物品 题目描述 给你两个二维整数数组 items1 和 items2 ,表示两个物品集合。每个数组 items 有以下特质: items[i] [valuei, weighti] 其中 valuei 表示第 i 件物品的 价值 ,weighti 表示第 i 件物品的 重量 。items 中每…...

华为OD机试题,用 Java 解【出租车计费】问题

最近更新的博客 华为OD机试题,用 Java 解【停车场车辆统计】问题华为OD机试题,用 Java 解【字符串变换最小字符串】问题华为OD机试题,用 Java 解【计算最大乘积】问题华为OD机试题,用 Java 解【DNA 序列】问题华为OD机试 - 组成最大数(Java) | 机试题算法思路 【2023】使…...

【人脸识别】DDL:数据分布知识蒸馏思想,提升困难样本(遮挡、低分辨率等)识别效果

论文题目:《Improving Face Recognition from Hard Samples via Distribution Distillation Loss》 论文地址:https://arxiv.org/pdf/2002.03662v3.pdf 代码地址:https://github.com/HuangYG123/DDL 1.前言及相关工作 Large facial variatio…...

如何管理好仓库/库房?

仓库管理是企业管理中不可缺少的一部分,事关企业能否正常运行的关键之一,古人有云:“三军未动粮草先行”,一个企业仓库管理做不好,他的生产管理肯定也是做不好的,不是说生产管理人员的管理能力不具备&#…...

Unity Lighting -- Unity的光源简介

在主菜单栏中,点击Window -> Rendering -> Light Explorer打开光源管理器,这个标签页可以看到场景中所有的光源,包括每个光源的类型,形状,模式,颜色,强度,阴影等信息。 在主菜…...

Android仿网易云音乐歌单详情页

效果图实现思路:1、Activity设置自定义Shared Element切换动画2、透明状态栏(透明Toolbar,使背景图上移)3、Toolbar底部增加和背景一样的高斯模糊图,并上移图片(为了使背景图的底部作为Toolbar的背景)4、上…...

linux基本功系列之free命令实战

文章目录前言一. free命令介绍二. 语法格式及常用选项三. 参考案例3.1 查看free相关的信息3.2 以MB的形式显示内存的使用情况3.3 以总和的形式显示内存的使用情况3.4 周期性的查询内存的使用情况3.5 以更人性化的形式来查看内存的结果输出总结前言 大家好,又见面了…...

华为OD机试模拟题 用 C++ 实现 - 连续子串(2023.Q1)

最近更新的博客 【华为OD机试模拟题】用 C++ 实现 - 最多获得的短信条数(2023.Q1)) 文章目录 最近更新的博客使用说明连续子串题目输入输出示例一输入输出说明Code使用说明 参加华为od机试,一定要注意不要完全背诵代码,需要理解之后模仿写出,通过率才会高。 华为 OD …...

【软考——系统架构师】UML 建模与架构文档化

🔎这里是【软考——系统架构师】,关注我考试轻松过线 👍如果对你有帮助,给博主一个免费的点赞以示鼓励 欢迎各位🔎点赞👍评论收藏⭐️ 文章目录UML 基础UML 软件开发过程系统架构文档化送书福利UML 基础 U…...

Spring中常用注解

声明 bean 的注解 Component:泛指各种组件 Controller、Service、Repository 都可以称为Component Controller:控制层 Service:业务层 Repository:数据访问层Bean 的生命周期属性 Scope 设置类型包括:设置 Spring 容器…...

JiYuTrainer:极域电子教室破解终极方案,三分钟重获学习自由

JiYuTrainer:极域电子教室破解终极方案,三分钟重获学习自由 【免费下载链接】JiYuTrainer 极域电子教室防控制软件, StudenMain.exe 破解 项目地址: https://gitcode.com/gh_mirrors/ji/JiYuTrainer 你是否曾在课堂上遇到过这样的困境&#xff1f…...

联想天逸100-15ibd旧本升级:光驱位装固态,我踩过的坑你别再踩了(附BIOS设置图)

联想天逸100-15ibd光驱位升级SSD全避坑指南 四年前入手的联想天逸100-15ibd笔记本,最近开机时间已经慢到让人焦虑。看着市面上那些秒开的电脑,决定给自己的老伙计来个"心脏移植"——加装固态硬盘。本以为是个简单的DIY小工程,没想到…...

RTSP拉流播放卡顿?从抓包分析到H264 RTP分片打包的避坑指南

RTSP拉流卡顿全链路诊断:从抓包分析到H264分片优化的实战指南 当视频监控系统的实时画面出现卡顿、花屏或延迟时,工程师往往需要像侦探一样逐层排查。本文将带您深入RTSP/RTP协议栈底层,通过Wireshark抓包分析、H264分片机制解析以及实战调优…...

从玩具小车到3D打印机:用51单片机和A4988模块玩转步进电机的5个创意项目

从玩具小车到3D打印机:用51单片机和A4988模块玩转步进电机的5个创意项目 当51单片机遇上A4988驱动模块,这个看似简单的组合却能爆发出惊人的创造力。不同于传统的驱动教程,我们将带你跨越基础,直接进入实战领域——从会动的玩具小…...

从排查到解决:Docker镜像拉取x509证书错误的实战指南

1. 当Docker镜像拉取失败时:x509证书错误初探 最近在部署Jenkins时,我遇到了一个让人头疼的问题:Docker拉取镜像时突然报错"x509: certificate has expired or is not yet valid"。这个错误看似简单,但背后可能隐藏着多…...

MathType 7安装激活全攻略:从下载到Word插件配置(附常见问题解决)

MathType 7终极配置指南:从零开始打造高效公式编辑环境 在学术写作和科研工作中,数学公式的编辑效率直接影响着文档产出的质量与速度。作为专业数学公式编辑器的标杆,MathType 7凭借其强大的兼容性和直观的操作界面,已成为教育工作…...

红日靶场实战复盘——从外网突破到域控提权的完整攻击链解析

1. 红日靶场环境搭建与初始配置 第一次接触红日靶场时,我被它高度仿真的企业内网环境惊艳到了。这个由红日安全团队打造的靶场平台,完美复现了国内企业常见的网络架构,特别适合练习从外网渗透到内网横向移动的全套技能。靶场包含三台虚拟机&…...

【强化学习环境搭建】攻克gym 0.18.3安装报错:setuptools与wheel版本降级实战

1. 强化学习环境搭建的常见坑点 最近在复现一篇经典强化学习论文时,遇到了gym 0.18.3安装报错的问题。相信很多刚入门强化学习的朋友都踩过类似的坑,特别是当教程或论文要求使用特定版本的gym时,这种版本兼容性问题简直让人抓狂。 我遇到的…...

技术人生:从BERT到晚年,如何构建一个持续进化的AI心智模型

1. 从BERT到河流:AI模型的终身学习哲学 第一次看到BERT模型在NLP任务上的表现时,我正坐在办公室啃着冷掉的三明治。那是2018年的冬天,Transformer架构像洪水般冲垮了传统RNN的堤坝。但当时没人想到,这个突破会引发一个更本质的思考…...

微信聊天记录永久保存与深度分析:WeChatMsg让你的数字记忆不再丢失

微信聊天记录永久保存与深度分析:WeChatMsg让你的数字记忆不再丢失 【免费下载链接】WeChatMsg 提取微信聊天记录,将其导出成HTML、Word、CSV文档永久保存,对聊天记录进行分析生成年度聊天报告 项目地址: https://gitcode.com/GitHub_Trend…...