欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue2純前端實(shí)現(xiàn)文字流式輸出效果

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

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布局的實(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-06
  • element-ui中導(dǎo)航組件menu的一個(gè)屬性:default-active說(shuō)明

    element-ui中導(dǎo)航組件menu的一個(gè)屬性:default-active說(shuō)明

    這篇文章主要介紹了element-ui中導(dǎo)航組件menu的一個(gè)屬性:default-active說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-05-05
  • Vue Element前端應(yīng)用開(kāi)發(fā)之前端API接口的封裝

    Vue 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-05
  • window.onresize在vue中只能使用一次,自適應(yīng)resize報(bào)錯(cuò)問(wèn)題

    window.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-10
  • Vue中computed屬性和watch,methods的區(qū)別

    Vue中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-05
  • Vue動(dòng)態(tài)綁定class、style、background的方式

    Vue動(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-01
  • Vue+Element?switch組件的使用示例代碼詳解

    Vue+Element?switch組件的使用示例代碼詳解

    這篇文章主要介紹了Vue+Element?switch組件的使用,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • Vue?el-menu?左側(cè)菜單導(dǎo)航功能的實(shí)現(xiàn)

    Vue?el-menu?左側(cè)菜單導(dǎo)航功能的實(shí)現(xiàn)

    這篇文章主要介紹了Vue?el-menu?左側(cè)菜單導(dǎo)航功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-08-08
  • vue中ref和e.target的區(qū)別以及ref用法

    vue中ref和e.target的區(qū)別以及ref用法

    這篇文章主要介紹了vue中ref和e.target的區(qū)別以及ref用法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue實(shí)現(xiàn)簡(jiǎn)易圖片左右旋轉(zhuǎn),上一張,下一張組件案例

    vue實(shí)現(xiàn)簡(jiǎn)易圖片左右旋轉(zhuǎn),上一張,下一張組件案例

    這篇文章主要介紹了vue實(shí)現(xiàn)簡(jiǎn)易圖片左右旋轉(zhuǎn),上一張,下一張組件案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07

最新評(píng)論