添加markdown解析ai返回信息、添加purify动态清理无用缓存

This commit is contained in:
张梦南 2025-04-08 19:36:29 +08:00
parent db6ebc7b25
commit 2c117c1ca7
5 changed files with 90 additions and 40 deletions

View File

@ -40,18 +40,49 @@
word-break: break-word; word-break: break-word;
} }
.message.user { .message.user {
background-color: #daf1fc; background-color: #daf1fc;
align-self: flex-end; align-self: flex-end;
text-align: left; text-align: left;
margin-left: auto; margin-left: auto;
} }
.message.bot { .message.bot {
background-color: #eee; background-color: #eee;
align-self: flex-start; align-self: flex-start;
text-align: left; text-align: left;
margin-right: auto; margin-right: auto;
font-size: 14px;
line-height: 1.5;
}
/* 清除常见 markdown 元素的默认 margin */
.message.bot h1,
.message.bot h2,
.message.bot h3,
.message.bot p,
.message.bot ul,
.message.bot ol,
.message.bot pre,
.message.bot code {
margin: 0;
padding: 0;
font-size: inherit;
}
/* 更友好地渲染列表 */
.message.bot ul,
.message.bot ol {
padding-left: 1.2em;
}
/* 美化代码块 */
.message.bot pre {
background: #272822;
color: #f8f8f2;
padding: 8px;
overflow-x: auto;
border-radius: 4px;
} }
.input-row { .input-row {

View File

@ -67,6 +67,8 @@
<script src="javascape/ai_api.js"></script> <script src="javascape/ai_api.js"></script>
<script src="javascape/chat.js"></script> <script src="javascape/chat.js"></script>
<script src="javascape/max_width.js"></script> <script src="javascape/max_width.js"></script>
<script src="javascape/marked.min.js"></script>
<script src="javascape/purify.min.js"></script>
</body> </body>
</html> </html>

View File

@ -4,50 +4,58 @@ const API_KEY = 'sk-or-v1-4915a672258dc64f8d553da4df271fce635b6cdf86b296d45ccbde
const API_URL = 'https://openrouter.ai/api/v1/chat/completions'; const API_URL = 'https://openrouter.ai/api/v1/chat/completions';
let messages = []; let messages = [];
function appendMessage(content, sender) { function appendMessage(content, sender, isMarkdown = false) {
const chatContainer = document.getElementById('chatContainer'); const chatContainer = document.getElementById('chatContainer');
const messageDiv = document.createElement('div'); const messageDiv = document.createElement('div');
messageDiv.classList.add('message', sender); messageDiv.classList.add('message', sender);
messageDiv.textContent = content;
chatContainer.appendChild(messageDiv); if (isMarkdown) {
chatContainer.scrollTop = chatContainer.scrollHeight; // 将 Markdown 转为 HTML 并清理
const html = DOMPurify.sanitize(marked.parse(content));
messageDiv.innerHTML = html;
} else {
messageDiv.textContent = content;
}
chatContainer.appendChild(messageDiv);
chatContainer.scrollTop = chatContainer.scrollHeight;
} }
async function sendMessage() { async function sendMessage() {
const inputElem = document.getElementById('userInput'); const inputElem = document.getElementById('userInput');
const userMessage = inputElem.value.trim(); const userMessage = inputElem.value.trim();
if (!userMessage) return; if (!userMessage) return;
appendMessage(userMessage, 'user'); appendMessage(userMessage, 'user');
messages.push({ role: 'user', content: userMessage }); messages.push({ role: 'user', content: userMessage });
inputElem.value = ''; inputElem.value = '';
const payload = { const payload = {
//model: 'deepseek/deepseek-r1:free', model: 'deepseek/deepseek-chat-v3-0324:free',
model: 'deepseek/deepseek-chat-v3-0324:free', messages: messages
messages: messages };
};
try { try {
const response = await fetch(API_URL, { const response = await fetch(API_URL, {
method: 'POST', method: 'POST',
headers: { headers: {
'Content-Type': 'application/json', 'Content-Type': 'application/json',
'Authorization': 'Bearer ' + API_KEY 'Authorization': 'Bearer ' + API_KEY
}, },
body: JSON.stringify(payload) body: JSON.stringify(payload)
}); });
const data = await response.json();
if (data.choices && data.choices.length > 0) { const data = await response.json();
const botMessage = data.choices[0].message.content;
appendMessage(botMessage, 'bot'); if (data.choices && data.choices.length > 0) {
messages.push({ role: 'assistant', content: botMessage }); const botMessage = data.choices[0].message.content;
} else { appendMessage(botMessage, 'bot', true); // 这里启用 Markdown 渲染
appendMessage('没有收到有效响应,请检查 API 设置。', 'bot'); messages.push({ role: 'assistant', content: botMessage });
} else {
appendMessage('没有收到有效响应,请检查 API 设置。', 'bot');
}
} catch (error) {
console.error('请求错误:', error);
appendMessage('请求出错:' + error.message, 'bot');
} }
} catch (error) {
console.error('请求错误:', error);
appendMessage('请求出错:' + error.message, 'bot');
}
} }

6
javascape/marked.min.js vendored Normal file

File diff suppressed because one or more lines are too long

3
javascape/purify.min.js vendored Normal file

File diff suppressed because one or more lines are too long