Vue.js组件开发

Vue.js 是一个用于构建用户界面的渐进式 JavaScript 框架,组件化开发是 Vue.js 的核心特性之一,它允许你将页面拆分成多个小的、可复用的组件,从而提高代码的可维护性和可复用性。以下是关于 Vue.js 组件开发的详细介绍:

1. 组件基础


全局组件注册

全局组件可以在应用的任何地方使用。

- 定义一个全局组件

// 定义一个全局组件
Vue.component('my-component', {template: '<div>这是一个全局组件</div>'
});// 创建 Vue 实例
new Vue({el: '#app'
});

- 使用全局组件

<div id="app"><!-- 使用全局组件 --><my-component></my-component>
</div>

局部组件注册

局部组件只能在注册它的组件内部使用。

// 创建 Vue 实例
new Vue({el: '#app',components: {// 定义一个局部组件'my-local-component': {template: '<div>这是一个局部组件</div>'}}
});

- 使用局部组件

<div id="app"><!-- 使用局部组件 --><my-local-component></my-local-component>
</div>

2. 组件的数据和方法

组件可以有自己的数据和方法,就像 Vue 实例一样。
 

Vue.component('my-component', {data: function () {return {message: 'Hello, Vue.js 组件!'};},methods: {showMessage: function () {alert(this.message);}},template: '<div><button @click="showMessage">点击显示消息</button></div>'
});new Vue({el: '#app'
});
<div id="app"><my-component></my-component>
</div>

3. 组件的 props

`props` 是组件用来接收外部数据的一种方式。

Vue.component('child-component', {props: ['message'],template: '<div>{{ message }}</div>'
});new Vue({el: '#app',data: {parentMessage: '这是从父组件传递过来的消息'}
});

传递数据给子组件

<div id="app"><!-- 传递数据给子组件 --><child-component :message="parentMessage"></child-component>
</div>

4. 组件的事件

组件可以通过自定义事件向父组件发送消息。

Vue.component('child-component', {template: '<button @click="sendMessage">点击发送消息</button>',methods: {sendMessage: function () {// 触发自定义事件this.$emit('custom-event', '这是子组件发送的消息');}}
});new Vue({el: '#app',methods: {handleEvent: function (message) {alert(message);}}
});

监听子组件的自定义事件

<div id="app"><!-- 监听子组件的自定义事件 --><child-component @custom-event="handleEvent"></child-component>
</div>

5. 单文件组件(SFC)

在实际开发中,通常会使用单文件组件(`.vue` 文件)来开发组件,它将模板、脚本和样式封装在一个文件中。

定义组件 MyComponent.vue 

<template><div><h1>{{ message }}</h1><button @click="showMessage">点击显示消息</button></div>
</template><script>
export default {data() {return {message: 'Hello, 单文件组件!'};},methods: {showMessage() {alert(this.message);}}
};
</script><style scoped>
h1 {color: blue;
}
</style>

使用自定义组件 main.js

import Vue from 'vue';
import MyComponent from './MyComponent.vue';new Vue({el: '#app',components: {MyComponent},template: '<MyComponent />'
});

6. 组件的生命周期钩子

组件有自己的生命周期,你可以在不同的生命周期钩子中执行特定的操作。

Vue.component('my-component', {template: '<div>这是一个组件</div>',beforeCreate() {console.log('组件实例初始化之后,数据观测和 event/watcher 事件配置之前被调用');},created() {console.log('实例已经创建完成之后被调用');},beforeMount() {console.log('模板编译挂载之前被调用');},mounted() {console.log('模板编译挂载之后被调用');},beforeUpdate() {console.log('数据更新之前被调用');},updated() {console.log('数据更新之后被调用');},beforeDestroy() {console.log('实例销毁之前被调用');},destroyed() {console.log('实例销毁之后被调用');}
});new Vue({el: '#app'
});

以上就是 Vue.js 组件开发的基本内容,通过组件化开发,你可以更高效地构建复杂的前端应用。

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

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

相关文章

备考蓝桥杯嵌入式7——ADC电压采集

目录 ADC电压采集 代码书写 ADC电压采集 ADC的含义就是将一个范围内的电压映射成为数字传入进来。举个例子&#xff0c;当我们想要做一个非常简单的电压测量计的时候&#xff0c;使用ADC就会将我们的模拟电压信号转化为数字电压信号。 我们的板子上有两个电压采集旋钮&#…

【大模型实战】0代码基于DeepSeek-R1搭建本地知识库,打造专属智能助手

【大模型实战】0代码基于DeepSeek-R1搭建本地知识库,打造专属智能助手 一、ollama下载与安装二、部署deepseek私有模型三、部署embedding模型四、可视化操作工具(1)下载与安装工具(2)部署安装的模型(3) 添加知识库(4)添加智能体助手(5) 助手问答一、ollama下载与安装…

Java进阶(vue基础)

目录 1.vue简单入门 ?1.1.创建一个vue程序 1.2.使用Component模板(组件&#xff09; 1.3.引入AXOIS ?1.4.vue的Methods&#xff08;方法&#xff09; 和?compoted&#xff08;计算&#xff09; 1.5.插槽slot 1.6.创建自定义事件? 2.Vue脚手架安装? 3.Element-UI的…

Java 面试真题

本题适合一到三年 Java 开发 &#xff0c;以下问题都是按照原面试官提问记录 文章目录 我要进大厂系列面试题二面 我要进大厂系列面试题 全部真题&#xff0c;欢迎投稿你的面试经验。 本篇涉及基础较多&#xff0c;但要耐性看完。 JVM内存模型垃圾回收器用的哪个gc各个算法…

前端组件标准化专家Prompt指令的最佳实践

前端组件标准化专家Prompt 提示词可作为项目自定义提示词使用&#xff0c;本次提示词偏向前端开发的使用&#xff0c;如有需要可适当修改关键词和示例 推荐使用 Cursor 中作为自定义指令使用Cline 插件中作为自定义指令使用在力所能及的范围内使用最好的模型&#xff0c;可以…

windows环境下安装Python3.13.2

1. 下载 Python 3.13.2 访问 Python 官方网站。 在下载页面中&#xff0c;找到 Python 3.13.2 的版本。如果下载其他版本&#xff0c;可以点击页面底部的“Previous releases”链接&#xff0c;查找旧版本。 选择适合 Windows 的安装包&#xff08;通常是 .exe 文件&#xff…

专业学习|通过案例了解蒙特卡罗模拟实操步骤与含义

一、蒙特卡罗模拟介绍 蒙特卡罗模拟&#xff08;Monte Carlo Simulation&#xff09;是一种基于随机采样的数值计算方法&#xff0c;用于解决具有不确定性或复杂概率分布的问题。其核心思想是通过多次随机抽样来逼近系统的行为或目标函数的真实值&#xff0c;进而对系统进行评估…

全面解析文件上传下载删除漏洞:风险与应对

在数字化转型的时代&#xff0c;文件上传、下载与删除功能已经成为各类应用程序的标准配置&#xff0c;从日常办公使用的协同平台&#xff0c;到云端存储服务&#xff0c;再到社交网络应用&#xff0c;这些功能在给用户带来便捷体验、显著提升工作效率的同时&#xff0c;也隐藏…

常用的ADC芯片有哪些

硬件工程师在设计电路时经常需要用到模数转换器&#xff08;Analog-to-Digital Converter, ADC&#xff09;芯片来将模拟信号转换为数字信号。市场上有许多不同品牌和型号的ADC芯片可供选择。以下是一些知名品牌的ADC芯片及其特点&#xff1a; 1.Texas Instruments (TI) •特点…

Redis的通用命令

⭐️前言⭐️ 本文主要介绍Redis的通用命令 &#x1f349;欢迎点赞 &#x1f44d; 收藏 ⭐留言评论 &#x1f349;博主将持续更新学习记录收获&#xff0c;友友们有任何问题可以在评论区留言 &#x1f349;博客中涉及源码及博主日常练习代码均已上传GitHub &#x1f4cd;内容导…

「全网最细 + 实战源码案例」设计模式——策略模式

核心思想 策略模式&#xff08;Strategy Pattern&#xff09;是一种行为型设计模式&#xff0c;用于定义一系列算法或策略&#xff0c;将它们封装成独立的类&#xff0c;并使它们可以相互替换&#xff0c;而不影响客户端的代码&#xff0c;提高代码的可维护性和扩展性。 结构 …

k8m 是一款轻量级、跨平台的 Kubernetes 仪表板

k8m 是一款轻量级、跨平台的 Kubernetes 仪表板&#xff0c;专注于简化集群管理与 AI 功能的集成。其最新版本 v0.0.28 于 2025 年 2 月 4 日发布&#xff0c;包含多项功能优化和安全增强。以下是该版本的核心更新内容&#xff1a; 1. 安全性与认证优化1 动态 JWT 密钥配置&…

【大模型】AI 辅助编程操作实战使用详解

目录 一、前言 二、AI 编程介绍 2.1 AI 编程是什么 2.1.1 为什么需要AI辅助编程 2.2 AI 编程主要特点 2.3 AI编程底层核心技术 2.4 AI 编程核心应用场景 三、AI 代码辅助编程解决方案 3.1 AI 大模型平台 3.1.1 AI大模型平台代码生成优缺点 3.2 AI 编码插件 3.3 AI 编…

python开发:爬虫示例——GET和POST请求处理

一、Get请求 import json import requests#输入示例&#xff1a;urlhttps://www.baidu.com #RequestHeader:F12标头-请求标头-原始-复制到这&#xff08;忽略第一句&#xff09; def GetRequest(url,RequestHeader""):try:dic{}RequestHeaderList RequestHeader.s…

nodejs:js-mdict 的下载、安装、测试、build

js-mdict 项目的目录结构&#xff1a;js-mdict 项目教程 js-mdict 下载地址: js-mdict-master.zip 先解压到 D:\Source\ js-mdict 6.0.2 用了 ts (TypeScript) 和 Jest&#xff0c;增加了应用开发的难度&#xff0c;因为先要了解 ts 和 Jest。 参阅&#xff1a;测试与开发&a…

DeepSeek辅助学术写作【对比概念】效果如何?

DeepSeek-R1在论文写作细节方面有很多好的应用。我们下面通过具体案例来逐一展示这些功能。 DeepSeek-R1在提问方面&#xff0c;可以简化提示词也能给出精准得答案。我们来一探究竟&#xff01; 对比概念(功能指数:★★★★★) DeepSeek-R1在概念对比方面的功能也非常强大。由…

单节锂电池外部供电自动切换的电路学习

文章目录 前言一、原理分析&#xff1a;①当VBUS处有外部电源输入时②当VBUS处无外部电源输入时 二、器件选择1、二极管2、MOS管3、其他 总结 前言 学习一种广泛应用的锂电池供电自动切换电路 电路存在外部电源时&#xff0c;优先使用外部电源供电&#xff0c;并为电池供电&…

Linux系统 环境变量

环境变量 写在前面概念查看环境变量main函数的参数argc & argvenv bash环境变量 写在前面 对于环境变量&#xff0c;本篇主要介绍基本概念及三四个环境变量 —— PATH、HOME、PWD。其中 PATH 作为 “ 敲门砖 ”&#xff0c;我们会更详细讲解&#xff1b;理解环境变量的全局…

107,【7】buuctf web [CISCN2019 华北赛区 Day2 Web1]Hack World

这次先不进入靶场 看到红框里面的话就想先看看uuid是啥 定义与概念 UUID 是 Universally Unique Identifier 的缩写&#xff0c;即通用唯一识别码。它是一种由数字和字母组成的 128 位标识符&#xff0c;在理论上可以保证在全球范围内的唯一性。UUID 的设计目的是让分布式系…

cesium传感器和大量线问题记录

1&#xff1a;场景图初始加载大量轨道线。 // 创建几何体实例const geometry new Cesium.PolylineGeometry({positions: positions,width: 1.0, // 轨道线的宽度});const geometryInstance new Cesium.GeometryInstance({id: res.id,geometry: geometry,});// 创建材质实例co…