Vue 前端基础笔记

Vue 前端基础笔记

跨域 + Vite 代理 + Vue 基础 + Axios 全套笔记


一、跨域

学科主题:浏览器安全策略 → 同源策略(Same-Origin Policy)

属于 前端网络 / HTTP 协议 / 浏览器安全 范畴。


二、什么是跨域?(最直白版)

1. 同源策略

浏览器规定:
前端所在的 协议、域名、端口 必须和后端完全一样,才能直接请求数据。

只要有一个不一样,就是 跨域

2. 什么时候跨域?

前端:http://localhost:5173(Vue/Vite 启动的)

后端:http://localhost:8080(SpringBoot)

端口不同 → 跨域!

浏览器就会报错:

复制代码
No Access-Control-Allow-Origin

意思:后端不允许你访问。


三、为什么前端不能直接请求后端接口?

因为 浏览器的安全限制,不是后端不让你访问,是浏览器拦截!

目的:

  • 防止恶意网站偷用户信息
  • 防止 CSRF 攻击
  • 保护接口不被随意调用

不是后端问题,是浏览器安全规则。


四、怎么解决跨域?(前端最常用:Vite 配置代理)

1. 什么是代理?

前端不直接请求后端

让 Vite 开发服务器帮你转发请求

→ 浏览器认为是同源,不拦截

2. vite.config.js 配置代理(固定写法)

js 复制代码
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'

export default defineConfig({
  plugins: [vue()],

  // 代理配置
  server: {
    proxy: {
      '/api': {
        target: 'http://localhost:8080', // 后端地址
        changeOrigin: true,             // 开启跨域
        rewrite: (path) => path.replace(/^\/api/, '')
      }
    }
  }
})

3. 作用

前端请求 /api/xxx

→ 自动转发到 http://localhost:8080/xxx

跨域问题解决


五、Vue 最基础使用(必背)

1. Vue 组件结构

vue 复制代码
<template>
  <!-- 页面结构 -->
  <div> 根元素只能有一个 </div>
</template>

<script>
export default {
  data() {
    return {
      // 数据
    }
  }
}
</script>

<style>
/* 样式 */
</style>

六、Vue 最常用指令(必背)

1. 文本插值

vue 复制代码
{{ name }}
js 复制代码
data() {
  return {
    name: "张三"
  }
}

2. 属性绑定

vue 复制代码
<img :src="imgUrl">
<input :value="msg">

3. 事件绑定

vue 复制代码
<button @click="handleClick">按钮</button>
js 复制代码
methods: {
  handleClick() { }
}

4. 双向绑定(表单)

vue 复制代码
<input v-model="keyword">

5. 条件渲染

vue 复制代码
<div v-if="type === 1">显示1</div>
<div v-else-if="type === 2">显示2</div>
<div v-else>显示3</div>

6. 列表渲染

vue 复制代码
<div v-for="item in list" :key="item.id">
  {{ item.name }}
</div>

七、Axios 网络请求(Vue 最常用)

1. 是什么?

基于 Promise 的网络请求库

前端专门用来调用后端接口。


2. 常用方法

js 复制代码
axios.get(url)
axios.post(url, data)
axios.put(url, data)
axios.delete(url)

3. 统一写法(最通用)

js 复制代码
axios({
  method: 'post',
  url: '/api/user/login',
  data: {
    username: '',
    password: ''
  }
})
.then(res => {})
.catch(err => {})

八、Axios 最常用完整示例

js 复制代码
axios.get("/api/order/list")
.then(res => {
  console.log(res.data)
})
.catch(err => {
  console.log(err)
})

九、今天所有知识总结

  1. 跨域:浏览器同源策略导致,前端不能直接访问不同端口/域名的后端
  2. 解决方式 :Vite 配置 proxy 代理
  3. Vue 组件<template> + <script> + <style>
  4. 常用指令{``{}} :src @click v-model v-if v-for
  5. Axios:前端请求后端接口工具
相关推荐
threerocks1 小时前
什么?我连 A2A、MCP 都没学会,现在又来了 AG-UI、A2UI.
前端·aigc·ai编程
牛奶2 小时前
如何自己写一个浏览器插件?
前端·chrome·浏览器
亿元程序员3 小时前
为什么Cocos都4.0了还有人用2.x?
前端
MomentYY3 小时前
AI 到底是“懂”,还是在“猜”?
前端·人工智能·ai编程
鹏毓网络科技3 小时前
Cursor Rules 文件配置实战:3 个隐藏参数让我每月少写 40% 样板代码
前端·github
没烦恼3013 小时前
无痕模式下 HTTP\-First 拦截引发的“页面刷新”误判
前端
ZhengEnCi3 小时前
Q02-Vue-React-index.html完全指南
vue.js·react.js·html
文心快码BaiduComate3 小时前
从个人提效到组织提效:Comate辅助构建自我进化的AI研发系统
前端·程序员
hunterandroid3 小时前
Compose 状态管理:remember、rememberSaveable 与状态提升
前端
星栈4 小时前
Dioxus 接数据库最容易写歪的 3 个地方:sqlx + SQLite 怎么接才顺
前端·rust·前端框架