手记

Vue3课程:新手入门到初级实战指南

本文为你提供了从新手入门到初级实战的Vue3课程指南,涵盖了Vue3的基础知识、安装、组件化开发和路由与状态管理等内容。通过本文,你将学会如何创建和运行Vue3项目,并掌握Vue3的核心概念和技术。此外,文章还推荐了丰富的学习资源,帮助你深入学习Vue3。

Vue3课程:新手入门到初级实战指南
Vue3基础概述

Vue3简介

Vue.js是一个用于构建用户界面的渐进式框架。与其他大型框架不同,Vue被设计为可以自底向上逐层应用。Vue的目标是通过尽可能简单的API实现响应的数据绑定和组合的视图组件。Vue的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合。同时,它也足量且灵活,能够为复杂的单页应用提供驱动。

Vue3是Vue.js的最新稳定版本,它在性能、开发者体验和内置工具方面做了大量的改进。Vue3引入了Composition API,这是一个新的API以解决组件中复杂的逻辑问题。同时,Vue3也增强了TypeScript支持,优化了响应式系统,提升了性能。

安装Vue3

安装Vue3一般通过npm或者yarn。首先,确保你已经安装了Node.js和npm。然后,可以通过以下步骤安装Vue CLI:

  1. 全局安装Vue CLI
npm install -g @vue/cli
  1. 创建一个新的Vue3项目
vue create my-project

在创建项目时,选择Vue 3选项:

? Please pick a preset:
 - Default (babel, eslint)
> Manually select features

选择Vue 3选项:

? Choose a version of Vue.js that you'd like to add to your project:
 - Vue 2
> Vue 3 Preview
  1. 安装完成后进入项目目录并启动项目
cd my-project
npm run serve

创建第一个Vue3项目

创建一个简单的Vue3项目,展示Vue3的基础使用。

  1. 创建项目
vue create my-first-vue3
  1. 选择Vue 3

选择Vue 3选项,如上安装部分。

  1. 添加组件

src/components目录下创建一个名为HelloWorld.vue的文件,内容如下:

<template>
  <div class="hello">
    <h1>{{ msg }}</h1>
  </div>
</template>

<script>
export default {
  name: 'HelloWorld',
  props: {
    msg: String
  }
}
</script>

<style scoped>
h1 {
  color: #42b983;
}
</style>
  1. 在主文件中引入组件

src/App.vue中引入并使用这个组件:

<template>
  <div id="app">
    <HelloWorld msg="Welcome to Your Vue.js App" />
  </div>
</template>

<script>
import HelloWorld from './components/HelloWorld.vue'

export default {
  name: 'App',
  components: {
    HelloWorld
  }
}
</script>
  1. 运行项目
npm run serve
Vue3组件化开发

组件基础

Vue3组件是可复用的Vue实例。每个组件都定义了可复用的UI组件,可以封装在单一的文件中复用在不同的位置。

  1. 创建组件文件

src/components目录下创建一个名为MyComponent.vue的文件,内容如下:

<template>
  <div class="my-component">
    <h2>{{ title }}</h2>
    <p>{{ description }}</p>
  </div>
</template>

<script>
export default {
  name: 'MyComponent',
  props: {
    title: String,
    description: String
  }
}
</script>

<style scoped>
.my-component {
  border: 1px solid #ccc;
  padding: 10px;
  margin: 5px;
}
</style>
  1. 在父组件中使用子组件

src/App.vue中引入并使用这个组件:

<template>
  <div id="app">
    <MyComponent title="My Title" description="This is a description." />
  </div>
</template>

<script>
import MyComponent from './components/MyComponent.vue'

export default {
  name: 'App',
  components: {
    MyComponent
  }
}
</script>

传值与事件绑定

在Vue3中,可以通过props向组件传递数据,也可以通过事件绑定实现组件间的通信。

  1. 使用props向组件传递数据
<template>
  <div class="child-component">
    <h2>{{ parentMessage }}</h2>
  </div>
</template>

<script>
export default {
  name: 'ChildComponent',
  props: ['parentMessage']
}
</script>

在父组件中使用:

<template>
  <div id="app">
    <ChildComponent :parentMessage="message" />
  </div>
</template>

<script>
import ChildComponent from './components/ChildComponent.vue'

export default {
  name: 'App',
  components: {
    ChildComponent
  },
  data() {
    return {
      message: 'Hello from parent'
    }
  }
}
</script>
  1. 通过事件绑定实现子组件向父组件传递数据

在子组件中定义一个事件:

<template>
  <div class="child-component">
    <button @click="sendMessage">Send Message</button>
  </div>
</template>

<script>
export default {
  name: 'ChildComponent',
  methods: {
    sendMessage() {
      this.$emit('messageFromChild', 'Message from child component')
    }
  }
}
</script>

在父组件中监听这个事件:

<template>
  <div id="app">
    <ChildComponent @messageFromChild="handleMessage" />
  </div>
</template>

<script>
import ChildComponent from './components/ChildComponent.vue'

export default {
  name: 'App',
  components: {
    ChildComponent
  },
  methods: {
    handleMessage(message) {
      console.log(message)
    }
  }
}
</script>

父子组件通信

在“组件基础”与“传值与事件绑定”两部分中,已经展示了如何通过props和事件实现父子组件间的通信。这里提供一个具体的代码示例,以帮助理解:

<!-- 父组件 -->
<template>
  <div id="app">
    <ChildComponent :parentMessage="parentMessage" @childMessage="handleMessage" />
  </div>
</template>

<script>
import ChildComponent from './components/ChildComponent.vue'

export default {
  name: 'App',
  components: {
    ChildComponent
  },
  data() {
    return {
      parentMessage: 'Hello from parent'
    }
  },
  methods: {
    handleMessage(message) {
      console.log(message)
    }
  }
}
</script>

<!-- 子组件 -->
<template>
  <div class="child-component">
    <p>{{ parentMessage }}</p>
    <button @click="sendMessage">Send Message</button>
  </div>
</template>

<script>
export default {
  name: 'ChildComponent',
  props: ['parentMessage'],
  methods: {
    sendMessage() {
      this.$emit('childMessage', 'Message from child component')
    }
  }
}
</script>
Vue3响应式原理

响应式系统介绍

Vue3的响应式系统基于Proxy对象。相比于Vue2使用的Object.defineProperty,Proxy提供了更强大的功能,并且性能也有了显著的提升。

  1. 使用Proxy实现响应式
const handler = {
  get(target, key) {
    track(target, key)
    return target[key]
  },
  set(target, key, value) {
    target[key] = value
    trigger(target, key)
    return true
  }
}

function reactive(target) {
  return new Proxy(target, handler)
}

function track(target, key) {
  // 简化的实现
}

function trigger(target, key) {
  // 简化的实现
}
  1. 使用refreactive实现响应式数据
import { ref, reactive } from 'vue'

const count = ref(0)
const state = reactive({
  message: 'Hello, Vue3'
})

console.log(count.value) // 0
console.log(state.message) // Hello, Vue3

ref与reactive的区别

refreactive是Vue3中用于创建响应式数据的两种方式。

  • ref:用于直接创建一个响应式引用,适用于基本类型。
  • reactive:用于创建一个响应式对象,适用于复杂的数据结构。
import { ref, reactive } from 'vue'

const count = ref(0)
const state = reactive({
  count: 0,
  message: 'Hello, Vue3'
})

console.log(count.value) // 0
console.log(state.count) // 0
console.log(state.message) // Hello, Vue3

响应式开发技巧

在实际开发中,可以利用Vue3的响应式系统来提高开发效率和代码可维护性。

  1. 使用computed计算属性
import { computed } from 'vue'

const count = ref(0)
const doubleCount = computed(() => count.value * 2)

console.log(doubleCount.value) // 0
  1. 使用watch监听数据变化
import { watch } from 'vue'

watch(count, (newValue, oldValue) => {
  console.log(`Count changed from ${oldValue} to ${newValue}`)
})
  1. 使用setup函数
import { ref, onMounted } from 'vue'

export default {
  setup() {
    const count = ref(0)
    const increment = () => count.value++

    onMounted(() => {
      console.log('Component is mounted')
    })

    return { count, increment }
  }
}

高级路由配置

在介绍Vue Router的基础配置之后,下面展示一些更高级的配置,如动态路由和嵌套路由。

  1. 动态路由
const routes = [
  {
    path: '/user/:id',
    component: User,
    props: true
  }
]
  1. 嵌套路由
const routes = [
  {
    path: '/parent',
    component: Parent,
    children: [
      {
        path: 'child',
        component: Child
      }
    ]
  }
]

Vuex基础应用

除了Vue Router之外,Vuex也用于状态管理。下面展示如何设置和使用Vuex Store。

  1. 安装Vuex
npm install vuex@next
  1. 创建Vuex Store

src/store/index.js中创建Store:

import { createStore } from 'vuex'

export default createStore({
  state: {
    count: 0
  },
  mutations: {
    increment(state) {
      state.count++
    }
  },
  actions: {
    increment({ commit }) {
      commit('increment')
    }
  },
  getters: {
    count: state => state.count
  }
})
  1. 在主文件中引入Store

src/main.js中引入并使用Store:

import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'

const app = createApp(App)
app.use(router)
app.use(store)
app.mount('#app')
  1. 在组件中使用Store
<template>
  <div>
    <h1>{{ count }}</h1>
    <button @click="increment">Increment</button>
  </div>
</template>

<script>
import { mapState, mapActions } from 'vuex'

export default {
  computed: {
    ...mapState(['count'])
  },
  methods: {
    ...mapActions(['increment'])
  }
}
</script>
Vue3路由与状态管理

Vue Router基础

Vue Router是Vue.js官方的路由管理器。它可以让你的Vue应用支持页面路由。

  1. 安装Vue Router
npm install vue-router@next
  1. 创建路由配置

src/router/index.js中创建路由配置:

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

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

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

export default router
  1. 在主文件中引入路由配置

src/main.js中引入并使用路由配置:

import { createApp } from 'vue'
import App from './App.vue'
import router from './router'

const app = createApp(App)
app.use(router)
app.mount('#app')
  1. 创建视图组件

src/views目录下创建Home.vueAbout.vue文件:

<!-- Home.vue -->
<template>
  <div>
    <h1>Home Page</h1>
  </div>
</template>

<script>
export default {
  name: 'Home'
}
</script>
<!-- About.vue -->
<template>
  <div>
    <h1>About Page</h1>
  </div>
</template>

<script>
export default {
  name: 'About'
}
</script>

Vuex基础应用

Vuex是一个专为Vue.js应用程序开发的状态管理模式。它采用集中式存储管理应用的所有组件的状态,并以相应的规则保证状态以一种可预测的方式发生变化。

  1. 安装Vuex
npm install vuex@next
  1. 创建Vuex Store

src/store/index.js中创建Store:

import { createStore } from 'vuex'

export default createStore({
  state: {
    count: 0
  },
  mutations: {
    increment(state) {
      state.count++
    }
  },
  actions: {
    increment({ commit }) {
      commit('increment')
    }
  },
  getters: {
    count: state => state.count
  }
})
  1. 在主文件中引入Store

src/main.js中引入并使用Store:

import { createApp } from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'

const app = createApp(App)
app.use(router)
app.use(store)
app.mount('#app')
  1. 在组件中使用Store
<template>
  <div>
    <h1>{{ count }}</h1>
    <button @click="increment">Increment</button>
  </div>
</template>

<script>
import { mapState, mapActions } from 'vuex'

export default {
  computed: {
    ...mapState(['count'])
  },
  methods: {
    ...mapActions(['increment'])
  }
}
</script>

实战项目选题

选择一个适合Vue3的项目主题,如博客网站、个人主页、在线商城等。

  1. 博客网站
  • 用户注册和登录
  • 发布和管理文章
  • 文章分类和标签
  • 评论系统
  1. 个人主页
  • 个人简历展示
  • 项目展示
  • 技能展示
  1. 在线商城
  • 商品展示
  • 购物车
  • 订单管理
  • 用户中心

项目开发步骤

  1. 需求分析

    • 列出需求清单
    • 分析项目可行性
  2. 环境搭建

    • 安装Vue CLI
    • 创建项目
    • 初始化项目结构
  3. 设计UI

    • 设计页面原型
    • 设计样式
  4. 开发实现

    • 实现前端页面
    • 实现后端接口
    • 实现前后端交互
    • 优化性能
  5. 测试验证

    • 单元测试
    • 集成测试
    • 用户测试
  6. 部署上线
    • 选择部署平台
    • 部署项目
    • 配置域名和SSL证书

项目打包部署

  1. 打包项目
npm run build
  1. 部署到服务器
scp -r dist/* user@server:/path/to/deploy
  1. 运行Nginx
sudo systemctl start nginx
  1. 配置Nginx

/etc/nginx/sites-available/default中添加配置:

server {
  listen 80;
  server_name yourdomain.com;

  location / {
    root /path/to/deploy;
    index index.html;
    try_files $uri $uri/ /index.html;
  }
}
  1. 重启Nginx
sudo systemctl restart nginx
Vue3学习资源推荐

官方文档

Vue3官方文档是学习Vue3的最佳资源,涵盖了所有核心功能和API的详细介绍。

在线教程

除了官方文档,还有许多在线教程可以帮助你更好地学习Vue3。

社区论坛与博客

加入Vue社区可以让你与其他开发者交流和学习。

以上就是《Vue3课程:新手入门到初级实战指南》的全部内容。希望这篇文章能够帮助你快速上手Vue3并应用于实际项目中。

0人推荐
随时随地看视频
慕课网APP