2026-01-19 23:45:08 +08:00
|
|
|
|
<!--
|
2026-02-23 01:50:43 +08:00
|
|
|
|
RealWorldApiDemo.vue - 紧凑版
|
|
|
|
|
|
目标:对比 HTTP 调用和 SDK 调用
|
2026-01-19 23:45:08 +08:00
|
|
|
|
-->
|
|
|
|
|
|
<template>
|
2026-02-23 01:50:43 +08:00
|
|
|
|
<div class="demo-root">
|
|
|
|
|
|
<div class="demo-header">
|
|
|
|
|
|
<span class="icon">⚡</span>
|
|
|
|
|
|
<span class="title">HTTP vs SDK:自己跑腿还是让管家代办?</span>
|
2026-02-18 17:38:10 +08:00
|
|
|
|
</div>
|
2026-01-20 08:51:04 +08:00
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
<div class="demo-layout">
|
|
|
|
|
|
<div class="tabs">
|
2026-01-20 08:51:04 +08:00
|
|
|
|
<button
|
|
|
|
|
|
:class="['tab', { active: mode === 'http' }]"
|
|
|
|
|
|
@click="mode = 'http'"
|
|
|
|
|
|
>
|
2026-02-23 01:50:43 +08:00
|
|
|
|
HTTP API
|
2026-01-20 08:51:04 +08:00
|
|
|
|
</button>
|
|
|
|
|
|
<button
|
|
|
|
|
|
:class="['tab', { active: mode === 'sdk' }]"
|
|
|
|
|
|
@click="mode = 'sdk'"
|
|
|
|
|
|
>
|
2026-02-23 01:50:43 +08:00
|
|
|
|
SDK
|
2026-01-20 08:51:04 +08:00
|
|
|
|
</button>
|
2026-01-19 23:45:08 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
<div class="code-area">
|
|
|
|
|
|
<div class="code-header">
|
|
|
|
|
|
<span>{{
|
|
|
|
|
|
mode === 'http' ? '自己处理所有细节' : '管家帮你处理'
|
|
|
|
|
|
}}</span>
|
2026-01-20 08:51:04 +08:00
|
|
|
|
</div>
|
2026-02-23 01:50:43 +08:00
|
|
|
|
<pre
|
|
|
|
|
|
class="code"
|
|
|
|
|
|
><code>{{ mode === 'http' ? httpCode : sdkCode }}</code></pre>
|
|
|
|
|
|
</div>
|
2026-01-20 08:51:04 +08:00
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
<div class="compare-panel">
|
|
|
|
|
|
<div class="compare-title">对比</div>
|
|
|
|
|
|
<div class="compare-list">
|
|
|
|
|
|
<div class="compare-item">
|
|
|
|
|
|
<span class="ci-label">代码量</span>
|
|
|
|
|
|
<span class="ci-val">{{ mode === 'http' ? '多' : '少' }}</span>
|
2026-01-20 08:51:04 +08:00
|
|
|
|
</div>
|
2026-02-23 01:50:43 +08:00
|
|
|
|
<div class="compare-item">
|
|
|
|
|
|
<span class="ci-label">错误处理</span>
|
|
|
|
|
|
<span class="ci-val">{{
|
|
|
|
|
|
mode === 'http' ? '自己写' : '自动处理'
|
|
|
|
|
|
}}</span>
|
2026-01-20 08:51:04 +08:00
|
|
|
|
</div>
|
2026-02-23 01:50:43 +08:00
|
|
|
|
<div class="compare-item">
|
|
|
|
|
|
<span class="ci-label">重试逻辑</span>
|
|
|
|
|
|
<span class="ci-val">{{
|
|
|
|
|
|
mode === 'http' ? '自己写' : '内置'
|
|
|
|
|
|
}}</span>
|
2026-01-19 23:45:08 +08:00
|
|
|
|
</div>
|
2026-02-23 01:50:43 +08:00
|
|
|
|
<div class="compare-item">
|
|
|
|
|
|
<span class="ci-label">类型提示</span>
|
|
|
|
|
|
<span class="ci-val">{{ mode === 'http' ? '无' : '有' }}</span>
|
2026-01-19 23:45:08 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
2026-02-23 01:50:43 +08:00
|
|
|
|
|
|
|
|
|
|
<div class="info-box">
|
|
|
|
|
|
<strong>核心思想:</strong>
|
|
|
|
|
|
<span>能用 SDK 就用 SDK,把麻烦事留给库,把时间留给自己。</span>
|
|
|
|
|
|
</div>
|
2026-01-19 23:45:08 +08:00
|
|
|
|
</div>
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script setup>
|
2026-01-20 08:51:04 +08:00
|
|
|
|
import { ref } from 'vue'
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
const mode = ref('sdk')
|
|
|
|
|
|
|
|
|
|
|
|
const httpCode = `import requests
|
|
|
|
|
|
|
|
|
|
|
|
response = requests.post(
|
|
|
|
|
|
"https://api.deepseek.com/v1/chat/completions",
|
|
|
|
|
|
headers={
|
|
|
|
|
|
"Authorization": "Bearer sk-xxx",
|
|
|
|
|
|
"Content-Type": "application/json"
|
|
|
|
|
|
},
|
|
|
|
|
|
json={
|
|
|
|
|
|
"model": "deepseek-chat",
|
|
|
|
|
|
"messages": [{"role": "user", "content": "你好"}]
|
|
|
|
|
|
}
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
if response.status_code == 200:
|
|
|
|
|
|
result = response.json()
|
|
|
|
|
|
content = result["choices"][0]["message"]["content"]
|
|
|
|
|
|
else:
|
|
|
|
|
|
# 处理错误...
|
|
|
|
|
|
pass`
|
|
|
|
|
|
|
|
|
|
|
|
const sdkCode = `from openai import OpenAI
|
|
|
|
|
|
|
|
|
|
|
|
client = OpenAI(
|
|
|
|
|
|
api_key="sk-xxx",
|
|
|
|
|
|
base_url="https://api.deepseek.com"
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
response = client.chat.completions.create(
|
|
|
|
|
|
model="deepseek-chat",
|
|
|
|
|
|
messages=[{"role": "user", "content": "你好"}]
|
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
|
|
content = response.choices[0].message.content`
|
2026-01-19 23:45:08 +08:00
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.demo-root {
|
2026-01-19 23:45:08 +08:00
|
|
|
|
border: 1px solid var(--vp-c-divider);
|
2026-02-23 01:50:43 +08:00
|
|
|
|
border-radius: 10px;
|
|
|
|
|
|
overflow: hidden;
|
2026-01-19 23:45:08 +08:00
|
|
|
|
background: var(--vp-c-bg-soft);
|
2026-02-23 01:50:43 +08:00
|
|
|
|
margin: 1rem 0;
|
|
|
|
|
|
font-size: 0.85rem;
|
2026-01-20 08:51:04 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.demo-header {
|
|
|
|
|
|
padding: 10px 16px;
|
2026-01-20 08:51:04 +08:00
|
|
|
|
background: var(--vp-c-bg);
|
2026-02-23 01:50:43 +08:00
|
|
|
|
border-bottom: 1px solid var(--vp-c-divider);
|
2026-01-19 23:45:08 +08:00
|
|
|
|
display: flex;
|
2026-01-20 08:51:04 +08:00
|
|
|
|
align-items: center;
|
|
|
|
|
|
gap: 8px;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.icon {
|
|
|
|
|
|
font-size: 18px;
|
2026-01-19 23:45:08 +08:00
|
|
|
|
}
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.title {
|
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
font-size: 0.9rem;
|
2026-01-19 23:45:08 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.demo-layout {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
flex-direction: column;
|
2026-01-19 23:45:08 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.tabs {
|
2026-01-20 08:51:04 +08:00
|
|
|
|
display: flex;
|
2026-02-23 01:50:43 +08:00
|
|
|
|
gap: 4px;
|
|
|
|
|
|
padding: 10px 12px;
|
|
|
|
|
|
background: var(--vp-c-bg);
|
2026-01-20 08:51:04 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
.tab {
|
2026-02-23 01:50:43 +08:00
|
|
|
|
padding: 6px 16px;
|
|
|
|
|
|
border: 1px solid var(--vp-c-divider);
|
|
|
|
|
|
border-radius: 6px;
|
|
|
|
|
|
background: transparent;
|
|
|
|
|
|
font-size: 0.85rem;
|
2026-01-20 08:51:04 +08:00
|
|
|
|
cursor: pointer;
|
|
|
|
|
|
transition: all 0.2s;
|
2026-01-19 23:45:08 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-01-20 08:51:04 +08:00
|
|
|
|
.tab.active {
|
2026-02-23 01:50:43 +08:00
|
|
|
|
background: var(--vp-c-brand);
|
2026-01-20 08:51:04 +08:00
|
|
|
|
color: white;
|
2026-02-23 01:50:43 +08:00
|
|
|
|
border-color: var(--vp-c-brand);
|
2026-01-19 23:45:08 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.code-area {
|
2026-01-20 08:51:04 +08:00
|
|
|
|
background: #1e293b;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.code-header {
|
|
|
|
|
|
padding: 6px 12px;
|
|
|
|
|
|
font-size: 0.75rem;
|
|
|
|
|
|
color: #94a3b8;
|
|
|
|
|
|
border-bottom: 1px solid #334155;
|
2026-01-20 08:51:04 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.code {
|
2026-01-20 08:51:04 +08:00
|
|
|
|
margin: 0;
|
2026-02-23 01:50:43 +08:00
|
|
|
|
padding: 12px;
|
|
|
|
|
|
font-family: 'Menlo', 'Monaco', monospace;
|
|
|
|
|
|
font-size: 0.72rem;
|
|
|
|
|
|
line-height: 1.5;
|
|
|
|
|
|
color: #e2e8f0;
|
|
|
|
|
|
overflow-x: auto;
|
|
|
|
|
|
white-space: pre;
|
2026-01-19 23:45:08 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.compare-panel {
|
|
|
|
|
|
padding: 12px;
|
|
|
|
|
|
background: var(--vp-c-bg);
|
2026-01-19 23:45:08 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.compare-title {
|
|
|
|
|
|
font-size: 0.8rem;
|
|
|
|
|
|
font-weight: 600;
|
|
|
|
|
|
margin-bottom: 8px;
|
2026-01-19 23:45:08 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.compare-list {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
gap: 12px;
|
|
|
|
|
|
flex-wrap: wrap;
|
2026-01-19 23:45:08 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.compare-item {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
align-items: center;
|
|
|
|
|
|
gap: 6px;
|
|
|
|
|
|
padding: 6px 10px;
|
|
|
|
|
|
background: var(--vp-c-bg-soft);
|
|
|
|
|
|
border-radius: 4px;
|
|
|
|
|
|
font-size: 0.75rem;
|
2026-01-20 08:51:04 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.ci-label {
|
|
|
|
|
|
color: var(--vp-c-text-2);
|
2026-01-20 08:51:04 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.ci-val {
|
|
|
|
|
|
font-weight: 600;
|
2026-01-19 23:45:08 +08:00
|
|
|
|
}
|
2026-01-20 08:51:04 +08:00
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.info-box {
|
|
|
|
|
|
display: flex;
|
|
|
|
|
|
gap: 0.25rem;
|
|
|
|
|
|
padding: 10px 14px;
|
|
|
|
|
|
background: var(--vp-c-bg-alt);
|
|
|
|
|
|
border-top: 1px solid var(--vp-c-divider);
|
|
|
|
|
|
font-size: 0.8rem;
|
|
|
|
|
|
color: var(--vp-c-text-2);
|
2026-01-20 08:51:04 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2026-02-23 01:50:43 +08:00
|
|
|
|
.info-box strong {
|
|
|
|
|
|
white-space: nowrap;
|
|
|
|
|
|
flex-shrink: 0;
|
2026-01-20 08:51:04 +08:00
|
|
|
|
}
|
2026-01-19 23:45:08 +08:00
|
|
|
|
</style>
|