VUE3学习

Vue 3 核心概念

1. Composition API(组合式 API)

Vue 3 最重要的特性。

基础示例(参考 src/views/h5/Login.vue
javascript 复制代码
<template>
  <div class="frame">
    <div class="login">
      <h2>H5端登录</h2>
      <van-divider />
      <!-- 条件渲染 -->
      <LoginPwd v-if="loginType==0"></LoginPwd>
      <LoginSms v-if="loginType==1"></LoginSms>
    </div>
  </div>
</template>
<script lang="ts" setup>
import { ref } from 'vue';

// 响应式数据
const loginType = ref<number>(0)
</script>
核心 API 说明

ref() - 创建响应式引用

javascript 复制代码
import { ref } from 'vue'

const count = ref(0)        // 基本类型
const user = ref({ name: '' }) // 对象类型

// 访问值需要使用 .value
count.value = 1
console.log(count.value)

reactive() - 创建响应式对象

javascript 复制代码
import { reactive } from 'vue'

const state = reactive({
  count: 0,
  name: 'Vue'
})

// 直接访问,不需要 .value
state.count = 1

computed() - 计算属性

javascript 复制代码
import { ref, computed } from 'vue'

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

watch() - 监听器

javascript 复制代码
import { ref, watch } from 'vue'

const count = ref(0)

watch(count, (newVal, oldVal) => {
  console.log(`count changed: ${oldVal} -> ${newVal}`)
})

生命周期钩子

java 复制代码
import { onMounted, onUnmounted } from 'vue'

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

onUnmounted(() => {
  console.log('组件已卸载')
})

2. 组件通信

Props(父传子)
javascript 复制代码
<!-- 父组件 -->
<ChildComponent :message="parentMessage" />

<!-- 子组件 -->
<script setup lang="ts">
interface Props {
  message: string
}

const props = defineProps<Props>()
</script>
Emits(子传父)
javascript 复制代码
<!-- 子组件 -->
<script setup lang="ts">
const emit = defineEmits<{
  (e: 'update', value: string): void
}>()

const handleClick = () => {
  emit('update', 'new value')
}
</script>
<!-- 父组件 -->
<ChildComponent @update="handleUpdate" />
Provide/Inject(跨层级通信)
javascript 复制代码
// 祖先组件
import { provide } from 'vue'
provide('theme', 'dark')

// 后代组件
import { inject } from 'vue'
const theme = inject('theme', 'light') // 第二个参数是默认值

3. 模板语法

插值表达式
javascript 复制代码
<template>
  <div>{{ message }}</div>
  <div v-text="message"></div>
</template>
指令
javascript 复制代码
<!-- v-if / v-show -->
<div v-if="isVisible">条件渲染</div>
<div v-show="isVisible">显示/隐藏</div>
<!-- v-for -->
<li v-for="(item, index) in list" :key="item.id">
  {{ item.name }}
</li>
<!-- v-bind (简写 :) -->
<img :src="imageSrc" />
<div :class="{ active: isActive }"></div>
<!-- v-on (简写 @) -->
<button @click="handleClick">点击</button>
<input @input="handleInput" />

<!-- v-model 双向绑定 -->
<input v-model="message" />

TypeScript 基础

1. 类型定义

基本类型
javascript 复制代码
let name: string = 'Vue'
let age: number = 3
let isActive: boolean = true
let list: number[] = [1, 2, 3]
let user: { name: string; age: number } = { name: 'Vue', age: 3 }
接口(Interface)

参考 src/interface/index.ts

javascript 复制代码
export interface ILoginUserInfo {
  id: string
  username: string
  email?: string  // 可选属性
  phone?: string
}

export interface IToken {
  accessToken: string
  refreshToken?: string
}
类型别名(Type)
javascript 复制代码
type Status = 'pending' | 'success' | 'error'
type Callback = (data: string) => void

2. 泛型

javascript 复制代码
function identity<T>(arg: T): T {
  return arg
}

interface ApiResponse<T> {
  code: number
  data: T
  message: string
}

3. 在 Vue 组件中使用 TypeScript

javascript 复制代码
<script setup lang="ts">
import { ref } from 'vue'

// 定义接口
interface User {
  name: string
  age: number
}

// 响应式数据
const user = ref<User>({
  name: '',
  age: 0
})

// 函数类型
const handleSubmit = (): void => {
  console.log('提交')
}
</script>
相关推荐
鹿心肺语39 分钟前
前端HTML转PDF的两种主流方案深度解析
前端·javascript
海石1 小时前
去到比北方更北的地方—2025年终总结
前端·ai编程·年终总结
一个懒人懒人1 小时前
Promise async/await与fetch的概念
前端·javascript·html
Mintopia1 小时前
Web 安全与反编译源码下的权限设计:构筑前后端一致的防护体系
前端·安全
输出输入1 小时前
前端核心技术
开发语言·前端
Mintopia1 小时前
Web 安全与反编译源码下的权限设计:构建前后端一体的信任防线
前端·安全·编译原理
林深现海2 小时前
Jetson Orin nano/nx刷机后无法打开chrome/firefox浏览器
前端·chrome·firefox
EchoEcho2 小时前
深入理解 Vue.js 渲染机制:从声明式到虚拟 DOM 的完整实现
vue.js
黄诂多2 小时前
APP原生与H5互调Bridge技术原理及基础使用
前端
前端市界2 小时前
用 React 手搓一个 3D 翻页书籍组件,呼吸海浪式翻页,交互体验带感!
前端·架构·github