一文大白话讲清楚webpack基本使用——4——vue-loader的配置和使用

一文大白话讲清楚webpack基本使用------4------vue-loader的配置和使用

1. 建议按文章顺序从头看是看

2. vue-loader的配置和使用

2.1 vue-loader的使用

  • 前端开发少不了使用vue框架,我们在src目录下新建目录vue,然后在vue目录下创建App.vue

  • 当然先安装vue

js 复制代码
nom install vue
  • 然后完善App.vue
vue 复制代码
<template>
    <di class="show">{{show}}</di>
</template>
<script setup>
    import {ref} from 'vue'
    const show=ref('I`m App.vue')
</script>
<style scoped>
    .show{
    font-size: 18px;
    color: green;
}
</style>
  • 在main.js引入app.vue,并挂载到dom实例
js 复制代码
import {App} from './vue/App.vue'
import {createApp} from 'vue'
const app=createApp(App)
app.mount('#app')
  • 安装vue-loader
js 复制代码
npm install vue-loader
  • 配置在webpack.config.js配置vue-loader
js 复制代码
{
    test:/\.vue$/,
    loader:'vue-loader'
}
  • 因为vue-loader15.x版本以上需要使用VueLoaderPlugin来优化vue-loader的使用,所以我们还要配置一下vueLoaderPlugin插件
js 复制代码
const VueLoaderPlugin=require('vue-loader')
new VuewLoaderPlugin()
  • 然后我们重新构建
js 复制代码
npm run build
  • 然后浏览器执行index.html

  • 此时vue文件已经被构建好了

2.2 vue-loader的原理

  • vue-loader的作用是将.vue文件转化为javascript
  • 怎么转化,我们看到一个vue组件里面有template,script和style三部分组成
  • 所以vue-loader就是通过将vue文件中的这三部分拆分三后分别处理
  1. 将vue文件拆分成template,script和style三部分
  2. 通过compile将template生成render、staticRenderFns
  3. 获取script部分返回的配置对象scriptExports
  4. 通过css-loader,vue-style-loader将style部分添加到head中去。或者通过css-loader和MiniCssExtractPlugin将style提取到一个公共的css文件中
  5. 最后通过normalizer方法返回完成的组件配置项options
相关推荐
用户479492835691511 小时前
🤫 你不知道的 JavaScript:`"👦🏻".length` 竟然不是 1?
前端·javascript·面试
掘金一周11 小时前
凌晨零点,一个TODO,差点把我们整个部门抬走 | 掘金一周 9.11
前端·人工智能·后端
用户81744134274811 小时前
kubernetes核心概念 Service
前端
xingkongv11 小时前
从“调接口仔”到“业务合伙人”:前端的 DDD 初体验
javascript·前端框架
东北南西11 小时前
Web Worker 从原理到实战 —— 把耗时工作搬到后台线程,避免页面卡顿
前端·javascript
Zz_waiting.11 小时前
案例开发 - 日程管理 - 第六期
前端·javascript·vue.js·路由·router
A 风11 小时前
封装日期选择器组件,带有上周,下周按钮
开发语言·javascript·vue.js
袁煦丞11 小时前
企业微信开发者的‘跨网穿梭门’:cpolar内网穿透实验室第499个成功挑战
前端·程序员·远程工作
Simon_He11 小时前
vue-markdown-renderer:比 vercel streamdown 更低 CPU、更多节点支持、真正的流式渲染体验
前端·vue.js·markdown
机构师11 小时前
<uniapp><指针组件>基于uniapp,编写一个自定义箭头指针组件
javascript·uni-app·vue·html