Table des matières
AST解析
render函数
普通组件和动态组件的对比
动态组件的render函数
Maison interface Web Voir.js Une brève discussion sur la façon d'utiliser les composants dynamiques dans Vue ?

Une brève discussion sur la façon d'utiliser les composants dynamiques dans Vue ?

Nov 10, 2021 pm 07:08 PM
vue 动态组件 组件

本文文章我们来了解一下Vue中的组件,介绍一下动态组件的用法,希望对大家有所帮助!

Une brève discussion sur la façon d'utiliser les composants dynamiques dans Vue ?

动态组件在开发的过程中大多数情况下都会用到,当我们需要在不同的组件之间进行状态切换时,动态组件可以很好的满足我们的需求,其中的核心是component标签和is属性的使用。【相关推荐:《vue.js教程》】

1

2

3

4

5

6

7

<div id="app">

  <button @click="changeTabs(&#39;child1&#39;)">child1</button>

  <button @click="changeTabs(&#39;child2&#39;)">child2</button>

  <button @click="changeTabs(&#39;child3&#39;)">child3</button>

  <component :is="chooseTabs">

  </component>

</div>

Copier après la connexion

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

// js

var child1 = {

  template: &#39;<div>content1</div>&#39;,

}

var child2 = {

  template: &#39;<div>content2</div>&#39;

}

var child3 = {

  template: &#39;<div>content3</div>&#39;

}

var vm = new Vue({

  el: &#39;#app&#39;,

  components: {

    child1,

    child2,

    child3

  },

  methods: {

    changeTabs(tab) {

      this.chooseTabs = tab;

    }

  }

})

Copier après la connexion

例子是一个动态组件的基本使用场景,当点击按钮时,视图根据this.chooseTabs值在组件child1,child2,child3间切换。

AST解析

<component>的解读和前面几篇内容一致,会从AST解析阶段说起,过程也不会专注每一个细节,而是把和以往处理方式不同的地方特别说明。针对动态组件解析的差异,集中在processComponent上,由于标签上is属性的存在,它会在最终的ast树上打上component属性的标志。

1

2

3

4

5

6

7

8

9

10

11

12

//  针对动态组件的解析

function processComponent (el) {

  var binding;

  // 拿到is属性所对应的值

  if ((binding = getBindingAttr(el, &#39;is&#39;))) {

    // ast树上多了component的属性

    el.component = binding;

  }

  if (getAndRemoveAttr(el, &#39;inline-template&#39;) != null) {

    el.inlineTemplate = true;

  }

}

Copier après la connexion

Une brève discussion sur la façon dutiliser les composants dynamiques dans Vue ?

render函数

有了ast树,接下来是根据ast树生成可执行的render函数,由于有component属性,render函数的产生过程会走genComponent分支。

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

// render函数生成函数

var code = generate(ast, options);

 

// generate函数的实现

function generate (ast,options) {

  var state = new CodegenState(options);

  var code = ast ? genElement(ast, state) : &#39;_c("div")&#39;;

  return {

    render: ("with(this){return " + code + "}"),

    staticRenderFns: state.staticRenderFns

  }

}

 

function genElement(el, state) {

  ···

  var code;

  // 动态组件分支

  if (el.component) {

    code = genComponent(el.component, el, state);

  }

}

Copier après la connexion

针对动态组件的处理逻辑其实很简单,当没有内联模板标志时(后面会讲),拿到后续的子节点进行拼接,和普通组件唯一的区别在于,_c的第一个参数不再是一个指定的字符串,而是一个代表组件的变量

1

2

3

4

5

6

7

8

9

10

// 针对动态组件的处理

  function genComponent (

    componentName,

    el,

    state

  ) {

    // 拥有inlineTemplate属性时,children为null

    var children = el.inlineTemplate ? null : genChildren(el, state, true);

    return ("_c(" + componentName + "," + (genData$2(el, state)) + (children ? ("," + children) : &#39;&#39;) + ")")

  }

Copier après la connexion

普通组件和动态组件的对比

1

"with(this){return _c(&#39;div&#39;,{attrs:{"id":"app"}},[_c(&#39;child1&#39;,[_v(_s(test))])],1)}"

Copier après la connexion

动态组件的render函数

1

with(this){return _c(&#39;div&#39;,{attrs:{"id":"app"}},[_c(chooseTabs,{tag:"component"})],1)}

Copier après la connexion

简单的总结,动态组件和普通组件的区别在于:

  • ast阶段新增了component属性,这是动态组件的标志

  • 产生render函数阶段由于component属性的存在,会执行genComponent分支,genComponent会针对动态组件的执行函数进行特殊的处理,和普通组件不同的是,_c的第一个参数不再是不变的字符串,而是指定的组件名变量。

  • rendervnode阶段和普通组件的流程相同,只是字符串换成了变量,并有{ tag: 'component' }data属性。例子中chooseTabs此时取的是child1

有了render函数,接下来从vnode到真实节点的过程和普通组件在流程和思路上基本一致,这一阶段可以回顾之前介绍组件流程的分析

更多编程相关知识,请访问:编程入门!!

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn

Article chaud

Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Article chaud

Combien de temps faut-il pour battre Split Fiction?
3 Il y a quelques semaines By DDD
Repo: Comment relancer ses coéquipiers
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Adventure: Comment obtenir des graines géantes
3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌

Tags d'article chaud

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Comment utiliser les graphiques électroniques dans Vue Comment utiliser les graphiques électroniques dans Vue May 09, 2024 pm 04:24 PM

Comment utiliser les graphiques électroniques dans Vue

Le rôle de l'export par défaut dans vue Le rôle de l'export par défaut dans vue May 09, 2024 pm 06:48 PM

Le rôle de l'export par défaut dans vue

Comment utiliser la fonction map dans vue Comment utiliser la fonction map dans vue May 09, 2024 pm 06:54 PM

Comment utiliser la fonction map dans vue

La différence entre event et $event dans vue La différence entre event et $event dans vue May 08, 2024 pm 04:42 PM

La différence entre event et $event dans vue

Le rôle du monté en vue Le rôle du monté en vue May 09, 2024 pm 02:51 PM

Le rôle du monté en vue

La différence entre l'exportation et l'exportation par défaut dans vue La différence entre l'exportation et l'exportation par défaut dans vue May 08, 2024 pm 05:27 PM

La différence entre l'exportation et l'exportation par défaut dans vue

Onmount en vue correspond à quel cycle de vie de réagir Onmount en vue correspond à quel cycle de vie de réagir May 09, 2024 pm 01:42 PM

Onmount en vue correspond à quel cycle de vie de réagir

Que sont les crochets en vue Que sont les crochets en vue May 09, 2024 pm 06:33 PM

Que sont les crochets en vue

See all articles