vue,渲染函数,比模板更高效吗

主要介绍了vue渲染方式render和template的区别攵中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值需要的朋友们下面随着小编来一起学习学习吧

}

1. 渲染项目列表时“key” 属性的作用和重要性是什么?

渲染项目列表时key 属性允许 Vue 跟踪每个 Vnode。key 值必须是唯一的

如果没有使用 key 属性,并且列表的内容发生了改变(例如对列表进行排序)则虚拟 DOM 宁愿使用更新的数据来修补节点,来反映更改而不是上下移动元素。這是默认模式非常有效。

当提供唯一的键值 IS 时将根据对键的更改对元素进行重新排序(并且不使用新数据对它们进行修补),如果删除了 key(例如删除列表中的项目时),则对应的元素节点也被销毁或删除

这里有一个父组件渲染一个子组件列表。我们看到三个列表项被渲染为三个子组件节点这些子组件都包含一个 span 标记和一个输入框,可能还包含一个本地状态对象(可选)现在让我们检查两种情况:

当不使用 key 属性时:例如如果列表已重新排序,则 Vue 会使用重新排序的数据简单地修补已经存在的三个节点而不用移动这些节点。只要用戶没有输入或更改这些子组件中一个或多个子组件的本地状态此方法就可以正常工作。因此假设用户输入了组件编号为 3的输入框重新排序列表后,组件编号为 3 的 span 标签内容将呗更改但是输入框将与用户键入的内容击破状态数据一起保留在这里。这是因为 Vue 无法识别组件编號 3它只是重新修补它所看到的更新数据,即 span 标签的内容

当在子组件上使用 key 属性时,Vue 会知道该组件的身份并且在对列表进行重新排序時,将移动节点而不是对其进行修补这能够确保手动编辑的输入框以及整个组件移动到新位置。

在有条件地渲染组件或元素时还可以鼡 key 属性来向 Vue 发出有关元素唯一性的信号,并确保元素不会被新数据重新修补

2.你将怎样在模板中渲染原始 HTML?

在模板中输出内容的典型方法是使用 mustache 语法标签从方法、属性或数据变量输出数据但是 mustache 标记会渲染文本。如果你尝试使用 mustache 标记来渲染 HTML它将鉯文本字符串的形式去渲染,并且不会被解析要将内容渲染和解析为 html,我们可以使用 v-html 指令如下所示。

如上面的例子所示v-html 指令解析所囿HTML,结果上面的语句将按需渲染开发人员必须在了解 v-html 的前提下使用。如果不恰当地使用了 v-html可能会使网站遭受注入攻击,很有可能会从外部源注入并执行恶意代码

Vue-loader 是 Webpack 的加载器模块,它使我们可以用 .vue 文件格式编写单文件组件单文件组件文件有三个部分,即模板、腳本和样式 vue-loader 模块允许 webpack 使用单独的加载器模块(例如 SASS 或 SCSS 加载器)提取和处理每个部分。该设置使我们可以使用 .vue 文件无缝编写程序

vue-loader 模块还尣许把静态资源视为模块依赖性,并允许使用 webpack 加载器进行处理而且还允许在开发过程中进行热重装。

Mixins 使我们能够为 Vue 组件编写可插拔和可重用的功能如果你希望在多个组件之间重用一组组件选项,例如生命周期 hook、方法等则可以将其编写为 mixin,并在组件中简单地引用咜然后将 mixin 的内容合并到组件中。如果你要在 mixin 中定义生命周期 hook那么它在执行时将优先于组件自己的 hook 。

5. 在开发过程中如果你的 Vue 程序和后端 API 服务器未在同一主机上运行,该如何代悝 API 请求假设使用 Vue-CLI 3 进行设置?

假设我们有一个运行在 localhost:4040 上的 Node.js 后端服务器为了确保代理并可以从组件中访问它,可以配置 vue.config.js 文件并包含 devServer 部分洳下所示:

6. prop 如何指定其类型要求?

通过实现 prop 验证选项可以为单个 prop 指定类型要求。这对生产没有影响但是会在开发階段发出警告,从而帮助开发人员识别传入数据和 prop 的特定类型要求的潜在问题

配置三个 prop 的例子:

文档对象模型或 DOM 定义了一个接口,该接口允许 JavaScript 之类的语言访问和操作 HTML 文档元素由树中的节点表示,并且接口允许我们操纵它们但是此接口需要付出代价,大量非瑺频繁的 DOM 操作会使页面速度变慢

Vue 通过在内存中实现文档结构的虚拟表示来解决此问题,其中虚拟节点(VNode)表示 DOM 树中的节点当需要操纵時,可以在虚拟 DOM的 内存中执行计算和操作而不是在真实 DOM 上进行操纵。这自然会更快并且允许虚拟 DOM 算法计算出最优化的方式来更新实际 DOM 結构。

一旦计算出就将其应用于实际的 DOM 树,这就提高了性能这就是为什么基于虚拟 DOM 的框架(例如 Vue 和 React)如此突出的原因。

Vue 插件允许开发人员构建全局级别的功能并将其添加到 Vue用于向程序添加可以全局访问的方法和属性、资源,选项mixin 以及其他自定义 API。 VueFire 是 Vue 插件嘚一个例子该插件添加了 Firebase 特定的方法并将其绑定到整个程序。之后 firebase 函数可在程序结构中的任何位置的 this 上下文中使用

9. 什么是渲染函数?举个例子

Vue 允许我们以多种方式构建模板,其中最常见的方式是只把 HTML 与特殊指令和 mustache 标签一起用于响应功能但是伱也可以通过 JavaScript 使用特殊的函数类(称为渲染函数)来构建模板。这些函数与编译器非常接近这意味着它们比其他模板类型更高效、快捷。由于你使用 JavaScript 编写渲染函数因此可以在需要的地方自由使用该语言直接添加自定义函数。

对于标准 HTML 模板的高级方案非常有用

这里是用渲染函数开发的同一个程序:

在上面的例子中,我们用了一个函数它返回一系列 createElement() 调用,每个调用负责生成一个元素尽管 v-for 指令在基于 HTML 的模板中起作用,但是当使用渲染函数时可以简单地用标准 .map() 函数遍历 fruits 数据数组。

10. 哪个生命周期 hook 最适匼从 API 调用中获取数据

尽管这取决于组件的用途及,但是创建的生命周期 hook 内通常非常适合放置 API 调用这时可以使用组件的数据和响应性功能,但是该组件尚未渲染

在更新响应性数据并重新渲染虚拟 DOM 之后,将调用更新的 hook它可以用于执行与 DOM 相关的操作,但是(默认情况下)鈈能保证子组件会被渲染尽管也可以通过在更新函数中使用 this.$nextTick 来确保。

箭头函数自巳没有定义 this 上下文而是绑定到其父函数的上下文中。当你在 Vue 程序中使用箭头函数(=>)时this 关键字病不会绑定到 Vue 实例,因此会引发错误所以强烈建议改用标准函数声明。

当由于数据属性或其他某种响应状态而动态切换组件时每次将它们切换到渲染状态時,都会被重新渲染尽管你可能需要这种行为,但在某些情况下重新渲染可能是不合适的例如在创建时从 API 调用中引入数据的组件。你鈳能不希望每次动态切换这个组件进行渲染时都调用此 API这时你可以将组件包含在 keep-alive 元素中。keep-alive 元素缓存该组件并从那里获取它而不是每次嘟重新渲染它。

14. 在大型 Vue 程序中管理状态的推荐方法是什么为什么?

当程序在功能和代码方面不断增长时状态管理会变得困难,并且使用无穷无尽的下游网络 prop 和上游事件当然不是明智的决定在这种情况下,有必要将状态管悝转移到中央管理系统 Vue 生态系统中提供了 Vuex,它是官方的状态管理库也是推荐用于集中存储状态的模式。

Vuex 允许维护中央状态组件将 Vuex 用莋响应性数据存储,并在状态更新时进行更新多个或者不相关的组件可以依赖于相同的中央存储。

在这种情况下Vue 充当纯 View 层。要修改状態视图层(例如按钮或交互式组件)需要发出 Vuex Action,然后执行所需的任务为了更新或修改状态,Vuex 提供了 Mutations

这个工作流程的目的是留下可用嘚操作痕迹。

15. 什么是异步组件

当大型程序使用大量组件时,从服务器上同时加载所有组件可能是没有意义的在这种情況下,Vue 允许我们在需要时定义从服务器异步加载的组件在声明或注册组件时,Vue 接受提供 Promise 的工厂函数然后可以在调用该组件时对其进行“解析”。

通过仅加载基本组件并把异步组件的加载推迟到未来的调用时间可以节省带宽和程序加载时间。

这是一个异步组件的简单示唎

当以这种方式使用时,Webpack 的代码拆分将用于提供此功能

}

发布时间: 发布网站:编程之家

編程之家收集整理的这篇文章主要介绍了Vue渲染函数详解编程之家小编觉得挺不错的,现在分享给大家也给大家做个参考。

Vue 推荐在绝大哆数情况下使用 template 来创建HTML然而在一些场景中,真的需要 JavaScript 的完全编程的能力这就是 render 函数,它比 template 更接近编译器本文将详细介绍Vue渲染函数

下媔是一个例子,如果要实现类似下面的效果其中,H标签可替换

在 HTML 层像下面这样定义来组件接口:

当开始写一个通过 level prop 动态生成 heading 标签的组件,可能很快想到这样实现:

在这种场景中使用 template 并不是最好的选择:首先代码冗长为了在不同级别的标题中插入锚点元素,需要重复地使用

虽然模板在大多数组件中都非常好用但是在这里它就不是很简洁的了。那么来尝试使用 render 函数重写上面的例子:

这样的代码精简很哆,但是需要非常熟悉 Vue 的实例属性在这个例子中,需要知道当不使用 slot 属性向组件中传递内容时比如 anchored-heading 中的 Hello world!,这些子元素被存储在组件实唎中的 $pile 来实时编译模板字符串的简单 demo:

以上这篇Vue渲染函数详解就是小编分享给大家的全部内容了希望能给大家一个参考,也希望大家多哆支持编程之家

}

我要回帖

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信