Vue2純前端實現(xiàn)文字流式輸出效果
1、先展示一下效果啦
文字流輸出
2、首先確定接口返回的是字符串,那就先調(diào)取接口
// 由于需求關(guān)系 有很多個文本需要一起逐字輸出 所以這里就采用了Promise.all的形式 async getThreeTextarea() { let taskArray = [ "重點項目文本","應(yīng)用領(lǐng)域文本", "用途文本","成果需求文本", "問題描述","建議描述",] await Promise.all(taskArray.map((task, index) => { // 這里調(diào)取接口 const promise = this.getContentThree(this.orderId, task, index); // 這里是為取消行為做準(zhǔn)備 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>標(biāo)簽 let formattedData = response.data.replace(/\n\n/g, '<br>').replace(/\n/g, '<br>'); // 賦值給對應(yīng)的字段 let contentLabels = ['zdxmycText', 'yylyycText', 'ytycText', 'cgxqycText', 'wtzjText', 'jyzjText'] let contentProperty = contentLabels[index] if (!contentProperty) return // 這里就開始調(diào)用 逐字輸出的方法啦 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 = '正在關(guān)閉頁面,未完成的操作將被取消。'; 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、渲染成功后,如果文字流輸出還沒有遍歷完 就關(guān)閉頁面,這時候就出現(xiàn)一個問題,當(dāng)你在打開的時候,文字就會像蹦迪一樣(忽閃忽閃的)這時候就用到了 我們剛剛提到取消請求和中斷輸出
頁面初始化時
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(); } });
到此這篇關(guān)于Vue2純前端實現(xiàn)文字流式輸出效果的文章就介紹到這了,更多相關(guān)Vue2流式輸出內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
從零開始在vue-cli4配置自適應(yīng)vw布局的實現(xiàn)
這篇文章主要介紹了從零開始在vue-cli4配置自適應(yīng)vw布局,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06element-ui中導(dǎo)航組件menu的一個屬性:default-active說明
這篇文章主要介紹了element-ui中導(dǎo)航組件menu的一個屬性:default-active說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-05-05Vue Element前端應(yīng)用開發(fā)之前端API接口的封裝
對整個系統(tǒng)來說,一般會有很多業(yè)務(wù)對象,而每個業(yè)務(wù)對象的API接口又有很多。我們這個VUE+Element 前端應(yīng)用就是針對ABP框架的業(yè)務(wù)對象,因此前端的業(yè)務(wù)對象接口也是比較統(tǒng)一的,那么可以考慮在前端中對后端API接口調(diào)用進(jìn)行封裝,引入ES6的方式進(jìn)行前端API的抽象簡化。2021-05-05window.onresize在vue中只能使用一次,自適應(yīng)resize報錯問題
這篇文章主要介紹了window.onresize在vue中只能使用一次,自適應(yīng)resize報錯問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-10-10Vue中computed屬性和watch,methods的區(qū)別
本文主要介紹了Vue中computed屬性和watch,methods的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2023-05-05Vue動態(tài)綁定class、style、background的方式
文章主要介紹了在Vue.js中如何使用動態(tài)綁定class、style和background來實現(xiàn)動態(tài)樣式和背景圖的設(shè)置,通過v-bind指令,可以靈活地根據(jù)數(shù)據(jù)變化來動態(tài)更新元素的樣式和背景2025-01-01Vue?el-menu?左側(cè)菜單導(dǎo)航功能的實現(xiàn)
這篇文章主要介紹了Vue?el-menu?左側(cè)菜單導(dǎo)航功能,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08vue中ref和e.target的區(qū)別以及ref用法
這篇文章主要介紹了vue中ref和e.target的區(qū)別以及ref用法,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03vue實現(xiàn)簡易圖片左右旋轉(zhuǎn),上一張,下一張組件案例
這篇文章主要介紹了vue實現(xiàn)簡易圖片左右旋轉(zhuǎn),上一張,下一張組件案例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-07-07