Vue2純前端實現(xiàn)文字流式輸出效果
更新時間:2025年03月12日 16:14:26 作者:煮豆燃豆萁~
這篇文章主要為大家詳細介紹了Vue2純前端實現(xiàn)像chatGpt和Deepseek那樣的文字流式輸出效果的相關知識,文中的示例代碼講解詳細,有需要的可以了解下
1、先展示一下效果啦

文字流輸出
2、首先確定接口返回的是字符串,那就先調取接口
// 由于需求關系 有很多個文本需要一起逐字輸出 所以這里就采用了Promise.all的形式
async getThreeTextarea() {
let taskArray = [ "重點項目文本","應用領域文本", "用途文本","成果需求文本", "問題描述","建議描述",]
await Promise.all(taskArray.map((task, index) => {
// 這里調取接口
const promise = this.getContentThree(this.orderId, task, index);
// 這里是為取消行為做準備
this.streamThreePromises.push(promise);
return promise;
}));
},
async getContentThree(id,task,index) {
// 如果取消了 就停止請求接口
if (!this.cancelTokenSource) return
let response = await axios.post(`${home}/model/workflowsIndexThree`, {
id: id,
taskt: task,
}, {
// axios提供的取消請求的示例
cancelToken: this.cancelTokenSource.token
});
if (typeof response.data !== 'string') return
// 將字符串中的\n和\n\n都替換成<br>標簽
let formattedData = response.data.replace(/\n\n/g, '<br>').replace(/\n/g, '<br>');
// 賦值給對應的字段
let contentLabels = ['zdxmycText', 'yylyycText', 'ytycText', 'cgxqycText', 'wtzjText', 'jyzjText']
let contentProperty = contentLabels[index]
if (!contentProperty) return
// 這里就開始調用 逐字輸出的方法啦
const promise = this.streamTextUpdate(contentProperty, formattedData);
this.streamThreePromises.push(promise);
await promise;
},
async streamTextUpdate(contentProperty, data) {
if (typeof data !== 'string') {
data = JSON.stringify(data) || '';
}
let text = "";
// 遍歷字符串 然后每加一個字符就更新一下視圖
for (let i = 0; i < data.length; i++) {
if (this.streamCancellationToken) {
break;
}
// String.charAt(index)是找到指定索引的字符 類似于Array[index]
text += data.charAt(i);
this.$set(this, contentProperty, text);
await this.$nextTick();
// 每隔50毫秒輸出一個字符
await new Promise(resolve => setTimeout(resolve, 50));
}
},
// 提示取消操作 嫌啰嗦 其實可以不要
handleBeforeUnload(event) {
if (this.cancelTokenSource) {
this.cancelTokenSource.cancel('中斷操作');
}
this.streamCancellationToken = true;
this.streamThreePromises.forEach(promise => {
if (promise.cancel) {
promise.cancel();
}
});
const message = '正在關閉頁面,未完成的操作將被取消。';
return this.$message.warning(message)
},3、獲取完數(shù)據(jù)就可以將數(shù)據(jù)渲染上去了
<div class="fx-content" style="height: 300px;overflow-y: auto;" v-html="zdxmycText"></div>
4、渲染成功后,如果文字流輸出還沒有遍歷完 就關閉頁面,這時候就出現(xiàn)一個問題,當你在打開的時候,文字就會像蹦迪一樣(忽閃忽閃的)這時候就用到了 我們剛剛提到取消請求和中斷輸出
頁面初始化時
if (!this.cancelTokenSource) {
// 在頁面初始化的時候 就實例化一下取消請求的實例
this.cancelTokenSource = axios.CancelToken.source();
// 監(jiān)聽是否要取消操作
window.addEventListener('beforeunload', this.handleBeforeUnload.bind(this));
}
this.streamCancellationToken = false;
頁面銷毀時
// 在頁面銷毀的時候 取消監(jiān)聽
window.removeEventListener('beforeunload', this.handleBeforeUnload.bind(this));
if (this.cancelTokenSource) {
this.cancelTokenSource.cancel('中斷操作');
}
this.streamCancellationToken = true;
// 然后取消所有的promise
this.streamPromises.forEach(promise => {
if (promise.cancel) {
promise.cancel();
}
});
到此這篇關于Vue2純前端實現(xiàn)文字流式輸出效果的文章就介紹到這了,更多相關Vue2流式輸出內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
如何解決sass-loader和node-sass版本沖突的問題
這篇文章主要介紹了如何解決sass-loader和node-sass版本沖突的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04
Vue監(jiān)聽iframe加載失敗事件的三種實現(xiàn)方法
iframe 是一個 HTML 標簽,作用是文檔中的文檔,或者浮動的框架(frame),iframe 元素會創(chuàng)建包含另外一個文檔的內聯(lián)框架(即行內框架),本文給大家介紹了Vue監(jiān)聽iframe加載失敗事件的幾種實現(xiàn)方法,需要的朋友可以參考下2025-06-06
詳解VUE自定義組件中用.sync修飾符與v-model的區(qū)別
這篇文章主要介紹了詳解VUE自定義組件中用.sync修飾符與v-model的區(qū)別,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-06-06

