当前位置:首页 > VUE

黑马vue实现

2026-01-13 07:43:43VUE

Vue.js 基础实现步骤

安装 Vue.js 可以通过 CDN 或 npm 方式。对于快速原型开发,CDN 引入更为便捷:

<script src="https://cdn.jsdelivr.net/npm/vue@3/dist/vue.global.js"></script>

使用 npm 安装适合大型项目:

npm install vue@next

创建 Vue 实例

在 HTML 中准备挂载点并初始化应用:

<div id="app">
  {{ message }}
</div>

<script>
  const { createApp } = Vue
  createApp({
    data() {
      return {
        message: 'Hello Vue!'
      }
    }
  }).mount('#app')
</script>

数据绑定与指令

Vue 提供多种模板语法实现动态渲染:

<div id="bind">
  <span v-bind:title="hoverText">悬停查看动态提示</span>
  <p v-if="seen">条件渲染内容</p>
  <button v-on:click="reverseText">反转文本</button>
  <input v-model="inputText">
</div>

<script>
  createApp({
    data() {
      return {
        hoverText: '页面加载于 ' + new Date().toLocaleString(),
        seen: true,
        inputText: '双向绑定示例'
      }
    },
    methods: {
      reverseText() {
        this.inputText = this.inputText.split('').reverse().join('')
      }
    }
  }).mount('#bind')
</script>

组件化开发

注册并使用自定义组件:

const app = createApp({})

app.component('todo-item', {
  props: ['todo'],
  template: `<li>{{ todo.text }}</li>`
})

app.mount('#todo-list-app')

模板中使用组件:

<div id="todo-list-app">
  <ol>
    <todo-item
      v-for="item in groceryList"
      v-bind:todo="item"
      v-bind:key="item.id"
    ></todo-item>
  </ol>
</div>

<script>
  createApp({
    data() {
      return {
        groceryList: [
          { id: 0, text: '蔬菜' },
          { id: 1, text: '奶酪' },
          { id: 2, text: '其他食材' }
        ]
      }
    }
  }).mount('#todo-list-app')
</script>

状态管理(Vuex)

对于复杂状态管理,可引入 Vuex:

npm install vuex@next

创建 store 实例:

import { createStore } from 'vuex'

const store = createStore({
  state() {
    return {
      count: 0
    }
  },
  mutations: {
    increment(state) {
      state.count++
    }
  }
})

在组件中使用:

const app = createApp({ /* 根组件 */ })
app.use(store)

app.component('MyComponent', {
  template: `<div>{{ $store.state.count }}</div>`,
  methods: {
    increment() {
      this.$store.commit('increment')
    }
  }
})

路由管理(Vue Router)

安装并配置路由:

npm install vue-router@4

路由配置文件示例:

import { createRouter, createWebHistory } from 'vue-router'
import Home from './views/Home.vue'
import About from './views/About.vue'

const routes = [
  { path: '/', component: Home },
  { path: '/about', component: About }
]

const router = createRouter({
  history: createWebHistory(),
  routes
})

const app = createApp({})
app.use(router)
app.mount('#app')

组合式 API

Vue 3 引入 setup 语法:

<script>
  import { ref, onMounted } from 'vue'

  export default {
    setup() {
      const count = ref(0)

      function increment() {
        count.value++
      }

      onMounted(() => {
        console.log('组件挂载完成')
      })

      return {
        count,
        increment
      }
    }
  }
</script>

<template>
  <button @click="increment">点击计数: {{ count }}</button>
</template>

项目脚手架

使用 Vite 创建 Vue 项目:

npm create vite@latest my-vue-app --template vue
cd my-vue-app
npm install
npm run dev

或使用 Vue CLI:

黑马vue实现

npm install -g @vue/cli
vue create my-project
cd my-project
npm run serve

标签: 黑马vue
分享给朋友:

相关文章

vue  select实现

vue select实现

Vue Select 实现方法 在 Vue 中实现下拉选择功能可以使用原生 <select> 标签或第三方库如 vue-select。以下是两种方法的详细说明: 原生 HTML Sele…

vue实现递归

vue实现递归

Vue 实现递归组件的方法 在 Vue 中实现递归组件通常用于处理树形结构数据(如菜单、评论列表、文件目录等)。以下是具体实现方法: 定义递归组件 通过 name 选项让组件可以递归调用自身:…

vue实现tablegrid

vue实现tablegrid

Vue 实现 TableGrid 的方法 使用 Element UI 的 Table 组件 Element UI 提供了强大的 Table 组件,可以快速实现表格布局。安装 Element UI 后,…

vue实现swipe

vue实现swipe

Vue实现Swipe功能的方法 使用第三方库(推荐) Vue生态中有多个成熟的轮播/滑动组件库,例如vue-awesome-swiper或swiper/vue。以下是基于swiper/vue的实现示例…

vue实现监听

vue实现监听

监听数据变化 在Vue中,可以通过watch选项或$watch方法监听数据的变化。watch适用于组件选项内声明式监听,$watch适用于动态监听。 // 选项式API export default…

vue实现computed

vue实现computed

Vue 中 computed 的实现原理 computed 属性是 Vue 的一个核心特性,它基于响应式依赖进行缓存,仅在依赖发生变化时重新计算。以下是 computed 的实现方式: 基本用法 在…