主頁 > .NET開發 > 無法擺脫全域變數(需要使其成為非全域變數)

無法擺脫全域變數(需要使其成為非全域變數)

2022-06-28 16:42:49 .NET開發

我正在開發一個顯示播放串列總持續時間的網路應用程式。在這里,我們正在處理 YouTube API。我想知道我應該如何擺脫全域變數newPageToken此外,我仍然需要在此代碼段的第三個函式中使用它。

let newPageToken = null;

// Next page for more results (Max 50 per page)
function getNextTokenURL() {
    console.log(newPageToken);
    return newPageToken
        ? `${playlistItemsURL}&playlistId=${extractedPlaylistIDId}&pageToken=${newPageToken}&key=${API_KEY}`
        : `${playlistItemsURL}&playlistId=${extractedPlaylistIDId}&key=${API_KEY}`;
}



async function getVideoIdsForPageToken() {
    try {
        const { data } = await axios.get(getNextTokenURL());
        const nextPageToken = data.nextPageToken;
        const videoIds = data.items.map((video) => {
            return video.contentDetails.videoId;
        });
        return { videoIds, nextPageToken };
    } catch (e) {
        if (e.response) {
            const { code, message } = e.response.data.error;
            throw new Error(`StatusCode ${code}. Reason: ${message}`);
            console.log("Errow while fetching videos list.");
        } else {
            throw new Error(e.message);
        }
    }
}



// Navigates between the videos per page and adds them (Maximum 50)
async function getPlaylistData() {
    try {
        const { videoIds, nextPageToken } = await getVideoIdsForPageToken();
        let pageToken = nextPageToken;
        newPageToken = pageToken;
        const returnedVideoIds = [];
        returnedVideoIds.push(getDetailsForVideoIds(videoIds));
        const videoGroups = await Promise.all(returnedVideoIds);



        for (const group of videoGroups) {
            for (const video of group) {
                finalTotalDuration  = returnedToSeconds(video.contentDetails.duration);
            }
        }

        // console.log(videoIds);
        if (nextPageToken) {
            await getPlaylistData();
        }
    } catch (e) {
        throw new Error(e.message);
        console.log("Error while navigating between video pages.");
    }
}```

uj5u.com熱心網友回復:

假設

  1. finalTotalDuration也是在某處宣告的全域變數(不是一個好主意)
  2. getPlaylistData為多個用戶呼叫多個播放串列

解決方案

您需要確保它getPlaylistData是獨立的并將 finalTotalDuration 作為回傳值回傳(不設定全域值)

為了使其獨立,它本質上必須是迭代的。它應該是一個遞回函式,它執行以下操作

async function getPlaylistTotalDuration(newPageToken) {

    // Step 1: Create the required query URL based on the newPageToken parameter
    // Step 2: Start a local duration counter
    // Step 3: Get the video details based on the URL created in Step 1
    // Step 4: Get the durations in seconds and add it to the local duration counter created in Step 2
    // Step 5: Check if the return of Step 3 has a nextPageToken, if so do a recursive call to self with the new token
    // Step 6: Return the final value, which will propogate back in a recursive function

}

您可以簡單地呼叫該函式

let finalTotalDuration = getPlaylistTotalDuration(null); // or getPlaylistTotalDuration();

例如以下getPlaylistTotalDuration是您的getPlaylistData方法的替代品


async function getVideoIdsForPageToken(url) {
    try {
        const { data } = await axios.get(url);
        const nextPageToken = data.nextPageToken;
        const videoIds = data.items.map((video) => {
            return video.contentDetails.videoId;
        });
        return { videoIds, nextPageToken };
    } catch (e) {
        if (e.response) {
            const { code, message } = e.response.data.error;
            throw new Error(`StatusCode ${code}. Reason: ${message}`);
            console.log("Errow while fetching videos list.");
        } else {
            throw new Error(e.message);
        }
    }
}


async function getPlaylistTotalDuration(newPageToken) {
    try {        
        // Step 1: Create the required query URL based on the newPageToken parameter
        let url = newPageToken
        ? `${playlistItemsURL}&playlistId=${extractedPlaylistIDId}&pageToken=${newPageToken}&key=${API_KEY}`
        : `${playlistItemsURL}&playlistId=${extractedPlaylistIDId}&key=${API_KEY}`;

        // Step 2: Start a local duration counter
        let totalDuration = 0;

        // Step 3: Get the video details based on the URL created in Step 1
        const { videoIds, nextPageToken } = await getVideoIdsForPageToken(url);
        const returnedVideoIds = [];
        returnedVideoIds.push(getDetailsForVideoIds(videoIds));
        const videoGroups = await Promise.all(returnedVideoIds);

        for (const group of videoGroups) {
            for (const video of group) {
                // Step 4: Get the durations in seconds and add it to the local duration counter created in Step 2
                totalDuration  = returnedToSeconds(video.contentDetails.duration);
            }
        }

        // Step 5: Check if the return of Step 3 has a nextPageToken, if so do a recursive call to self with the new token
        if (nextPageToken) {
            totalDuration  = await getPlaylistTotalDuration(nextPageToken);
        }

        // Step 6: Return the final value, which will propogate back in a recursive function
        return totalDuration;
    } catch (e) {
        throw new Error(e.message);
        console.log("Error while navigating between video pages.");
    }
}

注意:我實際上并沒有運行上面的代碼,但希望你對需要做什么有所了解。

轉載請註明出處,本文鏈接:https://www.uj5u.com/net/496461.html

標籤:javascript 节点.js 功能 全局变量

上一篇:C#檢查部分是否相交

下一篇:返回列表

標籤雲
其他(140916) Python(36177) JavaScript(23603) Java(15876) C(14647) 區塊鏈(8222) C#(7573) AI(7469) 爪哇(7061) html(6472) MySQL(6434) 基礎類(6313) 熊猫(5920) sql(5896) PHP(5549) 数组(5495) R(5186) 腳本語言(PerlPython)(5129) Linux(5047) 非技術區(4971) 反应(4890) Android(4340) 数据框(4187) css(4080) 节点.js(3801) C語言(3288) C++語言(3117) json(3088) 列表(3008) 扑(2915) 安卓(2867) 打字稿(2830) Java相關(2746) VBA(2708) 疑難問題(2699) 單片機工控(2479) 细绳(2447) ASP.NET(2287) iOS(2285) MongoDB(2229) 麻木的(2166) 正则表达式(2154) 字典(2139) 循环(2106) 擅长(2083) 镖(2037) 迅速(2034) Web開發(1951) 功能(1884) Unity3D(1814) python-3.x(1807) 弹簧靴(1806) 谷歌表格(1800) 網絡通信(1793) xml(1783) 蟒蛇-3.x(1774) 數據庫相關(1767) .NETCore(1761) VB基礎類(1755) for循环(1754)

熱門瀏覽
  • WebAPI簡介

    Web體系結構: 有三個核心:資源(resource),URL(統一資源識別符號)和表示 他們的關系是這樣的:一個資源由一個URL進行標識,HTTP客戶端使用URL定位資源,表示是從資源回傳資料,媒體型別是資源回傳的資料格式。 接下來我們說下HTTP. HTTP協議的系統是一種無狀態的方式,使用請求/ ......

    uj5u.com 2020-09-09 22:07:47 more
  • asp.net core 3.1 入口:Program.cs中的Main函式

    本文分析Program.cs 中Main()函式中代碼的運行順序分析asp.net core程式的啟動,重點不是剖析原始碼,而是理清程式開始時執行的順序。到呼叫了哪些實體,哪些法方。asp.net core 3.1 的程式入口在專案Program.cs檔案里,如下。ususing System; us ......

    uj5u.com 2020-09-09 22:07:49 more
  • asp.net網站作為websocket服務端的應用該如何寫

    最近被websocket的一個問題困擾了很久,有一個需求是在web網站中搭建websocket服務。客戶端通過網頁與服務器建立連接,然后服務器根據ip給客戶端網頁發送資訊。 其實,這個需求并不難,只是剛開始對websocket的內容不太了解。上網搜索了一下,有通過asp.net core 實作的、有 ......

    uj5u.com 2020-09-09 22:08:02 more
  • ASP.NET 開源匯入匯出庫Magicodes.IE Docker中使用

    Magicodes.IE在Docker中使用 更新歷史 2019.02.13 【Nuget】版本更新到2.0.2 【匯入】修復單列匯入的Bug,單元測驗“OneColumnImporter_Test”。問題見(https://github.com/dotnetcore/Magicodes.IE/is ......

    uj5u.com 2020-09-09 22:08:05 more
  • 在webform中使用ajax

    如果你用過Asp.net webform, 說明你也算是.NET 開發的老兵了。WEBform應該是2011 2013左右,當時還用visual studio 2005、 visual studio 2008。后來基本都用的是MVC。 如果是新開發的專案,估計沒人會用webform技術。但是有些舊版 ......

    uj5u.com 2020-09-09 22:08:50 more
  • iis添加asp.net網站,訪問提示:由于擴展配置問題而無法提供您請求的

    今天在iis服務器配置asp.net網站,遇到一個問題,記錄一下: 問題:由于擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載檔案,請添加 MIME 映射。 WindowServer2012服務器,添加角色安裝完.netframework和iis之后,運行aspx頁面 ......

    uj5u.com 2020-09-09 22:10:00 more
  • WebAPI-處理架構

    帶著問題去思考,大家好! 問題1:HTTP請求和回傳相應的HTTP回應資訊之間發生了什么? 1:首先是最底層,托管層,位于WebAPI和底層HTTP堆疊之間 2:其次是 訊息處理程式管道層,這里比如日志和快取。OWIN的參考是將訊息處理程式管道的一些功能下移到堆疊下端的OWIN中間件了。 3:控制器處理 ......

    uj5u.com 2020-09-09 22:11:13 more
  • 微信門戶開發框架-使用指導說明書

    微信門戶應用管理系統,采用基于 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層采用Boostrap + Metronic組合的前端框架,資料訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ......

    uj5u.com 2020-09-09 22:15:18 more
  • WebAPI-HTTP編程模型

    帶著問題去思考,大家好!它是什么?它包含什么?它能干什么? 訊息 HTTP編程模型的核心就是訊息抽象,表示為:HttPRequestMessage,HttpResponseMessage.用于客戶端和服務端之間交換請求和回應訊息。 HttpMethod類包含了一組靜態屬性: private stat ......

    uj5u.com 2020-09-09 22:15:23 more
  • 部署WebApi隨筆

    一、跨域 NuGet參考Microsoft.AspNet.WebApi.Cors WebApiConfig.cs中配置: // Web API 配置和服務 config.EnableCors(new EnableCorsAttribute("*", "*", "*")); 二、清除默認回傳XML格式 ......

    uj5u.com 2020-09-09 22:15:48 more
最新发布
  • 無法擺脫全域變數(需要使其成為非全域變數)

    我正在開發一個顯示播放串列總持續時間的網路應用程式。在這里,我們正在處理 YouTube API。我想知道我應該如何擺脫全域變數newPageToken。此外,我仍然需要在...

    uj5u.com 2022-06-28 16:42:49 more
  • C#檢查部分是否相交

    我有一個連續的 N 個固定尺寸的垂直和水平部分的串列,以一系列方向的形式(右→;左←;下↓;上↑)。如果這些部分相交,程式應該回傳 true。例如:N = 6: { 上、左、下...

    uj5u.com 2022-06-28 16:41:52 more
  • 不能在BMI計算器中使用浮點數

    我已經構建了以下代碼:# function to calculate bmi and return a result based on user inputdef calculatebmi(weight, height): bmivalue = weight //...

    uj5u.com 2022-06-28 16:40:55 more
  • ExcelSubtotal函式未創建表中數字的總和

    我有一個超級簡單的表格,其中有一列名為“Hours Book”。我正在嘗試獲取本專欄中的小時總和,但是似乎沒有任何功能可以實作這一點。我試過同時使用 sum 和 su...

    uj5u.com 2022-06-28 16:38:53 more
  • 使用PHPGET方法處理HTML表單

    我是 PHP 新手,我正在做一些簡單的練習來嘗試完全理解我學到的每一件事。我自信地輸出從表單輸入的資料,但對于這個特定的練習,我看不出我哪里出錯了。表單當...

    uj5u.com 2022-06-28 16:38:04 more
  • 是什么導致我在R中的分段函式中出現此錯誤?

    我正在嘗試使用以下引數在 R 中創建分段函式:##### Rules ##### If x from 2 to 6, x2# If x < 2, x-5# If x > 6, x^9因此,我制作了這個函式來嘗試擬合這些...

    uj5u.com 2022-06-28 16:36:48 more
  • 對Pandas資料框進行分組和統計分析的函式

    在下面的資料集中,我想撰寫一個執行以下操作的函式: 比較每個獨特mpg的油耗。No_of_cylindersmodel將所有結果(6 個模型)匯出為單個 csv 檔案# librariesimpor...

    uj5u.com 2022-06-28 16:36:00 more
  • constisType=<T>(type:string)=>(obj:unknown):objisT=>toString

    const isType = <T>(type: string) => (obj: unknown): obj is T => toString.call(obj) === `[object ${type}]`我知道這是一個判斷型別的功能,但是它使用...

    uj5u.com 2022-06-28 16:34:28 more
  • Javascript程式有問題,不知道為什么log的長度不是10?

    Javascript程式有問題,不知道為什么log的長度不是10?輸入 s :const s = "AAAAACCCCCAAAAACCCCCCAAAAAGGGTTT"var findRepeatedDnaSequences = function(s) {...

    uj5u.com 2022-06-28 12:59:03 more
  • Node.javascript獲取本地主機

    我正在嘗試關注視頻,但當我在網路瀏覽器中由本地主機加載時仍然無法獲取。我得到了一個監聽的控制臺日志,3000但似乎這一行:"app.use(express.static("/Users/...

    uj5u.com 2022-06-28 10:34:45 more