当前位置:首页 > 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')

模板中使用组件:

黑马vue实现

<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)

安装并配置路由:

黑马vue实现

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:

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

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

相关文章

vue实现预约页面

vue实现预约页面

Vue 预约页面实现步骤 准备工作 安装Vue CLI创建项目,确保已配置好开发环境。使用vue create appointment-page初始化项目,选择默认配置或手动配置。 页面结构设计 在…

vue 实现长列表

vue 实现长列表

Vue 实现长列表的优化方案 虚拟滚动技术 虚拟滚动是处理长列表的高效方式,仅渲染可视区域内的元素。通过计算滚动位置动态加载和卸载DOM节点,大幅减少内存占用和渲染压力。 <template…

vue登录逻辑的实现

vue登录逻辑的实现

Vue 登录逻辑实现 前端实现 创建登录组件 在 Vue 项目中创建一个登录组件,通常命名为 Login.vue。该组件包含表单元素,如用户名和密码输入框,以及提交按钮。 <template&…

vue搜索过后实现分页

vue搜索过后实现分页

Vue 实现搜索后分页功能 数据绑定与搜索逻辑 在 Vue 组件中定义必要的数据属性: data() { return { searchQuery: '', currentPa…

前端多线程实现vue

前端多线程实现vue

前端多线程与Vue的结合 在Vue中实现多线程通常通过Web Worker技术完成。Web Worker允许在后台线程中运行脚本,避免阻塞主线程,适合处理计算密集型任务。 使用Web Worker…

vue实现列表显示

vue实现列表显示

Vue 实现列表显示的方法 在 Vue 中实现列表显示通常使用 v-for 指令,结合数组或对象数据渲染动态列表。以下是几种常见的实现方式。 基本列表渲染 通过 v-for 指令遍历数组,动态生成列…