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:前端请求后端接口工具
相关推荐
小小小小宇1 小时前
GitLab + GitLab Runner + Qiankun 微前端 + Nginx + Node 中间件 前端开发机从零搭建 CI/CD 全流程
前端
哆哆啦001 小时前
obsidian远程同步方案:infiniCloud+remotely save方案
笔记·git·obsidian
前端那点事1 小时前
别再写垃圾组件!Vue3 如何设计「真正可复用」的高质量通用组件
前端·vue.js
卷帘依旧1 小时前
JavaScript 中的 Symbol
前端·javascript
老王以为1 小时前
Claude Code 从 GUI 到 TUI:开发者界面的范式回归
前端·人工智能·全栈
JYeontu1 小时前
正方体翻滚Loading 2.0
前端·javascript·css
llq_3501 小时前
React 组件处理 Props
前端
夫子3961 小时前
多人协同后内容丢失?一文搞懂ONLYOFFICE document.key的正确用法
前端
咸鱼翻身小阿橙1 小时前
Qt Quick 登录界面代码学习笔记
笔记·qt·学习