前端如何调用后端接口(HTML + JS & Vue )

本文将以 Go 语言后端 为例,详细介绍:

  • Go 后端接口如何设计
  • 接口的请求 / 响应结构
  • 前端如何用 HTML + JS 调用 Go 接口
  • 前端如何用 Vue 工程模式 调用 Go 接口
  • 两种方式的区别与适用场景

一、整体架构说明

前后端分离架构

浏览器
  |
  | HTTP 请求(JSON)
  ↓
前端(HTML / Vue)
  |
  | HTTP 请求
  ↓
Go 后端(API)
  |
  | JSON 响应
  ↓
前端渲染页面
  • 前端:负责 页面 + 交互
  • 后端(Go):负责 业务逻辑 + 数据处理
  • 通信方式:HTTP + JSON

二、Go 后端接口准备

先准备一个最简单但标准的 Go 接口,方便前端调用。

一个示例接口:用户登录

接口信息

项目内容
URL/user/login
方法POST
请求类型application/json
返回类型application/json

Go 后端代码示例

package main import ( "encoding/json" "net/http" ) type LoginRequest struct { Username string `json:"username"` Password string `json:"password"` } type Response struct { Code int `json:"code"` Msg string `json:"msg"` Data interface{} `json:"data,omitempty"` } func login(w http.ResponseWriter, r *http.Request) { // 只允许 POST if r.Method != http.MethodPost { w.WriteHeader(http.StatusMethodNotAllowed) return } var req LoginRequest if err := json.NewDecoder(r.Body).Decode(&req); err != nil { json.NewEncoder(w).Encode(Response{ Code: 400, Msg: "参数错误", }) return } // 模拟校验 if req.Username == "admin" && req.Password == "123456" { json.NewEncoder(w).Encode(Response{ Code: 200, Msg: "登录成功", Data: map[string]string{ "token": "mock-token-123", }, }) return } json.NewEncoder(w).Encode(Response{ Code: 401, Msg: "用户名或密码错误", }) } func main() { http.HandleFunc("/user/login", login) http.ListenAndServe(":8080", nil) } 

启动后端后,接口地址为:

http://localhost:8080/user/login

三、HTML + JavaScript 调用 Go 接口

这是最原始、最直观的方式,非常适合:

  • 学习 HTTP 请求本质
  • 不使用前端框架的简单项目
  • 理解 fetch / axios 的底层思想

1. HTML 页面结构

<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <title>登录页面</title> </head> <body> <h2>用户登录</h2> <form> <div> <input type="text" placeholder="用户名"> </div> <div> <input type="password" placeholder="密码"> </div> <button type="submit">登录</button> </form> <script src="login.js"></script> </body> </html> 

2. JavaScript 调用 Go 接口

const form = document.getElementById('loginForm'); form.addEventListener('submit', async function (e) { e.preventDefault(); // 阻止表单刷新页面 const username = document.getElementById('username').value; const password = document.getElementById('password').value; try { const res = await fetch('http://localhost:8080/user/login', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ username, password }) }); const data = await res.json(); if (data.code === 200) { alert('登录成功,token:' + data.data.token); } else { alert(data.msg); } } catch (err) { console.error(err); alert('请求失败'); } }); 

3.代码流程

监听表单提交阻止浏览器默认刷新获取输入框数据使用 fetch 发送 HTTP 请求请求体转成 JSON解析 Go 返回的 JSON根据 code 判断成功或失败

4. HTML + JS 的特点

✅ 优点:

  • 简单直接
  • 学习成本低
  • 无需工程化

❌ 缺点:

  • 代码容易混乱
  • 不适合复杂项目
  • 不利于组件复用

四、Vue 工程模式调用 Go 接口

这是实际开发中最常用的方式


1、Vue 项目基本结构

使用 Vite 创建 Vue 项目后,常见结构:

src/  ├── api/          # 所有接口请求  │    └── user.js  ├── views/        # 页面  │    └── Login.vue  ├── main.js

2、Vue 中封装 API 请求

 安装 axios

npm install axios

3. 创建 axios 实例(src/api/request.js)

import axios from 'axios' const request = axios.create({ baseURL: 'http://localhost:8080', timeout: 5000 }) export default request 

4. 用户接口封装(src/api/user.js)

import request from './request' export function login(data) { return request({ url: '/user/login', method: 'post', data }) }

5、Vue 页面中调用 Go 接口

Login.vue

<template> <div> <h2>用户登录</h2> <input v-model="username" placeholder="用户名" /> <input v-model="password" type="password" placeholder="密码" /> <button @click="handleLogin">登录</button> </div> </template> <script setup> import { ref } from 'vue' import { login } from '@/api/user' const username = ref('') const password = ref('') const handleLogin = async () => { try { const res = await login({ username: username.value, password: password.value }) if (res.data.code === 200) { alert('登录成功') console.log(res.data.data.token) } else { alert(res.data.msg) } } catch (err) { alert('请求失败') } } </script> 

五、Vue 调用流程总结

  1. 页面触发点击事件
  2. 调用封装好的 API 方法
  3. axios 发送 HTTP 请求
  4. Go 后端处理并返回 JSON
  5. Vue 根据返回结果更新 UI

六、前端调用 Go 接口时跨域问题

在实际开发中,很多同学在 HTML / Vue 调用 Go 接口 时,会在浏览器控制台看到类似错误:

Access to fetch at 'http://localhost:8080/user/login' from origin 'http://127.0.0.1:5500' has been blocked by CORS policy

这并不是 Go 代码写错,而是 浏览器的安全机制:跨域限制(CORS)

1.什么是跨域?

浏览器规定:
当前页面的“协议 + 域名 + 端口”必须和接口一致,否则就是跨域。

前端页面后端接口是否跨域
http://localhost:8080/login.htmlhttp://localhost:8080/user/login❌ 否
http://127.0.0.1:5500/login.htmlhttp://localhost:8080/user/login✅ 是
file:///login.htmlhttp://localhost:8080/user/login✅ 是

只要 有一个不一样,浏览器就会认为是跨域。

2.为什么 Vue / HTML 调用时容易跨域?

  • HTML 用 Live Server(5500 端口)
  • Vue 开发服务器(5173 端口)
  • Go 后端监听(8080 端口)

 端口不同 = 跨域

3. 跨域不是 Go 限制,而是浏览器限制

重点理解这句话:

跨域请求其实已经发到 Go 服务器了

是浏览器不让前端代码拿到响应

所以解决方案一定是:
 后端告诉浏览器:我允许你访问

4. Go 后端开启 CORS(通用做法)

1)最基础的 CORS 处理函数
func enableCORS(w http.ResponseWriter) { w.Header().Set("Access-Control-Allow-Origin", "*") w.Header().Set("Access-Control-Allow-Headers", "Content-Type") w.Header().Set("Access-Control-Allow-Methods", "GET, POST, OPTIONS") } 

2)在接口中使用(必须支持 OPTIONS)
func login(w http.ResponseWriter, r *http.Request) { enableCORS(w) // 预检请求,直接返回 if r.Method == http.MethodOptions { return } // 正常登录逻辑 } 

5.为什么一定要处理 OPTIONS 请求?

当你:

  • 使用 POST
  • 并且 Content-Type: application/json

浏览器会先发一个 OPTIONS 预检请求

OPTIONS /user/login

如果后端不处理:

 正式请求不会发送

6.Vue 项目中的跨域

Vue 开发阶段通常通过 代理解决跨域

// vite.config.js export default { server: { proxy: { '/api': { target: 'http://localhost:8080', changeOrigin: true } } } } 

七、HTML + JS vs Vue 

对比项HTML + JSVue
学习成本
工程化
代码组织
适合项目小 demo中大型项目

八、结语

无论你使用 HTML + JS 还是 Vue

 本质都是:前端通过 HTTP 请求调用 Go 接口

理解了:

  • 请求方法(GET / POST)
  • JSON 数据格式
  • 接口返回结构

你就掌握了前后端对接的核心能力

Read more

零基础玩转8MAV:你的第一个无人机编程项目

快速体验 1. 打开 InsCode(快马)平台 https://www.inscode.net 2. 点击'项目生成'按钮,等待项目生成完整后预览效果 输入框内输入如下内容: 创建一个适合新手的8MAV入门教程项目,包含:1.模拟器环境设置 2.基础飞行控制指令练习 3.简单航点任务编程 4.实时遥测数据显示。使用Blockly可视化编程界面,提供分步指导注释,所有代码不超过100行,能在30分钟内完成。 最近对无人机编程产生了兴趣,但手头没有硬件设备,又担心学习曲线太陡?别担心,通过8MAV模拟器和可视化编程工具,完全可以零成本开启无人机编程之旅。下面分享我的入门实践过程,从环境搭建到完成第一个飞行任务,全程只需要30分钟。 1. 模拟器环境设置 8MAV提供了完善的仿真环境,不需要购买任何硬件设备就能练习编程。我使用的是基于网页的模拟器,打开浏览器就能直接运行。最重要的是,模拟器完全还原了真实无人机的飞行物理特性,包括风速影响、

【无人机避障算法核心技术】:揭秘五种主流算法原理与实战应用场景

第一章:无人机避障算法概述 无人机避障算法是实现自主飞行的核心技术之一,其目标是在复杂环境中实时感知障碍物,并规划安全路径以避免碰撞。随着传感器技术和计算能力的提升,避障系统已从简单的距离检测发展为融合多源信息的智能决策体系。 避障系统的基本组成 典型的无人机避障系统包含以下关键模块: * 感知模块:利用激光雷达、超声波、立体视觉或RGB-D相机获取环境数据 * 数据处理模块:对原始传感器数据进行滤波、特征提取和障碍物识别 * 决策与规划模块:基于环境模型生成避障轨迹,常用算法包括A*、Dijkstra、RRT和动态窗口法(DWA) 常见避障算法对比 算法优点缺点适用场景A*路径最优,搜索效率高高维空间计算开销大静态环境全局规划DWA实时性强,适合动态避障局部最优风险室内低速飞行RRT*渐进最优,适应复杂空间收敛速度慢三维未知环境 基于深度学习的避障方法示例 近年来,端到端神经网络被用于直接从图像生成控制指令。以下是一个简化的行为克隆模型推理代码片段: import torch import torchvision.transforms as tran

AI绘画:解锁商业设计新宇宙(6/10)

AI绘画:解锁商业设计新宇宙(6/10)

1.AI 绘画:商业领域的潜力新星 近年来,AI 绘画技术以惊人的速度发展,从最初简单的图像生成,逐渐演变为能够创造出高度逼真、富有创意的艺术作品。随着深度学习算法的不断优化,AI 绘画工具如 Midjourney、Stable Diffusion 等的出现,更是让这一技术走进了大众的视野,引发了广泛的关注和讨论。这些工具不仅操作简便,而且能够在短时间内生成多种风格的绘画作品,大大降低了绘画创作的门槛。 AI 绘画在商业领域展现出了巨大的潜力。据相关数据显示,2021 年中国 AI 绘画市场规模仅为 0.1 亿元,而预计到 2026 年将激增至 154.66 亿元 ,年复合增长率高达 244.1%。这一迅猛的增长趋势,反映出 AI 绘画在商业应用中的广阔前景。越来越多的企业开始认识到 AI 绘画的价值,并将其应用到广告、插画、

Microi吾码:从零到服装ERP:低代码打造企业级系统的实战之旅

Microi吾码:从零到服装ERP:低代码打造企业级系统的实战之旅

个人主页:chian-ocean 文章专栏 从零到服装ERP:吾码平台打造企业级系统的实战之旅 关键词:吾码平台、低代码、服装ERP、多表关系、自动化、开发实例 引言 在传统的服装行业管理中,ERP系统已成为提高效率、降低成本、优化资源分配的核心工具。然而,开发一个功能全面、覆盖采购、库存、销售、财务等模块的ERP系统,往往需要投入大量时间和人力资源。在吾码低代码平台的支持下,1人仅用1个月便完成了包含100+表的企业级服装ERP系统。本文将从项目概述、开发细节到关键代码段详细剖析整个开发过程,展示低代码技术的强大能力。 第一部分:项目概览 1.1 项目背景 * 项目需求: * 支持采购、库存、销售、客户管理、财务报表等多个模块。 * 包括100+数据表,涵盖复杂的业务逻辑与数据关联。 * 需实现流程自动化(如采购审批、库存提醒)。 * 开发目标: * 快速完成开发,并保证系统稳定性与扩展性。