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:前端请求后端接口工具
相关推荐
袋鼠云数栈几秒前
从前端到基础设施,ACOS 如何打通企业全链路可观测
运维·前端·人工智能·数据治理·数据智能
AskHarries6 分钟前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
Moment20 分钟前
长上下文会最终杀死 Rag 吗?
前端·javascript·后端
qcx231 小时前
【系统学AI】25 论文导读 ①:两篇改变 AI 的开山之作——Attention Is All You Need & ReAct
前端·人工智能·react.js·transformer
AOwhisky1 小时前
Ceph系列第六期:Ceph 文件系统(CephFS)精讲
linux·运维·网络·笔记·ceph
萤萤七悬1 小时前
【Python笔记】AI帮实现CLI工具-使用argparse.ArgumentParser接收命令参数
开发语言·笔记·python
kyriewen2 小时前
大文件上传最全指南:分片、断点续传、秒传,一篇就够了
前端·javascript·面试
郑洁文3 小时前
基于Python的Web命令执行漏洞自动化检测系统
前端·python·网络安全·自动化
新酱爱学习3 小时前
手搓 10 个 Skill 后,我把重复劳动收敛成了一套零依赖 CLI 工具
前端·javascript·人工智能
IT_陈寒3 小时前
Python的线程池居然把我坑在了垃圾回收这块
前端·人工智能·后端