feat(api): 添加多路由代理处理实现
- 新增api目录下多个接口路径代理处理文件,支持动态拼接目标URL - 根据环境变量选择不同的后端服务地址(如dev和生产环境) - 统一添加TenantId和Authorization请求头传递租户及身份信息 - 实现请求参数及搜索参数的完整转发 - 引入better-sqlite3及node内建模块支持服务端功能 - 新增专家详情页面,实现文章、成果及预约咨询功能展示 - 页面实现加载骨架屏、标签页切换及空状态提示优化体验
This commit is contained in:
8
.output/server/chunks/build/index-styles.roYPIOiz.mjs
Normal file
8
.output/server/chunks/build/index-styles.roYPIOiz.mjs
Normal file
@@ -0,0 +1,8 @@
|
||||
const index_vue_vue_type_style_index_0_scoped_f62ec455_lang = ".expert-page[data-v-f62ec455]{margin:0 auto;max-width:1200px;padding:40px 20px}.page-header[data-v-f62ec455]{margin-bottom:40px;text-align:center}.page-title[data-v-f62ec455]{color:#1f2937;font-size:32px;font-weight:700;margin:0 0 12px}.page-desc[data-v-f62ec455]{color:#6b7280;font-size:16px;margin:0}.category-tabs[data-v-f62ec455]{margin-bottom:32px;text-align:center}.expert-list[data-v-f62ec455]{display:flex;flex-direction:column;gap:20px}.expert-item[data-v-f62ec455]{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000000f;cursor:pointer;display:flex;gap:20px;padding:20px;transition:all .2s}.expert-item[data-v-f62ec455]:hover{box-shadow:0 4px 16px #0000001a;transform:translateY(-2px)}.expert-avatar[data-v-f62ec455],.expert-default-avatar[data-v-f62ec455]{border-radius:50%;flex-shrink:0;height:80px;overflow:hidden;width:80px}.expert-avatar img[data-v-f62ec455]{height:100%;-o-object-fit:cover;object-fit:cover;width:100%}.expert-default-avatar[data-v-f62ec455]{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;font-size:32px;font-weight:700;justify-content:center}.expert-content[data-v-f62ec455]{flex:1}.expert-title[data-v-f62ec455]{color:#1f2937;font-size:18px;font-weight:600;margin:0 0 8px}.expert-meta[data-v-f62ec455]{color:#6b7280;display:flex;font-size:12px;gap:12px;margin-bottom:8px}.expert-overview[data-v-f62ec455]{color:#6b7280;font-size:14px;line-height:1.6;margin:0}.empty-placeholder[data-v-f62ec455],.loading-placeholder[data-v-f62ec455]{padding:60px 0;text-align:center}.pagination-wrap[data-v-f62ec455]{margin-top:40px;text-align:center}";
|
||||
|
||||
const indexStyles_roYPIOiz = [
|
||||
index_vue_vue_type_style_index_0_scoped_f62ec455_lang
|
||||
];
|
||||
|
||||
export { indexStyles_roYPIOiz as default };
|
||||
//# sourceMappingURL=index-styles.roYPIOiz.mjs.map
|
||||
Reference in New Issue
Block a user