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