Vue 单文件组件的基础入门指南

        本文是我2年前做的一个学习小demo,在这里分享一下

        希望对想要学习Vue的小伙伴能有一丢丢的小帮助~_~

1 Vue CLI

     Vue CLI (opens new window)是一个基于Vue.js进行快速开发的完整系统。

  • 这里我使用 Vue CLI 生成了一个Vue项目,命令为:vue create 自定义项目名称
  • 生成的Vue项目目录结构如下👇【目录生成命令:tree > /f E:result.txt】
│  .gitignore  这个文件的作用就是告诉Git哪些文件不需要添加到版本管理中
│  babel.config.js 项目范围配置
│  jsconfig.json 目录中存在jsconfig.json文件表示该目录是JavaScript项目的根目录
│  package.json  定义了项目的所有依赖,包括开发时依赖和发布时依赖
│  README.md     说明文件
│  vue.config.js vue的一个配置文件
│  yarn.lock     作用是锁定唯一版本
├─node_modules  这个目录存放的是项目的所有依赖,即 npm install 命令下载下来的文件  
├─public
│      favicon.ico  ico图标文件
│      index.html  项目的首页,入口页,也是整个项目唯一的HTML页面
│      
└─src│  App.vue  是一个Vue组件,也是项目的第一个Vue组件│  main.js  相当于Java中的main方法,是整个项目的入口js│  ├─assets  用来存放资源文件│      logo.png  图片文件│      └─components  用来存放组件(一些可复用,非独立的页面)HelloWorld.vue 项目自带的HelloWorld组件TodoItem.vue   自定义开发的组件示例

2 组件中包含三部分内容

<template>
这里写的是html代码
</template><script>
这里写的是js代码
</script><style>
这里写的是css代码  
如果style标签里加个scoped属性,它表示style里面所写的css样式只会对本文件生效,别的地方用是不好使的
</style>

3 源码示例

  • TodoItem.vue

这个是开发的一个单文件组件示例代码

<!--这里写的是html代码 -->
<template><li class="item"><!-- checkbox复选框 --><input type="checkbox" v-model="yuan" ><!-- slot是vue中的插槽,插槽用于决定将所携带的内容,插入到指定的某个位置 --><!-- 通过插槽jialin将checkbox选中状态(true或false)checked值传递过去,在App.vue的中使用了插槽v-slot:jialin --><slot name="jialin" v-bind="{yuan}"></slot></li>
</template><!--这里写的是js代码 -->
<script>
export default {props:['item'],data(){return{// isCheck和<input type="checkbox" v-model="isCheck">中的v-model进行双向绑定yuan:false,}}
}
</script><!--这里写的是css代码,加上scoped属性表示:style里面所写的css样式只会对本文件中<template>模板中的html代码生效,别的地方用是不好使的 -->
<style scoped>.item {color: red;}
</style>
  • App.vue

这个是开发的一个单文件组件示例代码

<!--这里写的是html代码 -->
<template><li class="item"><!-- checkbox复选框 --><input type="checkbox" v-model="yuan" ><!-- slot是vue中的插槽,插槽用于决定将所携带的内容,插入到指定的某个位置 --><!-- 通过插槽jialin将checkbox选中状态(true或false)checked值传递过去,在App.vue的中使用了插槽v-slot:jialin --><slot name="jialin" v-bind="{yuan}"></slot></li>
</template><!--这里写的是js代码 -->
<script>
export default {props:['item'],data(){return{// isCheck和<input type="checkbox" v-model="isCheck">中的v-model进行双向绑定yuan:false,}}
}
</script><!--这里写的是css代码,加上scoped属性表示:style里面所写的css样式只会对本文件中<template>模板中的html代码生效,别的地方用是不好使的 -->
<style scoped>.item {color: red;}
</style>
  • App.vue

这个是开发的一个单文件组件示例代码

<!--这里写的是html代码 -->
<template><div id="app">{{msg}}<!-- div代码块-start --><div><!-- input输入框,输入的内容会赋值给info --><input type="text" v-model="info"><!-- button添加按钮,鼠标单击事件(v-on:click)中定义了一个handleClick方法 --><button ref="inputPosition" v-on:click="handleClick">添加</button></div><!-- div代码块-end --><!-- ul代码块-start --><ul><!-- 通过v-for循环获取list数组中的内容,每次获取内容以item变量输出 --><todo-item v-for="flm in list" :key="flm"><!-- 通过v-slot:jialin插槽传递checkbox是否选中的对象,选中时itemProps.checked=true,未选中时itemProps.checked=false --><template v-slot:jialin="itemProps"><!-- {{flm}}获取循环的内容 --><span :style="{fontSize:'20px',color:itemProps.yuan?'red':'blue'}">{{flm}}</span></template></todo-item></ul><!-- ul代码块-end --></div>
</template><!--这里写的是js代码 -->
<script>
// 引用TodoItem组件
import TodoItem from './components/TodoItem.vue'export default {name: 'app',//在这里初始化数据data(){return{msg:'单文件组件',info:'',list:[],}},//在这里编写方法methods:{//button按钮的单击事件方法handleClick(){if(this.info==''){alert("请先写点啥呗")return;}//向list数组中添加input框中输入的info内容this.list.push(this.info)//清空input框中输入的info内容this.info = ''}},//在这里注册组件components: {TodoItem,}
}
</script><!--这里写的是css代码 -->
<style></style>

4 最终运行效果

5 下载源码

下载源码icon-default.png?t=N7T8https://github.com/fenglm2021/fenglm-vue-cli.git

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/320982.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

C语言中指针变量如何使用

一、指针变量的定义与声明 1.1 定义 指针变量是用来存储另一个变量的内存地址的变量。在C语言中&#xff0c;指针变量的类型是指向某个类型的指针。例如&#xff0c;int *p; 表示一个整型指针变量p。 1.2 声明 指针变量的声明分为两种形式&#xff0c;一种是直接声明&#…

字节跳动 Spark 支持万卡模型推理实践

摘要&#xff1a;本文整理自字节跳动基础架构工程师刘畅和字节跳动机器学习系统工程师张永强在本次 CommunityOverCode Asia 2023 中的《字节跳动 Spark 支持万卡模型推理实践》主题演讲。 背景介绍 在云原生化的发展过程中 Kubernetes 由于其强大的生态构建能力和影响力&…

多线程基础入门【Linux之旅】——下篇【死锁,条件变量,生产消费者模型,信号量】

目录 一&#xff0c;死锁 1. 死锁的必要条件 2&#xff0c;避免死锁 二&#xff0c;条件变量 同步概念与竞态条件 条件变量——初始化 静态初始化 动态初始化 pthread_cond_destroy (销毁) pthread_cond_wait (等待条件满足) pthread_cond_signal (唤醒线程) ph…

2023 北京国炬软件年度总结—JeecgBoot与敲敲云

2023年对于北京国炬软件公司来说是一个充满成就和创新的一年。 我们成功推出了APass零代码平台—敲敲云&#xff0c;一款能够在5分钟内搭建应用的新一代零代码平台。自2023年1月1号正式上线以来&#xff0c;敲敲云已经突破了10万注册用户&#xff0c;并与数百家战略合作伙伴达…

Rust使用gRPC

需要先安装protoc&#xff08;Protocol Buffers Compiler&#xff09;&#xff0c;可据此Protobuf Compiler Installation下载 第一步&#xff1a;创建项目 创建两个新的Rust项目&#xff0c;分别作为服务端与客户端&#xff1a; cargo new rust_grpc_servercargo new rust_grp…

【python测验】数字游戏 取模数 数位dp

这题目看得人感觉要失去梦想…… 题目&#xff1a; 看不懂也做不出来&#xff0c;python方法未知&#xff0c;记录几个可供参考的帖子。 LightOJ 1068 Investigation 算法提高篇–动态规划&#xff08;八&#xff09;&#xff1a;数位DP&#xff08;3&#xff09;

【软件测试】2024年准备中/高级测试岗技术面试...

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 1、软件测试基础知…

两阶段提交协议三阶段提交协议

两阶段提交协议 分布式事务是指会涉及到操作多个数据库的事务,在分布式系统中&#xff0c;各个节点之间在物理上相互独立&#xff0c;通过网络进行沟通和协调。 XA 就是 X/Open DTP 定义的交易中间件与数据库之间的接口规范&#xff08;即接口函数&#xff09;&#xff0c;交易…

Spring——Spring基于注解的IOC配置

基于注解的IOC配置 学习基于注解的IOC配置&#xff0c;大家脑海里首先得有一个认知&#xff0c;即注解配置和xml配置要实现的功能都是一样的&#xff0c;都是要降低程序间的耦合。只是配置的形式不一样。 1.创建工程 1.1 pom.xml <?xml version"1.0" encoding…

TP-GMM

Task-parameterized Gaussian mixture model (TP-GMM) 对于一组示教数据 ξ ∈ R D N \bm{ξ} ∈R^{DN} ξ∈RDN&#xff0c;从不同的坐标系去观测它 X t ( j ) A t , j − 1 ( ξ t − b t , j ) X^{(j)}_t\bm{A}^{-1}_{t,j}(\bm{ξ}_t-\bm{b}_{t,j}) Xt(j)​At,j−1​(ξ…

多通道病虫害分子检测仪-百科科普知识

在农业科技日新月异的今天&#xff0c;病虫害防治已经成为现代农业的重要一环。为了更精准、更快速地检测和防治病虫害&#xff0c;多通道病虫害分子检测仪应运而生&#xff0c;成为守护绿色家园的"黑科技"。 WX-XC1多通道病虫害分子检测仪是一款集成了分子生物学、…

如何使用Cloudreve+Cpolar搭建个人PHP云盘系统并发布公网可访问

文章目录 1、前言2、本地网站搭建2.1 环境使用2.2 支持组件选择2.3 网页安装2.4 测试和使用2.5 问题解决 3、本地网页发布3.1 cpolar云端设置3.2 cpolar本地设置 4、公网访问测试5、结语 1、前言 自云存储概念兴起已经有段时间了&#xff0c;各互联网大厂也纷纷加入战局&#…