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

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

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

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布局的實現(xiàn)

    這篇文章主要介紹了從零開始在vue-cli4配置自適應(yīng)vw布局,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • element-ui中導(dǎo)航組件menu的一個屬性:default-active說明

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

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

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

    window.onresize在vue中只能使用一次,自適應(yīng)resize報錯問題

    這篇文章主要介紹了window.onresize在vue中只能使用一次,自適應(yīng)resize報錯問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue中computed屬性和watch,methods的區(qū)別

    Vue中computed屬性和watch,methods的區(qū)別

    本文主要介紹了Vue中computed屬性和watch,methods的區(qū)別,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-05-05
  • Vue動態(tài)綁定class、style、background的方式

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

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

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

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

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

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

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

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

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

最新評論