簡體   English   中英

檢索數組JS中的所有對象

[英]retrieving all objects in an array JS

我正在ServiceNow中工作,並試圖建立一個數組來檢索與用戶有關的所有知識文章。 我下面的代碼僅返回文章之一,我不確定為什么...有什么建議嗎?

var kaArray = [];
var ka = new GlideRecord('my_knowledge');
ka.addQuery('workflow_state', 'Published');
ka.addQuery('kb_category.label', 'Benefits');
ka.addQuery('occ_series', 'CONTAINS', occ)
  .addOrCondition('location', 'CONTAINS', loc)
  .addOrCondition(
    ka.addNullQuery('location') && ka.addNullQuery('occ_series')
  );    
ka.orderByDesc('sys_updated_on');
ka.query();
while(ka.next()) {
    obj = {number: ka.number.toString(),
           short_desc: ka.short_description.toString(),
           url: 'kb_view.do?sysparm_article=' + ka.number}; 
    kaArray.push(obj);
}

我建議您做幾件事,其中之一可能是解決您的問題的方法。

  1. 您正在使用條件運算符“ &&”來..那么恐怕我不太確定。 您無法以嘗試的方式在JavaScript中執行此操作。 另外,由於.addOrCondition()不會返回您要用作布爾值的值),所以這將無法工作。 相反,只需將下一個命令放在下一行。 我將在底部顯示代碼的完成版本。

  2. 代替這些復雜的.addNullQuery()addQuery()和.addOrCondition()調用序列,只需導航到您要過濾的表,然后在條件生成器中實際構建過濾器即可。 然后,右鍵單擊最終的篩選器面包屑,然后單擊“復制查詢”,然后使用.addEncodedQuery() 像這樣:

復制查詢 gr.addEncodedQuery('short_descriptionLIKEeclipse ^ kb_category = c78a2d2047b002007f47563dbb9a71bf ^ workflow_state = published'/ 單擊“復制查詢”的結果 /);

  1. 為什么要使用作用域內的應用程序和自定義表? 如果您打算在市場上將范圍限定的應用程序列出來,那么該應用程序很有意義,但是根據表名,聽起來像是針對特定企業的。 我推薦一個全球性的應用程序,如果有的話。 我還強烈建議(無論是范圍內的還是全局的)您只創建一個新的知識庫,而不是創建一個新的表,除非您擁有此知識庫中需要的一些高級功能,並且願意犧牲很多OOB功能為拿到它,為實現它。 不是說您在做什么是錯誤的,只是要確保您知道自己可能會自己創建的麻煩。 :-)

  2. 據我所知,您無需使用CURRENT配置,就不必擔心JavaScript的傳遞引用特質,我看不到您在任何地方聲明“ obj”。 您可能想要這樣做,並給它起一個更好的名字。 不過,您可能想對添加到該數組的對象進行功能化。 如果#5不正確,那么問題很可能是由於我錯過了一個裁判通過問題,至少這是我的猜測。 我可以看到您的while循環內第三行至少有一個傳遞引用問題:

    網址:“ kb_view.do?sysparm_article =” + ka.number};

始終使用“獲取器和設置器”。 也就是說,當您想要GlideRecord中的值時,切勿直接引用gr.fieldName 而是使用gr.getValue('fieldName'); 作為一種選擇(我不喜歡,但沒有合理的理由不這樣做),您也可以使用.toString() ,就像在其他地方一樣。 這將值顯式轉換為字符串,而不是其所屬的對象(GlideElement對象)。 我不是很喜歡這個,因為這意味着您正在將對象強制轉換為STRING。 這樣做沒有EASY路徑,因此它依賴於GlideElement類的內置方法來覆蓋大多數其他類型的.toString方法。

  1. 我敢打賭,無論采用哪種方式編寫的查詢,都只會返回一條記錄。 您可以使用gs.info('Looking through ' + ka.getRowCount() + ' records.');類的東西輕松地進行測試gs.info('Looking through ' + ka.getRowCount() + ' records.'); 查詢后。

對於您,我謹向您推薦“ Learning ServiceNow ”。 完全公開,這是我自己的書。 就是說,我專門為那些完全掌握您的知識和經驗的人量身定制了這本書,並且我認為您會從中學到很多。 大多數SN開發人員會從中受益匪淺,但是我認為您處於發揮最大作用的特殊位置。 我知道它說是6月9日,但是應該在本月底或幾天之內發布。

這是我認為您要嘗試執行的操作的一個版本,該版本應該有效。 我確定查詢將需要進行一些調整-我不得不猜測您要做什么,但是我認為^ NQ的使用與您要完成的工作最接近。 就像我說的那樣,只需在表上構建查詢,然后將其復制到encQuery(並替換我現有的邏輯/從buildEncQuery返回正確的查詢)。 這里是:

 /**
 * encQuery will hold the temporary and final encoded query strings, which will look something like this (when finished):
 * "workflow_state=published^kb_category.label=Benefits^federal_occ_seriesLIKEOCC_HERE^ORlocationLIKELOC_HERE^NQworkflow_state=published^kb_category.label=Benefits^locationISEMPTY^federal_occ_seriesISEMPTY"
 * @type {String}
 */
var encQuery = buildEncQuery(occ, loc); //occ and loc were used in your original queries, so I assume they're variables that are available to you in this scope at this point in your script. 
/**
 * An array of objects, each containing data about knowledge articles returned from our query using encQuery.
 * @type {{name: string, short_desc: string, url: string}[]}
 */
var knowledgeArray = [];
/**
 * The GR we're iterating over
 * @type {GlideRecord}
 */
var knowledgeGR = new GlideRecord('x_81991_federal_hc_federal_knowledge');
knowledgeGR.addEncodedQuery(encQuery);
knowledgeGR.orderByDesc('sys_updated_on');
knowledgeGR.query();
while (knowledgeGR.next()) {
    knowledgeArray.push({
                     number:     knowledgeGR.getValue('number'),
                     short_desc: knowledgeGR.getValue('short_description'),
                     url:        'kb_view.do?sysparm_article=' + knowledgeGR.getValue('number')
                 });
}
gs.info('Located ' + knowledgeGR.getRowCount() + ' records. Array length: ' + knowledgeArray.length + '.');
//Done

/**
 * Builds the encoded query for the calling function.
 * @param occ {*}
 * @param loc {*}
 * @returns {string}
 */
function buildEncQuery(occ, loc) {
    if (occ === undefined || loc === undefined) {
        return;
    }
    var encQuery = 'workflow_state=published^kb_category.label=Benefits'
    encQuery += '^federal_occ_seriesLIKE' + occ + '^ORlocationLIKE' + loc + '^NQ' + encQuery + '^locationISEMPTY^federal_occ_seriesISEMPTY';
    return encQuery;
}

編輯:我注意到您在StackOverflow中發布了很多內容。 但是,問題一旦被回答,您似乎並沒有將其標記為已回答。 我建議您這樣做,但是我也建議您查看sndevs.slack.com 這是一個由其他ServiceNow開發人員組成的社區。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM