vue常见问题

文章目录

    • data为什么是一个函数,而不是一个对象?什么情况下可以使用对象?
    • key的作用,为什么不能用Index?
    • render函数,h函数,和template什么关系?
    • vue 是怎么解析template的? template会变成什么?
    • 父子,子孙传值

data为什么是一个函数,而不是一个对象?什么情况下可以使用对象?

因为Vue组件可以同时存在多个实例,如果直接使用对象形式的data选项,那么所有的实例将会共享同一个data对象,这样就会造成数据互相干扰的问题。

key的作用,为什么不能用Index?

作用:主要用在Vue 的虚拟DOM 算法,在新旧nodes 对比时辨识VNodes,在源码中使用的是 === 来判断的两个DOM元素是否相同,所以不能设置非基本类型。

为什么不能用Index?

  • 性能损耗:用index 作为key 时,在对数据进行,逆序添加,逆序删除等破坏顺序的操作时,会产生没必要的真实DOM更新,从而导致效率低
  • 额外问题:例如在一个li列表后面加一个<input>输入框,然后在给列表前面加一个元素,会导致patch失败,原因是

源码中:

export function isSameVNodeType(n1: VNode, n2: VNode): boolean {return n1.type === n2.type && n1.key === n2.key
}

render函数,h函数,和template什么关系?

render: h => h(App) :表示 Vue 实例选项对象的 render 方法作为一个函数, 接受传入的参数 h函数,返回 h(App) 的函数调用结果。
h函数:是 hyperscript 的简称——意思是“能生成 HTML (超文本标记语言) 的 JavaScript”。这个名字来源于许多虚拟 DOM 实现默认形成的约定。一个更准确的名称应该是 createVnode(),类似vue2的createElement()
接受三个参数,返回vNode节点:

  • tag:一个 HTML 标签名、一个组件、一个异步组件、或一个函数式组件。(必需的)
  • props:与 attribute、prop 和事件相对应的对象。(可选)
  • children:子 VNodes,使用 h() 构建,或使用字符串获取 “文本 Vnode” 或者有插槽的对象。(可选)

render和template都是Vue中定义组件的方式,但它们有一些不同之处:

  • template是一种类HTML的语法,它定义了组件的结构和展示,包括HTML标签、属性、事件和插值等。Vue将template编译成render函数,最终将render函数渲染成虚拟DOM,并将其渲染到页面上。
  • render函数则是一个函数式组件,它的参数是一个createElement函数和上下文对象。render函数用代码方式描述组件的结构和展示,并返回一个虚拟DOM节点,最终也会被渲染到页面上。

相对于template,render函数更加灵活和强大,可以更精细地控制组件的展示。同时,由于render函数是JavaScript代码,因此它可以被更好地集成到其他代码中。template则更加容易编写和理解,但可能会受到HTML标签和属性的限制。
在实际开发中,我们可以选择使用template或render函数来定义组件,具体取决于组件的需求和开发者的习惯。如果组件需要较为复杂的展示逻辑和动态交互,可以使用render函数来实现。如果组件比较简单,可以使用template来编写。

vue 是怎么解析template的? template会变成什么?

Vue.js在解析和编译模板时,会经过以下过程:

  • 解析模板:Vue.js使用自定义的HTML解析器将模板解析成抽象语法树(AST)。解析器会分析模板中的HTML标记、指令、表达式和事件等内容,并构建出一颗表示模板结构的AST。
  • 静态优化:在生成AST的过程中,Vue.js会对静态内容进行优化。静态内容是指在编译过程中不会发生变化的部分,例如纯文本内容。Vue.js会将静态内容标记为静态节点,以在后续更新过程中跳过对其的处理,提高性能。
  • 编译为渲染函数:Vue.js将AST编译为渲染函数。渲染函数是一个JavaScript函数,它接收数据作为参数,并返回一个虚拟DOM(VNode)树,用于渲染组件的视图。
  • 渲染视图:当组件的数据发生变化时,渲染函数会被调用,生成新的虚拟DOM树。Vue.js会通过比较新旧虚拟DOM树的差异,计算出需要更新的部分,并将其应用到实际的DOM上,从而更新组件的视图。

在上述过程中,模板会被转换成一个渲染函数。渲染函数可以是以下几种形式之一:
使用render方法编写的渲染函数:在组件中定义了一个render方法,该方法返回一个虚拟DOM树。
使用单文件组件(.vue文件):Vue.js提供了单文件组件的支持,其中的部分就是模板,通过编译转换为渲染函数。
使用Vue.js的模板语法:在Vue组件的template选项中使用Vue.js的模板语法,也会被编译为渲染函数。
总之,Vue.js将模板解析为AST,然后根据AST生成渲染函数,最终通过渲染函数来渲染组件的视图。这个过程使得Vue.js能够高效地根据数据动态更新视图。

父子,子孙传值

  • 通过 props 传递
  • 通过 $emit触发自定义事件
  • 使用 ref
  • EventBus
  • $parent$root
  • attrs 与 listeners
  • Provide 与 Inject
  • Vuex

父子关系:选择 props 与 $emit进行传递,也可选择ref
兄弟关系:选择$bus,其次可以选择$parent进行传递
祖先与后代:选择attrs与listeners或者 Provide与 Inject
复杂关系的组件:通过vuex存放共享的变量

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

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

相关文章

讨好型人格的职业分析,如何改变讨好型人格

一味讨好他人&#xff0c;忽略自己感受&#xff0c;凡事以人为先&#xff0c;忽视自己需求&#xff0c;这就是讨好型人格。 讨好型人格最典型的表现就是非常注重外界的看法&#xff0c;不管做什么事都会小心翼翼&#xff0c;生怕自己所做的事会引发别人的不满。 如果自己哪方…

MAC电脑系统清理空间免费版软件CleanMyMac X2024

大家好&#xff0c;我是那个总是被苹果电脑“内存已满”提示搞得焦头烂额的专业博主。如果你也像我一样&#xff0c;在使用Mac时经常遭遇卡顿、慢吞吞的情况&#xff0c;那么今天的Mac清理空间妙招分享绝对适合你&#xff01; CleanMyMac X全新版下载如下: https://wm.makedi…

【Redis快速入门】深入解读哨兵模式

个人名片&#xff1a; &#x1f43c;作者简介&#xff1a;一名大三在校生&#xff0c;喜欢AI编程&#x1f38b; &#x1f43b;‍❄️个人主页&#x1f947;&#xff1a;落798. &#x1f43c;个人WeChat&#xff1a;hmmwx53 &#x1f54a;️系列专栏&#xff1a;&#x1f5bc;️…

分糖果问题(java实现)

一、题目 描述 一群孩子做游戏&#xff0c;现在请你根据游戏得分来发糖果&#xff0c;要求如下&#xff1a; 每个孩子不管得分多少&#xff0c;起码分到一个糖果。任意两个相邻的孩子之间&#xff0c;得分较多的孩子必须拿多一些糖果。(若相同则无此限制) 给定一个数组 arr …

odoo16实用功能之作业队列(queue.job)

目录 1、官方文档 2、说明 3、简单的开发手册 1、在 Odoo 代码中定义需要异步处理的方法。 2、在需要调用异步方法的位置&#xff0c;使用 with_delay() 调用该方法。 3、注意事项 1、官方文档 Job Queue .. !!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!! This…

layui-tab加载echarts宽度丢失

主要是设置div的样式为&#xff1a;width:100%;height:100%;display: block; <style>.layui-tab-item{width:100%;height:480px;} </style><div class"layui-tab layui-tab-brief" lay-filter"component-tabs-brief"><ul class"…

C语言系列12——多线程与并发编程

目录 写在开头1 多线程的基本概念与应用场景1.1 什么是多线程&#xff1f;1.2 多线程的优势1.3 应用场景详解1.3.1 并行计算1.3.2 高响应性应用程序1.3.3 网络编程1.3.4 实时处理 1.4 多线程编程的挑战 2 POSIX线程库的使用与实际案例2.1 基础概念2.2 创建和管理线程2.3 线程同…

HTML 入门指南

简述 参考&#xff1a;HTML 教程- (HTML5 标准) HTML 语言的介绍、特点 HTML&#xff1a;超级文本标记语言&#xff08;HyperText Markup Language&#xff09; “超文本” 就是指页面内可以包含图片、链接等非文字内容。“标记” 就是使用标签的方法将需要的内容包括起来。…

116 C++ 可变参数函数,initializer_list (初始化列表), 省略号形参

一 可变参数函数 有时候我们传递的参数是不固定的。 这种能接受非固定个数参数的函数就是可变参数函数 怎么实现呢&#xff1f;就要用到 initializer_list 标准库类型 该类型能够使用的前提条件是&#xff1a;所有的实参类型相同。 二&#xff0c;initializer_list(初始化列…

电阻(二):希尔伯特(Hilbert)曲线

1、Hilbert简介 希尔伯特曲线是一种能在 2D平面完美填充正方形的曲线&#xff0c;连续且稳定&#xff08;当细分足够小时&#xff0c;线构成面&#xff09;而又不可导的曲线。只要恰当选择函数&#xff0c;画出一条连续的参数曲线&#xff0c;当参数 t 在 [0、1 ] 区间取值时&a…

ESP32-Cam学习(2)——PC实时显示摄像头画面

具体代码和操作过程见&#xff1a; 3. 实时显示摄像头画面 (itprojects.cn)https://doc.itprojects.cn/0006.zhishi.esp32/02.doc/index.html#/e03.showvideo我主要记录一下我在复现的过程中&#xff0c;遇到的问题以及解决方法。 1.安装第三方库 首先电脑端的代码需要用pych…

备战蓝桥杯---动态规划(入门3之子串问题)

本专题再介绍几种经典的字串问题。 这是一个两个不重叠字串和的问题&#xff0c;我们只要去枚举分界点c即可&#xff0c;我们不妨让c作为右区间的左边界&#xff0c;然后求[1,c)上的单个字串和并用max数组维护。对于右边&#xff0c;我们只要反向求单个字串和然后选左边界为c的…

到底什么是哈希值,哈希值到底是怎么生成的,有什么用?

哈希值&#xff0c;即HASH值&#xff0c;通常用一个短的随机字母和数位组成的字串来代表&#xff0c;是一组任意长度的输入信息通过哈希算法得到的“数据指纹”&#xff0c;即进行加密运算得到的一组二进制值。因为电脑在底层机器码是采用二进位的模式&#xff0c;因此通过哈希…

java中x++和++x的区别,执行后x的值是多少

在Java和C等编程语言中&#xff0c;x 和 x 都是用来对变量 x 进行自增操作的表达式&#xff0c;它们的主要区别在于自增操作发生的时机以及返回值&#xff1a; 后置递增运算符 x&#xff1a; 先使用当前 x 的值进行表达式计算&#xff0c;然后将 x 的值加 1。 执行后的 x 值为…

django连接本地数据库并执行增删改查

1&#xff0c;首先需要将本地数据库的表同步到django的models.py文件 py manage.py inspectdb tb_books tb_heros > demo001/models.py 2&#xff0c;同步成功后models.py会根据每张表映射出不同的类 models.py文件根据数据库表映射出对应的类 3&#xff0c;然后根据不同…

初识 Rust 语言

目录 前言一、Rust 的背景二、Rust的特性三、部署开发环境&#xff0c;编写一个简单demo1、在ubuntu 20.04部署环境2、编写demo测试 四、如何看待Linux内核引入Rust 前言 自Linux 6.1起&#xff0c;初始的Rust基础设施被添加到Linux内核中。此后为了使内核驱动程序能够用Rust编…

应如何看待用AI写论文一事? AI写论文有助科研还是助长作弊?

自大语言模型问世后&#xff0c;许多高校学生都在悄悄利用ChatGPT等AI&#xff08;人工智能&#xff09;写作软件代写论文&#xff0c;或者用AI辅助论文写作&#xff0c;如罗列提纲、润色语言、降低重复率等。 国内类似ChatGPT的AI写作软件并不少见。在各大等网站上&#xff0…

SpringBoot 打成jar包后如何获取jar包Resouces下的文件

获取resouces下的文件使用以下代码即可读取&#xff0c;如果需要变成file传入其他的方法中&#xff0c;需要创建临时文件将输入流文件 复制到 临时文件中&#xff0c;并传入相关方法&#xff0c;最后删除临时文件即可。不能通过ClassPathResouce对象直接获取 文件File ClassPa…

管理员分级管控三大模式,提高企业内部管理效率

随着公司规模的不断扩大和部门的持续增加&#xff0c;权限管理问题日益凸显。每当新员工入职&#xff0c;都需要经过一系列繁琐的步骤来为其匹配相应的权限。然而&#xff0c;这种传统的、基于手动更新的管理方式不仅效率低下、安全风险大&#xff0c;给企业带来了巨大的数据安…

echats 时间直方图示例

需求背景 某订单有N个定时任务&#xff0c;每个任务的执行时间已经确定&#xff0c;希望直观的查看该订单的任务执行趋势 查询SQL&#xff1a; select UNIX_TIMESTAMP(DATE_FORMAT(exec_time,%Y-%m-%d %H:%i)) execTime, count(*) from order_detail_task where order_no 2…