《Vue3 四》Vue 的组件化

组件化:将一个页面拆分成一个个小的功能模块,每个功能模块完成自己部分的独立的功能。任何应用都可以被抽象成一棵组件树。

Vue 中的根组件:

Vue.createApp() 中传入对象的本质上就是一个组件,称之为根组件(APP 组件)。

复制代码
<div id="app">
    <div>{{message}}</div>
</div>

<script>
	// 组件
	const APP = {
	    data() {
	        return {
	            message: 'Hello Vue',
	        }
	    },  
	}   
	// Vue.createApp() 中传入对象的本质上就是一个组件,称之为根组件(APP 组件)
	const app = Vue.createApp(APP)
	app.mount('#app')
</script>

注册组件:

每个组件都可以拥有自己的模板、样式、代码逻辑。注册组件分为两种:

  1. 全局组件:在任何其他的组件中都可以使用的组件。
  2. 局部组件:只有在注册的组件中才能使用的组件。

只要注册了全局组件,即使代码中没有用到,Webpack 等打包工具依然会对其进行打包;局部组件如果没有用到,将不会对其进行打包。

注册全局组件:

全局组件需要使用全局创建的 app 来注册,通过 app.component() 方法传入组件名称、组件对象即可注册一个全局组件。

复制代码
<div id="app">
    <!-- 使用全局组件 -->
    <product-item></product-item>
</div>

<script>
	const app = Vue.createApp()
	
	// 创建组件对象
	const productItem = {
	    template: '<div>我是一个组件</div>'
	}
	// 注册全局组件
	app.component('product-item', productItem)
	
	app.mount('#app')
</script>

组件的 template 模板还有另外一种写法。

复制代码
<!-- 编写组件模板 -->
<template id="product-item-template">
    <div>我是一个组件</div>
</template>

<div id="app">
    <product-item></product-item>
</div>

<script>
const app = Vue.createApp()

const productItem = {
    // 使用组件模板
    template: '#product-item-template'
}
app.component('product-item', productItem)

app.mount('#app')
</script>

注册局部组件:

局部组件通过 components 属性选项来进行注册,该选项对应的是一个对象,对象中的键值对是 组件名称:组件对象

复制代码
<div id="app">
    <!-- 使用局部组件 -->
    <product-item></product-item>
</div>

<script>
	// 创建组件对象
	const productItem = {
	    template: '<div>我是一个组件</div>'
	}
	
	const app = Vue.createApp({
	    // 注册局部组件
	    components: {
	        'product-item': productItem,
	    }
	})
	app.mount('#app')
</script>

组件的 template 模板还有另外一种写法。

复制代码
<!-- 编写组件模板 -->
<template id="product-item-template">
    <div>我是一个组件</div>
</template>

<div id="app">
    <product-item></product-item>
</div>

<script>
const app = Vue.createApp({
    components: {
        'product-item': {
        	// 注册组件模板
            template: '#product-item-template',
        }
    }
})

app.mount('#app')
</script>

定义组件名称的方式:

定义组件名称的方式有两种:

  1. 使用 kebab-case 短横线分隔符。

    复制代码
    // 使用
    <product-item></product-item>
    
    // 定义
    app.component('product-item', productItem)
  2. 使用 PascalCase 大驼峰标识符。

    复制代码
    // 使用。在原生 HTML 文件中这么写是无效的,因为 HTML 不区分大小写;不过在 Vue 文件中就没有这个问题了
    <productItem></productItem>
    
    // 定义
    app.component('productItem', productItem)
相关推荐
蓝胖子的多啦A梦5 小时前
Vue3 (数组push数据报错) 解决Cannot read property ‘push‘ of null报错问题
前端·vue3·push·数组数据
有梦想的攻城狮2 天前
从0开始学vue:vue3和vue2的关系
前端·javascript·vue.js·vue3·vue2
全栈小55 天前
【前端】Vue3+elementui+ts,TypeScript Promise<string>转string错误解析,习惯性请出DeepSeek来解答
前端·elementui·typescript·vue3·同步异步
西哥写代码7 天前
基于cornerstone3D的dicom影像浏览器 第二十七章 设置vr相机,复位视图
3d·vue3·vr·cornerstonejs
西哥写代码8 天前
基于cornerstone3D的dicom影像浏览器 第二十五章 自定义VR调窗工具
javascript·3d·vue3·vr·cornerstonejs
放逐者-保持本心,方可放逐9 天前
浅谈 JavaScript 性能优化
开发语言·javascript·性能优化·vue3·v-memo·vue3性能优化·v-once
西哥写代码10 天前
基于cornerstone3D的dicom影像浏览器 第二十四章 显示方位、坐标系、vr轮廓线
javascript·3d·vue3·vr·dicom·cornerstonejs
西哥写代码11 天前
基于cornerstone3D的dicom影像浏览器 第二十三章 mpr预设窗值与vr preset
javascript·3d·vue3·dicom·cornerstonejs
linweidong12 天前
汇量科技前端面试题及参考答案
webpack·vue3·react·前端面试·hooks·懒加载·flex布局
EndingCoder13 天前
从零基础到最佳实践:Vue.js 系列(9/10):《单元测试与端到端测试》
前端·javascript·vue.js·性能优化·单元测试·vue3