Heim > Web-Frontend > View.js > Vue Learning spricht über die Prinzipien der Vorlagenkompilierung

Vue Learning spricht über die Prinzipien der Vorlagenkompilierung

青灯夜游
Freigeben: 2023-03-07 19:01:00
nach vorne
1532 Leute haben es durchsucht

Was ist eine Vorlagenkompilierung? Im folgenden Artikel geht es um die Vorlagenkompilierung in Vue und die Prinzipien der Vorlagenkompilierung. Ich hoffe, dass er für Sie hilfreich ist.

Vue Learning spricht über die Prinzipien der Vorlagenkompilierung

vue stellt eine Vorlagensyntax bereit, die es uns ermöglicht, die Bindungsbeziehung zwischen Status und DOM deklarativ zu beschreiben, wie zum Beispiel <p>{{name}}</p> <p></p>. <p>{{name}}</p> <p></p>

模板编译指的是模板将编译成render函数的过程,渲染函数的作用是每次执行时,会根据最新状态生成新的vnode

编译的过程是:模板作为输入 -> 模板编译 阶段->生成 渲染函数

面试题

  • vue的模板编译?
  • 模板编译Compiler中render讲解?
  • vue 模板编译的过程,每一个过程细说一下做了些什么
  • 模板编译,谁去解析AST树 【相关推荐:vuejs视频教程web前端开发

将模板编译成渲染函数

Vue Learning spricht über die Prinzipien der Vorlagenkompilierung

  • 解析器:将模板解析为AST(Abstract Syntax Tree 抽象语法树)
  • 优化器:遍历AST标记静态节点,因为静态节点不可变,不需要为打上标签的静态节点创建新的虚拟节点,直接克隆已有的虚拟节点。
  • 代码生成器:使用AST生成渲染函数。将AST转换成代码字符串。将代码字符串放入渲染函数中,导出被外界使用。

案例

Vue Learning spricht über die Prinzipien der Vorlagenkompilierung

1.模板确认

假设如下代码,有eltemplaterender$mount

//复杂案例
let vue = new Vue({
    el: &#39;#app&#39;,
    data() {
        return {
            a: 1,
            b: [1]
        }
    },
    render(h) {
        return h(&#39;div&#39;, { id: &#39;hhh&#39; }, &#39;hello&#39;)
    },
    template: `<div id=&#39;hhh&#39; style="aa:1;bb:2"><a>{{xxx}}{{ccc}}</a></div>`
}).$mount(&#39;#app&#39;)

console.log(vue)

//脚手架创建的案例
let vue = new Vue({
  render: h => h(App)
}).$mount(&#39;#app&#39;)
Nach dem Login kopieren

Vue Learning spricht über die Prinzipien der Vorlagenkompilierung

1)渲染到哪个根节点上:判断有无el属性,有的话直接获取el根节点,没有的话调用$mount时去获取根节点

2)渲染哪个模板到根节点上去:是否调用render 函数传入了模板 render: h => h(App) -> <App></App>

  • 有render:这时候优先执行render函数,render优先级 > template
  • 无render:
    • 有template:template解析成render函数的所需格式-代码字符串,并使用调用render函数渲染
    • 无template:el根节点的outerHTML解析成render函数的所需格式-代码字符串,并使用调用render函数渲染
      3.渲染的方式:无论什么情况,最后都统一是要使用render函数渲染

2.解析器-将模板解析成AST

解析器-将模板解析成AST

<div>
  <p>{{name}}</p>
</div>
Nach dem Login kopieren

将上述模板解析成AST后,AST抽象语法树就是使用JS中的对象来描述一个节点,一个对象表示一个节点。

{
  tag: "div"
  type: 1, //节点类型
  staticRoot: false,
  static: false,
  plain: true,
  parent: undefined, //存放父节点
  attrsList: [],
  attrsMap: {},
  children: [ //存放孩子节点
      {
      tag: "p"
      type: 1,
      staticRoot: false,
      static: false,
      plain: true,
      parent: {tag: "div", ...},
      attrsList: [],
      attrsMap: {},
      children: [{
          type: 2,
          text: "{{name}}",
          static: false,
          expression: "_s(name)"
      }]
    }
  ]
}
Nach dem Login kopieren

解析器的工作原理

解析器的原理的是一小段一小段地截取模板字符串,每截取一小段字符串,就会根据截取出来的字符串类型触发不同的钩子函数,直到模板字符串截空停止。然后使用栈来确定层级关系

解析器内部分也分几个子解析器,如HTML解析器、文本解析器等。

HTML解析器的作用是解析HTML,在解析HTML的过程中不断触发各种钩子函数,

  • 开始标签的钩子函数中可以构建元素类型的节点
  • 文本钩子函数中可以构建文本类型的节点
  • 注释钩子函数中可以构建注释类型的节点
  • 结束标签钩子函数

文本解析器是对HTML解析出来的文本进行二次加工,比如插值语法{{}}

如何确定DOM之间的层级关系?使用栈
在触发开始标签的钩子函数时,如果当前标签不是自闭合标签,就pushstack
在触发结束标签的钩子函数时,就从栈中pop

Vorlagenkompilierung bezieht sich auf den Prozess des Kompilierens der Vorlage in eine Renderfunktion. Die Funktion der Renderfunktion besteht darin, bei jeder Ausführung einen neuen Vnode basierend auf dem neuesten Status zu generieren. Der Kompilierungsprozess ist: Vorlage als Eingabe-> Vorlagenkompilierungsphase->Rendering-Funktion generieren

Interviewfragen

🎜🎜🎜Kompilieren Sie die Vorlage in eine Rendering-Funktion🎜🎜🎜< img src=" https://img.php.cn/upload/article/000/000/024/172657b2595ab9895c742e2770ca3e51-0.jpeg" alt="Bildbeschreibung hier einfügen"/>🎜
  • Parser< /code>: Analysieren Sie die Vorlage in AST (Abstract Syntax Tree)</li><li><code>Optimierer: Durchlaufen Sie den AST, um statische Knoten zu markieren, da statische Knoten unveränderlich sind und dies nicht müssen Markieren Sie statische Knoten, um neue virtuelle Knoten zu erstellen und vorhandene virtuelle Knoten direkt zu klonen.
  • Codegenerator: Verwenden Sie AST, um Rendering-Funktionen zu generieren. Konvertieren Sie AST in eine Codezeichenfolge. Fügen Sie die Codezeichenfolge in die Rendering-Funktion ein und exportieren Sie sie zur Verwendung durch die Außenwelt.

🎜🎜Fall🎜

🎜Bildbeschreibung hier einfügen🎜🎜🎜🎜1. Vorlagenbestätigung🎜🎜🎜Gehen Sie vom folgenden Code aus, mit el</ code>, <code>template, render, $mount🎜
<div>
  <p>{{name}}</p>
</div>
//生成的render渲染函数
{
  render: `with(this){return _c('div',[_c('p',[_v(_s(name))])])}`
}
//格式化后
with(this){
  return _c(
    'div',
    [
      _c(
        'p',
        [
          _v(_s(name))
        ]
      )
    ]
  )
}
Nach dem Login kopieren
Nach dem Login kopieren
🎜Bildbeschreibung hier einfügen🎜🎜🎜1) Auf welchen Stammknoten gerendert werden soll🎜: Bestimmen Sie, ob ein el-Attribut vorhanden ist, und wenn ja, rufen Sie es ab el direkt Root-Knoten, wenn nicht, erhalten Sie den Root-Knoten, wenn Sie $mount aufrufen🎜🎜🎜2) Welche Vorlage auf dem Root-Knoten gerendert werden soll🎜: Ob die render-Funktion aufgerufen und die Vorlage übergeben werden soll render: h =&gt ; h(App) -> <App></App>🎜
Verwandte Etiketten:
Quelle:csdn.net
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage