Vue入门(六):Vue组件

好久不见,uu们,哈士奇昨天给自己放了一天的假,今天继续回来为大家更新Vue入门系列。今天给大家更新的是Vue的组件。组件是 Vue 应用程序的基本构建块,可以将页面拆分为独立可复用的部分。哈士奇将介绍如何创建、使用和管理 Vue 组件。

什么是 Vue 组件?

Vue 组件是 Vue.js 应用程序中的独立模块,它封装了特定的功能和样式,并且可以被其他组件或者页面引用和复用。每个组件可以包含自己的模板、脚本和样式,使得代码更加模块化和易于维护。

创建一个简单的 Vue 组件

要创建一个 Vue 组件,你可以使用 Vue.component 方法。以下是一个简单的示例:

vue 复制代码
<template>
  <div>
    <h1>Hello, {{ name }}!</h1>
    <p>{{ message }}</p>
  </div>
</template>

<script>
Vue.component('hello-component', {
  props: ['name'],
  data() {
    return {
      message: 'Welcome to Vue.js!'
    };
  }
});
</script>

在这个例子中,我们创建了一个名为 hello-component 的 Vue 组件,它接受一个 name 属性,并且显示一个欢迎消息。

在 Vue 应用中使用组件

要在 Vue 应用程序中使用组件,你需要在 Vue 实例中注册组件,并在模板中引用它们。以下是一个示例:

vue 复制代码
<template>
  <div>
    <hello-component name="Alice"></hello-component>
    <hello-component name="Bob"></hello-component>
  </div>
</template>

<script>
new Vue({
  el: '#app'
});
</script>

在这个例子中,我们在模板中引用了 hello-component 组件,并传递了不同的 name 属性值。

Vue 组件的生命周期钩子

Vue 组件具有一系列的生命周期钩子函数,允许你在组件的不同阶段执行代码。以下是一些常用的生命周期钩子函数:

  • beforeCreate:在实例初始化之后,数据观测 (data observer) 和 event/watcher 事件配置之前被调用。
  • created:实例已经创建完成之后被调用。在这一步,实例已完成以下的配置:数据观测 (data observer),属性和方法的运算,watch/event 事件回调。然而,挂载阶段还没开始,$el 属性目前不可见。
  • mounted:实例已经挂载到 DOM 上后调用,这时 el 被新创建的 vm.$el 替换了。如果根实例挂载到了一个文档内的元素上,当 mounted 被调用时 vm.$el 也在文档内。
  • beforeUpdate:数据更新时调用,发生在虚拟 DOM 重新渲染和打补丁之前。
  • updated:由于数据更改导致的虚拟 DOM 重新渲染和打补丁后调用。
  • beforeDestroy:实例销毁之前调用。在这一步,实例仍然完全可用。
  • destroyed:实例销毁后调用。该钩子被调用后,Vue 实例上所有的东西都会解绑定,所有的事件监听器会被移除,所有的子实例也会被销毁。

Vue 组件通信

在 Vue 应用程序中,组件通信是非常重要的,可以让不同的组件之间共享数据、响应事件以及协调行为,包括 PropsEvents$emit$parent/$childrenVuex 等。

PropsEvents

Props 和 Events 是 Vue 组件通信的基础。Props 允许父组件向子组件传递数据,而 Events 则允许子组件向父组件发送消息。这种单向数据流的设计使得组件之间的通信更加清晰和可维护。

Props

Props 是在组件之间传递数据的一种方式。父组件可以使用 Props 向子组件传递数据,子组件通过 Props 接收数据并在组件内部使用。以下是一个简单的示例:

vue 复制代码
<!-- ParentComponent.vue -->
<template>
  <child-component :message="parentMessage"></child-component>
</template>

<script>
export default {
  data() {
    return {
      parentMessage: 'Hello from parent!'
    };
  }
};
</script>
vue 复制代码
<!-- ChildComponent.vue -->
<template>
  <div>{{ message }}</div>
</template>

<script>
export default {
  props: ['message']
};
</script>

在这个示例中,父组件通过 Props 将 parentMessage 数据传递给子组件,子组件通过 message Prop 接收并显示数据。

Events

Events 允许子组件向父组件发送消息。子组件可以使用 $emit 方法触发一个自定义事件,并且可以传递数据给父组件。以下是一个示例:

vue 复制代码
<!-- ChildComponent.vue -->
<template>
  <button @click="sendMessage">Send Message</button>
</template>

<script>
export default {
  methods: {
    sendMessage() {
      this.$emit('message', 'Hello from child!');
    }
  }
};
</script>
vue 复制代码
<!-- ParentComponent.vue -->
<template>
  <div>
    <child-component @message="handleMessage"></child-component>
    <p>{{ receivedMessage }}</p>
  </div>
</template>

<script>
export default {
  data() {
    return {
      receivedMessage: ''
    };
  },
  methods: {
    handleMessage(message) {
      this.receivedMessage = message;
    }
  }
};
</script>

在这个示例中,子组件通过 $emit 方法触发一个名为 message 的自定义事件,并且传递了消息数据。父组件监听了这个事件,并在 handleMessage 方法中接收消息数据。

$parent$children

Vue 还提供了 $parent$children 属性来访问父组件和子组件的实例。虽然这种方式不太推荐,因为它会导致组件间的耦合性增加,但在某些情况下是有用的。以下是一个简单的示例:

vue 复制代码
<!-- ParentComponent.vue -->
<template>
  <div>
    <child-component></child-component>
  </div>
</template>

<script>
export default {
  mounted() {
    console.log(this.$children[0].message);
  }
};
</script>
vue 复制代码
<!-- ChildComponent.vue -->
<template>
  <div>{{ message }}</div>
</template>

<script>
export default {
  data() {
    return {
      message: 'Hello from child!'
    };
  }
};
</script>

在这个示例中,父组件通过 $children 访问了子组件的实例,并且打印了子组件的 message 数据。

Vuex

Vuex 是一个专门为 Vue.js 应用程序开发的状态管理库,它可以帮助我们更好地管理应用程序的状态并实现组件之间的通信。在大型的 Vue.js 应用程序中,组件之间的状态共享和通信是非常常见的需求,而 Vuex 提供了一种集中式的状态管理方案,使得状态的管理变得简单而有序。

Vuex 的核心概念

State

State 是 Vuex 存储应用程序状态的地方,即数据源。我们可以通过 Vuex 的 store.state 属性访问状态,并且可以在组件中使用 mapState 辅助函数来简化对状态的访问。

Getters

Getters 允许我们在 Vuex 的 store 中定义计算属性。它们的作用类似于组件中的计算属性,用于对 state 中的数据进行一些处理后返回新的数据。我们可以通过 store.getters 属性访问 getters,并且可以使用 mapGetters 辅助函数简化访问。

Mutations

Mutations 是 Vuex 中用于修改状态的唯一方式。每个 mutation 都有一个字符串的事件类型 (type) 和一个回调函数 (handler),我们可以通过提交 (commit) mutation 来修改状态。由于 mutations 是同步的,所以 Vuex 能够追踪状态的变化,并且可以在开发工具中进行调试。

Actions

Actions 类似于 mutations,但是可以支持异步操作。Actions 提交 (commit) mutations 来修改状态,但可以包含任意异步操作。我们可以通过 store.dispatch 方法触发 action,并且可以使用 mapActions 辅助函数简化调用。

Modules

Modules 允许我们将 store 分割成模块。每个模块拥有自己的 state、getters、mutations 和 actions,使得大型应用程序的状态管理更加灵活和可维护。

在 Vue 应用程序中使用 Vuex

要在 Vue 应用程序中使用 Vuex,首先需要创建一个 Vuex 的 store 并将其注入到根 Vue 实例中。以下是一个简单的示例:

javascript 复制代码
// store.js
import Vue from 'vue';
import Vuex from 'vuex';

Vue.use(Vuex);

const store = new Vuex.Store({
  state: {
    count: 0
  },
  mutations: {
    increment(state) {
      state.count++;
    }
  },
  actions: {
    incrementAsync({ commit }) {
      setTimeout(() => {
        commit('increment');
      }, 1000);
    }
  },
  getters: {
    doubleCount(state) {
      return state.count * 2;
    }
  }
});

export default store;
javascript 复制代码
// main.js
import Vue from 'vue';
import App from './App.vue';
import store from './store';

new Vue({
  el: '#app',
  store,
  render: h => h(App)
});

在这个例子中,我们创建了一个包含 count 状态、increment mutation、incrementAsync action 和 doubleCount getter 的 Vuex store,并将其注入到根 Vue 实例中。

总结

Vue 组件是构建 Vue.js 应用程序的重要部分,它提供了一种模块化和可复用的方式来组织和管理代码。使用Vue组件将会使得前端开发变得更加清晰明了,同时提高代码的复用性,这使得开发人员的开发速度获得了快速的提升。

相关推荐
朝阳3913 分钟前
JS 正则表达式 -- 分组【详解】含普通分组、命名分组、反向引用
前端·javascript·正则表达式
Cool----代购系统API1 小时前
css设置盒子动画,CSS3 transition动画 animation动画
前端·css·css3
哟哟耶耶1 小时前
css-设置元素的溢出行为为可见overflow: visible;
前端·css
sunly_1 小时前
CSS:跑马灯
前端·css
2301_818732061 小时前
用layui表单,前端页面的样式正常显示,但是表格内无数据显示(数据库连接和获取数据无问题)——已经解决
java·前端·javascript·前端框架·layui·intellij idea
yqcoder1 小时前
npm link 作用
前端·npm·node.js
林涧泣1 小时前
【Uniapp-Vue3】页面和路由API-navigateTo及页面栈getCurrentPages
前端·vue.js·uni-app
Komorebi゛1 小时前
【uniapp】获取上传视频的md5,适用于APP和H5
前端·javascript·uni-app
林涧泣1 小时前
【Uniapp-Vue3】动态设置页面导航条的样式
前端·javascript·uni-app
杰九2 小时前
【全栈】SprintBoot+vue3迷你商城(10)
开发语言·前端·javascript·vue.js·spring boot