0

0

使用 ServiceNow 引用限定符动态过滤目录项变量

霞舞

霞舞

发布时间:2025-09-28 20:27:17

|

314人浏览过

|

来源于php中文网

原创

使用 servicenow 引用限定符动态过滤目录项变量

本文旨在帮助 ServiceNow 开发者解决目录项中引用类型变量的引用限定符不生效的问题。通过本文,你将学习如何利用脚本包含和 GlideRecord,结合 sys_idIN 操作符,动态过滤引用类型变量的选项,使其仅显示与特定条件匹配的值。

问题描述

在 ServiceNow 的目录项中,我们经常需要使用引用类型变量,并根据用户的选择或其他变量的值来动态过滤引用选项。例如,一个 listId 变量引用 service_offer 表,我们希望根据 account 变量的值,只显示与该账户相关的服务项目。虽然配置了引用限定符,但实际效果却是显示了 service_offer 表中的所有值,未能实现动态过滤。

解决方案

解决此问题的关键在于正确使用 sys_idIN 操作符,并确保脚本包含返回的是一个包含有效 sys_id 的字符串。

  1. 修改引用限定符脚本:

    将引用限定符脚本修改为以下格式:

    javascript: "sys_idIN" + new OfferingServices().gettingList(current.variables.account);

    这里,sys_idIN 操作符会接收一个以逗号分隔的 sys_id 字符串,并只显示 sys_id 在该字符串中的记录。

  2. 修改脚本包含:

    Imagen – Google Research
    Imagen – Google Research

    Google Brain team推出的图像生成模型。

    下载

    确保脚本包含 OfferingServices 中的 gettingList 函数返回的是一个以逗号分隔的 sys_id 字符串。

    var OfferingServices = Class.create();
    OfferingServices.prototype = Object.extendsObject(global.AbstractAjaxProcessor, {
        gettingList: function(value){
            var results = [];
            if(value){
                var gr = new GlideRecord('service_offer');
                gr.addQuery('account', value); // 直接使用 account 字段,假设它是一个引用类型
                gr.query();
                while (gr.next()) {
                    results.push(gr.getValue('sys_id')); // 只需 sys_id
                }
            }
            //gs.info('sys_ids ==> '+ results.join(',')); //调试用,可以注释掉
            return results.join(',');
        },
        type: 'OfferingServices'
    });

    注意:

    • 将 gr.addQuery('account.sys_id', value) 修改为 gr.addQuery('account', value)。 假设 account 字段本身就是一个引用类型字段,直接比较 sys_id 更简洁。
    • results.push({ name: gr.getValue('name'), deviceSolutionID: gr.getValue('sol_id') });修改为results.push(gr.getValue('sys_id')); 只需要返回 sys_id 即可,无需其他字段。
    • 将 return JSON.stringify(results); 修改为 return results.join(',');,返回一个以逗号分隔的 sys_id 字符串。
    • 确保脚本包含是客户端可调用的(Client Callable)。
    • 添加 type: 'OfferingServices' 到脚本包含定义中。

示例

假设 service_offer 表中有以下数据:

sys_id name account (sys_id)
111111111111111111111111111 Offer A 222222222222222222222222222
333333333333333333333333333 Offer B 222222222222222222222222222
444444444444444444444444444 Offer C 555555555555555555555555555

当 current.variables.account 的值为 222222222222222222222222222 时,OfferingServices().gettingList(current.variables.account) 将返回字符串 "111111111111111111111111111,333333333333333333333333333"。因此,listId 变量的引用选项将只显示 "Offer A" 和 "Offer B"。

注意事项

  • 确保 account 变量的值是有效的 sys_id。
  • 如果脚本包含返回的字符串过长,可能会超出 URL 的长度限制。在这种情况下,可以考虑使用 GlideAjax 和服务器端脚本来处理。
  • 使用 gs.info() 进行调试时,请确保在生产环境中移除或注释掉这些代码。

总结

通过使用 sys_idIN 操作符和正确编写脚本包含,我们可以轻松地实现 ServiceNow 目录项中引用类型变量的动态过滤,从而提高用户体验和数据准确性。记住,关键在于理解 sys_idIN 的工作原理,并确保脚本包含返回的是一个有效的 sys_id 字符串。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

402

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

528

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

306

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

248

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

205

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1435

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

609

2023.11.24

php源码安装教程大全
php源码安装教程大全

本专题整合了php源码安装教程,阅读专题下面的文章了解更多详细内容。

3

2025.12.31

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.1万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 1.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号