Vue单文件组件

一、.vue文件

我们使用Vue的单文件组件的时候,一个.vue文件就是一个组件。

例如我们创建一个School组件:

二、组件的结构

我们编写网页代码的时候有HTML结构、CSS样式、JS交互。

组件里也是同样存在这三种结构的:

javascript 复制代码
<template>
    <div>
        <!-- 模板 -->
    </div>
</template>

<script>
    // 交互
</script>

<style>
    /* 样式 */
</style>

模板中必须要用一个div标签包住所有的模板,不然会报错。

然后将模板的内容写在template中,Vue的内容写在script中,style正常写样式即可。

javascript 复制代码
<template>
  <div>
    <div>学校名称:{{ name }}</div>
    <div>学校地址:{{ address }}</div>
    <button @click="showHello">点我弹窗</button>
  </div>
</template>

<script>
export default {
  name:"School",
  data() {
    return {
      name: "家里蹲大学",
      address: "家",
    }
  },
  methods: {
    showHello() {
      alert("Hello!");
    },
  }
};
</script>

<style>
    button{
        background-color: skyblue;
    }
</style>

这里的VueComponent必须暴露出去外界才能引用到这个组件。

三、App.vue

当我们创建完所有的组件的后,全部都交由App.vue进行统一管理。

先对组件进行引入,然后配置components,最后在模板中使用组件:

javascript 复制代码
<template>
  <div>
    <School/>
    <Student/>
  </div>
</template>

<script>
import School from './School.vue';
import Student from './Student.vue';

export default {
    name: "App",
    components: {
        School,
        Student
    }
}
</script>

四、main.js

main.js为入口文件,主要管理App.vue文件。

需要创建Vue实例对象和挂载Vue:

javascript 复制代码
import App from "App.vue";

new Vue({
    el: "#root",
    template: `<App></App>`,
    components: {
        App
    }
})

五、index.html

配置root根元素和引入入口文件:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="root"></div>

    <script src="/js/vue.js"></script>
    <script src="/单文件组件/main.js"></script>
</body>
</html>

所以最终文件结构如下:

相关推荐
悟能不能悟1 分钟前
vue导出excel文件
前端·vue.js·excel
VX:Fegn08954 分钟前
计算机毕业设计|基于springboot + vue电影院购票管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
闭上眼让寒冷退却4 分钟前
知识库发布按钮引发的查询版本发布状态(轮询?——>调用后端接口)以及api接口设计学习
java·前端·javascript
q_19132846956 分钟前
基于SpringBoot2+Vue2的企业合作与活动管理平台
java·vue.js·经验分享·spring boot·笔记·mysql·计算机毕业设计
sleeppingfrog8 分钟前
konva实现canvas画图基础版本
前端·javascript·css
jingling55512 分钟前
Mark3D | 用 Mars3D 实现一个炫酷的三维地图
前端·javascript·3d·前端框架·html
前端白袍12 分钟前
Vue:如何实现日志导出下载功能?
javascript·vue.js·ecmascript
这是个栗子15 分钟前
【前端知识点总结】请求/响应拦截器的介绍
前端·拦截器
Y‍waiX‍‍‮‪‎⁠‌‫‎‌‫‬15 分钟前
【npm】从零到一基于Vite+vue3制作自己的Vue3项目基础的npm包并发布npm
前端·npm·node.js
专注VB编程开发20年18 分钟前
vb.net宿主程序通过统一接口直接调用,命名空间要一致
服务器·前端·.net