vue2———组件

一个简单的组件

组件进行注册并使用

结果:

在进行对组件的学习时遇见一些问题:

1、组件的命名

解决方法:

 组件的命名

Vue.js 组件的命名遵循一些最佳实践,这些实践有助于保持代码的清晰和一致性。

  • 多单词命名:Vue 官方推荐组件名应该总是多单词的,以防止与现有的 HTML 元素或未来的 HTML 元素冲突。这可以通过短横线分隔(kebab-case)或驼峰式命名(PascalCase,但在模板中需要使用短横线分隔)来实现。

    • 短横线分隔(kebab-case):在 .vue 文件名、组件注册名(局部或全局)以及模板中使用时,都使用短横线分隔。例如,my-component.vue 和 <my-component />

    • 驼峰式命名(PascalCase):在 JavaScript 中注册组件时可以使用驼峰式命名,但在模板中引用时仍需使用短横线分隔的形式。Vue 模板编译器会自动将短横线分隔的组件名转换为对应的驼峰式命名,以便在 JavaScript 中引用。

  • 避免与 HTML 元素冲突:确保你的组件名不会与现有的 HTML 元素或未来的 HTML 元素冲突。

  • 明确意图:组件名应该能够清晰地表达组件的用途或功能。

2、对组件注册后的使用

首先先调用一下,import xxx from xxx

注意:from的地址需要注意在同一目录(eg:

之后注册在components中,

然后在template中v-bind也就是  :...

Vue.js 2.x 中的组件是构建用户界面的可复用元素。它们可以包含自己的模板、逻辑(JavaScript)和样式(CSS),并且可以接收外部传入的数据(通过 props)以及向外部发送事件(通过 events)。组件的使用极大地提高了代码的可复用性、可维护性和组织性。下面我将详细讲解 Vue 2.x 中的组件的几个方面。

1. 组件的注册

Vue 组件有两种注册方式:全局注册和局部注册。

  • 全局注册:注册的组件可以在任何新创建的 Vue 根实例的模板中使用。
Vue.component('my-component', {  
  // 选项...  
})
  • 局部注册:注册的组件只能在注册它的实例/组件的模板中使用。
var Child = {  
  // 选项...  
}  
  
new Vue({  
  el: '#app',  
  components: {  
    'my-component': Child  
  }  
})

2. 组件的选项

Vue 组件包含一系列的选项,这些选项定义了组件的行为和外观。

  • data:组件的数据对象。Vue 会将 data 对象的属性加入到组件的响应式系统中。
  • props:一个包含属性名称和配置的数组或对象,用于接收来自父组件的数据。
  • computed:计算属性,基于它们的响应式依赖进行缓存。只有当相关响应式依赖发生改变时,它们才会重新求值。
  • methods:组件的方法,可以在模板或其他方法中被调用。
  • watch:一个对象,键是需要观察的表达式,值是对应回调函数。当表达式的值变化时,会调用对应的回调函数。
  • template:一个字符串模板,作为组件的 HTML 模板。
  • mountedupdated 等:生命周期钩子,用于在组件的不同阶段执行代码。

3. 组件的模板

Vue 组件的模板定义了组件的 HTML 结构。模板可以是字符串,也可以是单文件组件中的 .vue 文件中的 <template> 部分。模板可以包含普通的 HTML、文本、指令、插值表达式等。

4. 组件的通信

Vue 组件之间的通信主要有以下几种方式:

  • Props 向下传递:父组件通过 props 向下传递数据给子组件。
  • 事件向上传递:子组件通过 $emit 触发事件,向父组件发送消息。
  • 插槽(Slots):允许父组件在子组件的模板中插入额外的 HTML 内容。
  • 全局事件总线(不推荐在大型应用中使用):通过 Vue 实例作为事件中心,实现跨组件通信。
  • Vuex:对于复杂的应用,推荐使用 Vuex 进行状态管理,实现跨组件的通信和状态共享。

5. 组件的复用

Vue 组件的最大优点之一就是可复用性。通过注册和使用组件,可以构建出复杂的用户界面,同时保持代码的清晰和可维护性。

  • 18
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
组件Vue.js 中最重要的概念之一。组件可以让我们将 UI 拆分为独立、可复用的部件,使得代码更加清晰、易于维护。在 Vue.js 中,组件可以分为全局组件和局部组件,其中全局组件可在任何地方使用,而局部组件只能在其父组件中使用。 定义组件时,需要使用 Vue.component() 方法,该方法需要传入两个参数:组件名称和组件配置对象。组件名称应该采用 kebab-case(短横线分隔命名)格式,以便在 HTML 中使用。 示例代码如下: ```javascript // 定义一个名为 button-counter 的新组件 Vue.component('button-counter', { data: function () { return { count: 0 } }, template: '<button v-on:click="count++">You clicked me {{ count }} times.</button>' }) ``` 在上述代码中,我们定义了一个名为 button-counter 的组件,该组件包含一个计数器,每次点击按钮计数器加一。 在 HTML 中使用组件时,需要使用组件名称作为自定义标签来调用组件。示例代码如下: ```html <div id="app"> <button-counter></button-counter> </div> ``` 在上述代码中,我们调用了 button-counter 组件,并将其渲染到了 id 为 app 的 div 元素中。 除了组件的 data 和 template 属性外,还可以使用 props 属性来传递组件之间的数据。使用 props 时,需要在组件的配置对象中定义 props 属性,并在 HTML 中使用 v-bind 指令来传递数据。 示例代码如下: ```javascript // 定义一个名为 todo-item 的新组件 Vue.component('todo-item', { props: ['todo'], template: '<li>{{ todo.text }}</li>' }) // 创建一个 Vue 实例 var app = new Vue({ el: '#app', data: { groceryList: [ { id: 0, text: '蔬菜' }, { id: 1, text: '水果' }, { id: 2, text: '奶酪' } ] } }) ``` 在上述代码中,我们定义了一个名为 todo-item 的组件,并使用 props 属性定义了一个名为 todo 的 prop。在 HTML 中,我们使用 v-bind 指令将 groceryList 数组中的每个对象传递给了 todo-item 组件。示例代码如下: ```html <div id="app"> <ul> <todo-item v-for="item in groceryList" v-bind:todo="item" v-bind:key="item.id"></todo-item> </ul> </div> ``` 在上述代码中,我们使用 v-for 指令遍历 groceryList 数组,并使用 v-bind 指令将数组中的每个对象传递给了 todo-item 组件。注意,我们还需要使用 v-bind:key 指令来为每个列表项指定一个唯一的 key 值。 插槽是 Vue.js 中另一个重要的概念。插槽可以让父组件在子组件中插入任意的 HTML 内容,使得组件更加灵活、可复用。 在子组件中,使用 <slot> 标签来定义插槽。在父组件中,使用子组件的自定义标签来调用组件,并在标签内部插入 HTML 内容。示例代码如下: ```javascript // 定义一个名为 alert-box 的新组件 Vue.component('alert-box', { template: ` <div class="alert-box"> <strong>Error!</strong> <slot></slot> </div> ` }) // 创建一个 Vue 实例 var app = new Vue({ el: '#app' }) ``` 在上述代码中,我们定义了一个名为 alert-box 的组件,并在组件中定义了一个插槽。在 HTML 中,我们调用了 alert-box 组件,并在标签内部插入了一些 HTML 内容。示例代码如下: ```html <div id="app"> <alert-box> <p>Something bad happened.</p> </alert-box> </div> ``` 在上述代码中,我们调用了 alert-box 组件,并在标签内部插入了一些 HTML 内容。该 HTML 内容会被插入到 alert-box 组件的插槽中。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值