亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

.vue文件編譯成瀏覽器可執(zhí)行文件的流程詳解

 更新時(shí)間:2023年09月01日 09:36:20   作者:九殤  
這篇文章主要給大家介紹了.vue?文件是如何編譯成瀏覽器可執(zhí)行的文件,文中通過代碼示例將編譯流程介紹的非常詳細(xì),對(duì)我們的學(xué)習(xí)或工作有一定的價(jià)值,感興趣的同學(xué)可以參考閱讀下

vue2官網(wǎng) 其中”安裝”介紹了關(guān)于Vue的各種版本。

  • 編譯器:用來將模板字符串編譯成為 JavaScript 渲染函數(shù)的代碼。
<div id="app">
    <div>{{ a }}</div> 
</div> 
<script src="https://cdn.jsdelivr.net/npm/vue@2.7.14/dist/vue.js"></script> <script> 
const vm = new Vue({ el: '#app', data: { a: 'hello world', }, }) 
</script>

以上是一段簡(jiǎn)單的Vue2代碼, 打開瀏覽器可以正確顯示出 “hello world”,- 可以發(fā)現(xiàn) <div>{{ a }}</div> 不是瀏覽器支持的語(yǔ)法. 所以實(shí)際上能顯示 hello world, 并不是由以上模板代碼直接在瀏覽器執(zhí)行的結(jié)果, 而是通過”編譯器”編譯, 再由瀏覽器執(zhí)行

  • 接下來用代碼為大家演示Vue2是如何將上面代碼編譯的
  • 首先必須引入”完整版”,
  • 打開頁(yè)面, 在控制臺(tái)可以發(fā)現(xiàn)方法: Vue.compile

  • 將剛才的 template 代碼放到編譯方法里執(zhí)行, 結(jié)果如下

  • 可以看到 template 被編譯成 JavaScript,_c,_v,_s,是vue實(shí)例vm上一些方法的簡(jiǎn)稱

  • 編譯結(jié)果可以翻譯成
<script>
    const vm = new Vue({
      el: '#app',
      name: 'App',
      data: () => ({
        a: 'hello world!!!',
      }),
      render() {
        const {_c, _v, _s, a} = this
        //return createElement('div', [createTextNode(toString(a))])
        return  _c('div',[_v(_s(a))])
      }
  })
  </script>

這樣 模板template就被編譯為了 render函數(shù)

  • 以上便是在 .html 文件中使用template 開發(fā), 由 Vue2完整版 進(jìn)行編譯的過程

.vue文件是如何進(jìn)行編譯的?

通常項(xiàng)目中是使用Webpack打包, 再由瀏覽器引入這些js, css等文件, 那么Webpack是如何對(duì).vue文件進(jìn)行編譯的?

1. .vue文件

.vue文件,.vue 文件是一個(gè)自定義的文件類型,用類 HTML 語(yǔ)法描述一個(gè) Vue 組件。每個(gè) .vue 文件包含三種類型的頂級(jí)語(yǔ)言塊 <template>、<script> 和 <style>,還允許添加可選的自定義塊.

2. vue-loader

vue-loader 會(huì)解析文件,提取每個(gè)語(yǔ)言塊,如有必要會(huì)通過其它 loader 處理,最后將他們組裝成一個(gè) ES Module,它的默認(rèn)導(dǎo)出是一個(gè) Vue.js 組件選項(xiàng)的對(duì)象。

接下來通過vue-loader的源碼來了解是如何實(shí)現(xiàn)編譯的

vue-loader/src/index.ts

vue文件分為 template, script, style 三個(gè)部分, 而實(shí)際必須通過編譯才能在瀏覽器執(zhí)行的部分只有template, 所以我們?cè)诳?vue-loader 源碼時(shí)可以重點(diǎn)關(guān)注 “template” 關(guān)鍵詞

descriptor.template 如上圖所示, 在源碼搜索 template 關(guān)鍵字可以找到這段處理 script, template, style 的代碼, 仔細(xì)觀察發(fā)現(xiàn)這三段都在用 descriptor 對(duì)象, 接下來搜索 descriptor, 找到這個(gè)變量在哪里生成的 descriptor

再來找 parse 方法

compiler.ts compiler.ts

parse 方法從 vue/compiler-sfc 中引用

至此, 了解到 vue-loader 是通過 @vue/compiler-sfc 的 parse 方法解析 .vue 文件, 從中解析出script, template, style

@vue/compiler-sfc

用一段nodejs代碼進(jìn)行驗(yàn)證

// App.vue
<template>
  <div id="app">
    <div>{{ a }}</div>
    <input type="text" v-model="a">
  </div>
</template>
<script>
export default {
  name: 'App',
  data: () => ({
    a: 'hello world'
  }),
}
</script>
// build.js
const { parse } = require('@vue/compiler-sfc')
const fs = require('fs')
const data = fs.readFileSync('./App.vue')
const { descriptor } = parse(data.toString())
// 結(jié)果包含很多項(xiàng), 本文檔中只展示重點(diǎn)字段
console.log(Object.keys(descriptor))

運(yùn)行 build.js

[
  'styles',
	'template',
  'script',
  // ...
]

通過以上代碼可以解析出 .vue 文件的三部分, 接下來開始解析 template vue-template-compiler vue-template-compiler 可以將 template 編譯成 Javascript

  • 繼續(xù)修改 build.js, 根據(jù)文檔加上 compile 的部分
// build.js
const { parse } = require('@vue/compiler-sfc')
const fs = require('fs')
const compiler = require('vue-template-compiler')
const data = fs.readFileSync('./App.vue')
const { descriptor } = parse(data.toString())
// console.log(Object.keys(descriptor))
console.log(compiler.compile(descriptor.template.content).render)
  • 運(yùn)行結(jié)果如下
with(this){
  return _c(
    'div',
    {attrs:{"id":"app"}},
    [
      _c('div',[_v(_s(a))]),
      _v(" "),
      _c(
        'input',
        {
          directives:[{name:"model",rawName:"v-model",value:(a),expression:"a"}],
          attrs:{"type":"text"},
          domProps:{"value":(a)},
          on:{
            "input": function($event){
              if($event.target.composing) return;
              a=$event.target.value
            }
          }
        }
      )
    ]
  )
}

再將以上代碼放到 .html 的 new Vue(...) 方法中進(jìn)行驗(yàn)證

<div id="app"/>
<script src="https://cdn.jsdelivr.net/npm/vue@2.7.14/dist/vue.js"></script>
<script>
  const vm = new Vue({
    name: 'App',
    data: () => ({
      a: 'hello world!!!',
    }),
    render() {
      const {_c, _v, _s, a} = this
      return _c(
        'div',
        {attrs: {'id': 'app'}},
        [
          _c('div', [_v(_s(a))]),
          _v(' '),
          _c(
            'input',
            {
              directives: [{name: 'model', rawName: 'v-model', value: (a), expression: 'a'}],
              attrs: {'type': 'text'},
              domProps: {'value': (a)},
              on: {
								// 注意這里的 this, 需要改成箭頭函數(shù)
                'input': ($event) => {
                  if ($event.target.composing) return
                  this.a = $event.target.value
                },
              },
            },
          ),
        ],
      )
    },
  }).$mount('#app')
</script>

以上便是 Webpack 如何將 .vue 文件編譯成瀏覽器可執(zhí)行文件的過程

到此這篇關(guān)于.vue文件編譯成瀏覽器可執(zhí)行文件的流程詳解的文章就介紹到這了,更多相關(guān).vue文件編譯成可執(zhí)行文件內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評(píng)論