Vue单文件组件

news/2024/10/26 15:14:47/

单文件组件

单文件组件是在开发中用的比较多的,它的后缀都是.vue结尾的

既然是.vue结尾,那么直接给浏览器是不能运行的,.vue文件是vue团队打造的特殊文件,想让.vue文件让浏览器识别并且运行,需要对它进行处理加工成纯粹的js文件,那么浏览器就认识了

常用的处理加工.vue文件有两种方式

1 借助webpack:自己找一些插件完成整个编译流程

2 借助脚手架:这是vue官方提供的,它其实就是vue的团队拿着webpack打造完的流程和编译整个环境,我们直接拿来用即可

所以第二种方式明显是更简单和方便的,但是这里先不使用脚手架,直接单独看看.vue文件里面的代码都是什么,应该怎么写,至于怎么运行,以后使用脚手架即可

1 创建组件

接下来就开始编写单文件组件了,首先创建一个学校组件(School.vue)

2 安装插件vetur

开始编写vue代码之前,如果是使用vscode进行开发的,推荐一个插件:

它会帮助我们识别.vue文件,并且进行代码提示和高亮显示等功能,可以大幅度提高开发效率

安装步骤很简单,打开vscode,插件里面搜索vetur,点击安装即可,安装完成后建议重启vscode

3 .vue单文件代码结构

类似于html,一个html中有js,html,css基本代码,对于vue来说也是基本一样的

它有三个核心(基本)标签:

1 :组件的结构

2 :组件交互相关的代码(数据,方法)

3 :组件的样式,如果不需要可以不写

写完组件后,我们应该暴露组件,方便给其他组件使用

暴露方式一般有三种,我们一般使用最后一种,也就是默认暴露,因为有些时候当我们暴露的东西是一个的时候,我们往往喜欢默认暴露,因为使用默认暴露,用的时候比较简单,直接import xxx from xxx就行了

1 export xxx分别暴露

2 export {xxx} 统一暴露

3 export default xxx 默认暴露

使用简写Vue.extend的方式,直接暴露组件的配置对象,并且用name标识组件名称,最好和文件名称保持一致

到了这里,一个单文本组件就写完了,看着结构就很清晰,template里面写的是组件的结构,script里面是组件的交互,style里面是组件的样式,一个标准的组件就完成了

注:如果安装了上面的插件,就不用自己写标签了,可以通过快捷键(<v)自动生成代码结构

打一个尖括号,然后打个v,回车即可

生成的结构如下

4 完善单文件组件结构

上面已经完成了一个完整的单文本组件(school.vue),接下来继续完善单文件组件的结构

首先复制一个Student组件,进行一些更改,首先不要样式,那么就可以去掉style标签,不要单击事件,那么就可以去掉methods属性,改掉name属性为Student,最终代码如下所示

基本的组件就写到这就行了,两个组件就够了,接下来由一个重量级的人物,那就是App.vue,它用来管理全部的组件,由vm直接调用

App.vue

负责汇总全部的组件 ,在这个文件中,我们要注册组件,在注册之前需要引用组件

在脚手架里面引入组件的时候组件的.vue后缀可以写也可以不写,我个人喜欢写完整的组件名称+后缀

三部曲:1 引用组件 2 注册组件 3 使用组件(展示组件元素)

到了这个App.vue就写好了,但是所有的组件都要听从vm分配管理,所以接下来还要创建vm

main.js

一般都会创建一个main.js,有的脚手架叫做index,作用都是一样的

它的主要作用就是引入App.vue,并且创建vm实例注册App组件,所以它也叫入口文件

template可以直接在这里写,也可以在页面上定义一个div,里面写组件标签

这里就有个问题,我们的el是一个id叫root的容器,那么容器在哪?所以需要再创建一个叫index.html的文件

index.html

主要用来存放根容器

全部写好之后就可以打开文件在浏览器上查看,发现报错了,浏览器不能直接支持ES6的模板化语法

我们代码是没有问题的,只是浏览器不认识,如果使用脚手架,就能马上运行起来,这里这是演示整个流程


http://www.ppmy.cn/news/349103.html

相关文章

万字长文+示例代码详解DDD中常用的架构(含代码示例)

目录 分层架构&#xff08;Layered Architecture&#xff09; 概念 示例代码 总结 领域驱动设计的六边形架构&#xff08;Hexagonal Architecture&#xff09; 概念 示例代码 总结 CQRS&#xff08;Command Query Responsibility Segregation&#xff09; 概念 示例…

AntDB 企业增强特性介绍——分布式集群下强一致备份恢复技术

AntDB 使用 barman 实现数据的备份和恢复&#xff0c;但是集群节点部署在多台主机上&#xff0c;每个节点单独备份和恢复。多台服务器时钟不同步的情况下同时备份后&#xff0c; 无法真正实现基于时间点的数据完全和不完全恢复。AntDB 提供基于时间点的全局一致性备份恢复。 A…

ShedLock的使用

通常&#xff0c;我们在公司里的部分对外服务都是多集群多节点部署的。同时我们可能一些拆分的不是很细的服务&#xff0c;里面混杂着一些定时任务。 而定时任务中&#xff0c;有些业务为了防止同一时间并发操作&#xff0c;我们就用到了“分布式锁”。 一般最简单的方法我们就…

mac docker 安装 ES

一. docker 安装 ES 1. 下载镜像 docker pull elastcisearch:8.7.1 2. 启动镜像 docker run -d --name elasticsearch -p 9200:9200 -p 9300:9300 -e "discovery.typesingle-node" -e ES_JAVA_OPTS"-Xms256m -Xmx256m" elasticsearch:8.7.1 参数说明…

python使用pymysql来操作MySQL

例子1 from pymysql import Connection# 构建到MySQL数据库的连接 conn Connection(host"localhost",port3306,user"root",password"123456",autocommitTrue # 设置自动提交 )print(conn.get_server_info())# 要执行SQL查询必须要先获得游标对象…

宏晶微MS2109高清视频采集芯片资料

MS2109是一款高清视频传采集晶片&#xff0c;内部集成USB2.0控制器和数据收发模块&#xff0c;HDMI RX模块和音视频处理模块。MS2109可以将HDMI接口输出的音视频信号通过USB接口传送到PC&#xff0c;智慧型手机或者平板电脑预览或者采集。USB视频符合UVC规范&#xff0c;音频符…

GSCOOLINK GSV2006替CH6002 HDMI2.0接口芯片

GSV2006是100%纯国产产品 GSV2006是 HDMI2.0/HDCP2.2 2x4 矩阵, 支持DownScaler, CSC 及音频分离和音频嵌入&#xff0c;支持ARC 及CEC 功能。 目标应用&#xff1a;HDMI2.0矩阵&#xff0c;分离器。 功能特征 1、2进4出 2、18 Gbps 3、灵活的HDCP 2.2/1.4支持 4、双路音频…

《嵌入式 – GD32开发实战指南》第21章 I2C

开发环境&#xff1a; MDK&#xff1a;Keil 5.30 开发板&#xff1a;GD32F207I-EVAL MCU&#xff1a;GD32F207IK 21.1 I2C工作原理 21.1.1 I2C串行总线概述 I2C总线是PHLIPS公司推出的一种双线式半双工串行总线&#xff0c;是具备多主机系统所需的总线裁决和高低速器件同步功…