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的…

前端组件标准化专家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;提高代码的可维护性和扩展性。 结构 …

【大模型】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 编…

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 的设计目的是让分布式系…

【LeetCode】5. 贪心算法:买卖股票时机

太久没更了&#xff0c;抽空学习下。 看一道简单题。 class Solution:def maxProfit(self, prices: List[int]) -> int:cost -1profit 0for i in prices:if cost -1:cost icontinueprofit_ i - costif profit_ > profit:profit profit_if cost > i:cost iret…

01vue3实战-----前言

01vue3实战-----前言 1.大前端时代2.技术栈3.项目大致展示4.创建Vue项目4.1Vue CLI4.2create-vue 5.参考资料 1.大前端时代 前端移动端iOS/android开发桌面端 window/mac 常用的electron框架来开发其它平台:穿戴设备、车载系统(智能汽车)、VR、AR…web3方向 2.技术栈 开发工…

使用request库实现接口测试-笔记

目录 request库request库的安装和查验request发送请求的语法获取响应结果指定内容案例 Unittest框架集成Requests库Unittest框架语法Unittest框架基础代码案例 request库 request库是python编写的&#xff0c;基于urllib的HTTP库,使用方便。 request库的安装和查验 安装&…

快速傅里叶离散变换FFT (更新中)

声明&#xff1a;参考了 y y c yyc yyc 的 blog 和 PPT (from smwc) &#xff0c;以及 w z r wzr wzr 的 blog 。 目录 Part 1 多项式Part 2 FFT概论Part 3 点值与插值Part 4 复数&#xff0c;单位根Part 5 Part 1 多项式 定义&#xff1a;对于有限数列 A 0 A_{0} A0​~ n…

【C++】STL——list的使用

目录 &#x1f495;1.带头双向链表List &#x1f495;2.list用法介绍 &#x1f495;3.list的初始化 &#x1f495;4.size函数与resize函数 &#x1f495;5.empty函数 &#x1f495;6.front函数与back函数 &#x1f495;7.push_front,push_back,pop_front,pop_back函数…