gpt4 book ai didi

angularjs - SharePoint JSOM KeywordQuery 更改它正在搜索的 ContentType

转载 作者:行者123 更新时间:2023-12-02 23:31:49 26 4
gpt4 key购买 nike

我目前正在使用 AngularJS 和 SharePoint JSOM 对结果源执行一些关键字查询。

我有一个接受 ResultSourceName 和 ResultSourceLevel 变量的 angular.factory

angular.module('app.services.sharepoint').factory('resultSourceDataSvc', ['$log', '$q', '$timeout', function ($log, $q, $timeout) {
return function (resultSourceName, resultSourceLevel) {
return new ResultSourceDataService($log, $q, $timeout, resultSourceName, resultSourceLevel);
}
}]);

这被注入(inject)到我的 Controller 中,他们像这样使用它:

var inTheNewsResultDataSource = resultSourceData('TSToday In The News Result Source', 'SPSite');
inTheNewsResultDataSource.ready(function () {
inTheNewsResultDataSource.getData(null, IN_THE_NEWS_COLUMNS, IN_THE_NEWS_MAP_COLUMNS)
.then(function (data) {
$log.debug('Resolving data:', data);
deferred.resolve(data);
},
function (resp) {
$log.error('Error while attempting to retrieve In The News data:', resp);
deferred.reject(resp);
});
});

这一切的实际内容是在从我的工厂返回的 ResultSourceDataService 中处理的,以下是其中的代码:

function ResultSourceDataService($log, $q, $timeout, resultSourceName, resultSourceLevel) {
var deferred = $q.defer(),
promise = deferred.promise,
context = undefined,
resultSourceQuery = undefined,
resultSourceExecutor = undefined,
properties = undefined;

$log = $log.getInstance('app.services.sharepoint.resultSourceDataSvc(' + resultSourceName + ')');

function init() {
$log.debug('Initializing new Result Source Data Service for:', resultSourceName, 'on', resultSourceLevel);

SP.SOD.registerSod('sp.search.js', '/_layouts/15/sp.search.js');

SP.SOD.loadMultiple(['sp.js', 'sp.search.js'], function () {
context = SP.ClientContext ? SP.ClientContext.get_current() : undefined;

// should probably add error checking to make sure context is loaded here

resultSourceQuery = new Microsoft.SharePoint.Client.Search.Query.KeywordQuery(context);
resultSourceExecutor = new Microsoft.SharePoint.Client.Search.Query.SearchExecutor(context);

resultSourceQuery.set_trimDuplicates(false);

resultSourceQuery.get_properties().set_item('SourceName', resultSourceName);
resultSourceQuery.get_properties().set_item('SourceLevel', resultSourceLevel);

$log.debug('Initialized');
deferred.resolve();
});
}
init();

//#region Private Functions
function setSelectProperties(columnsToRetrieve) {
properties = resultSourceQuery.get_selectProperties();

for (var i = columnsToRetrieve.length; i-- > 0;) {
$log.debug('Adding in property to retrieve', columnsToRetrieve[i]);
properties.add(columnsToRetrieve[i]);
}
}
function getResults(data, columnsToRetrieve, columnsToMap) {
return data.map(function (obj, i) {
var result = columnsToRetrieve.length == 0 ? obj : {};
for (var j = columnsToRetrieve.length; j-- > 0;) {
result[columnsToMap[j]] = obj[columnsToRetrieve[j]];
}
$log.debug('getResult', result);

return result;
});
}
//#endregion

//#region Public Functions
this.getData = function (keyword, columnsToRetrieve, columnsToMap) {
var deferred = $q.defer(),
promise = deferred.promise,
data = undefined,
results = [];

keyword = keyword || '*';
columnsToRetrieve = columnsToRetrieve || [];
columnsToMap = columnsToMap || columnsToRetrieve;

resultSourceQuery.set_queryText(keyword);
setSelectProperties(columnsToRetrieve);

$log.info('Attempting to retrieve data from result source with keyword:', keyword, resultSourceQuery);

data = resultSourceExecutor.executeQuery(resultSourceQuery);

context.executeQueryAsync(
function (sender, args) {
$log.debug('Data retrieved successfully', data.get_value().ResultTables);
results = getResults(data.get_value().ResultTables[0].ResultRows, columnsToRetrieve, columnsToMap);
$log.info('Resolving data', results);
deferred.resolve(results);
},
function (sender, args) {
$log.error('Error with resolving data in ResultSourceDataService', args.get_message());
deferred.reject(args.get_message());
});

return promise;
}
this.ready = function (fn) {
promise.then(fn);
}
//#endregion
}

当我加载运行此代码的页面时,它运行良好。当我刷新页面时,它运行正常。但是,如果我从网站内的任何其他页面导航到此页面,它就会中断并返回数据,就好像没有指定结果源一样。

出于某种原因,QueryModification(如果我是正确的,本质上告诉它我们在查询中寻找什么ContentType)正在改变。当我最初加载页面并查看记录到控制台的数据时($log.debug('Data检索成功', data.get_value().ResultTables);),我可以向下钻取进入其中并查看 QueryModification 中的差异。

当它正常运行时(刷新页面或直接从网站外部导航到该页面),我看到值 ContentTypeId:0x0100A9723709C6D74A77B01EA922C770FDD0*,这是正确的。然而;如果我从 SharePoint 内部导航到该页面,我会看到 * -ContentClass=urn:content-class:SPSPeople 的值,因此它返回的结果将在我未指定结果源时显示名称。

当我向它传递相同的变量时,有什么想法可能会导致这种情况吗?

最佳答案

不知道为什么会这样,但是删除

        resultSourceQuery.get_properties().set_item('SourceName', resultSourceName);
resultSourceQuery.get_properties().set_item('SourceLevel', resultSourceLevel);

init 方法并将其添加到 getData 方法解决了该问题。不知道为什么它会起作用,因为如果调用代码使用 ready 方法,则应始终在 getData 方法之前设置它。

如果有人明白为什么会解决这个问题,请指出。与此同时,我的问题已经解决。

关于angularjs - SharePoint JSOM KeywordQuery 更改它正在搜索的 ContentType,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32786746/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com