ListViewの接続項目のIDを取得できますか?
-
10-12-2019 - |
質問
アプリケーションページには3つの接続されたListView Webパーツがあり、各Webパーツで選択されている項目にアクセスできるようになりたいです。これは「チェックボックス」のように選択されていませんが、フィルタ値を次のWeb部分に渡している接続項目。私はを試しました
myWebPart.Connections // empty
myWebPart.FilterValue // null
myWebPart.ConnectionID // null
.
と私のウェブ部品の他のすべての財産。接続されているアイテムのIDを取得する方法はありませんか?
解決
I created three web parts connected together and filterable using Title:
Choose a color -> Choose a fruit -> View fruit details.
I created the following selector (jQuery required):
$('img[alt="Selected"]').parent().next().children('div.ms-vb');
Which returns an array of the selected elements which have an ID attribute. You could then do a simple each and do the work you want with each ID.
$('img[alt="Selected"]').parent().next().children('div.ms-vb').each(function(i){
console.log($(this).attr('id'));
});
// will give you:
// 3 (Blue)
// 2 (Blueberry)
Shows up like this in Chrome console:
I think this will work as long as the you use the Title (linked to item) column in the web parts.
他のヒント
If you use JSLink instead, I think you can connect to the items in the ListView Web Part like this:
- In a location of your choice (such as SiteAssets library of your site, or in _catalogs/masterpage), create new JavaScript file.
- In the file, add the code below
- In your web part, reference this JavaScript file in the JSLink setting, like ~/site/SiteAssets/news_ui.js
(function () {
// Initialize the variables for overrides objects
var overrideCtx = {};
overrideCtx.Templates = {};
overrideCtx.Templates.Fields = {
'ID': { 'ItemID' : ctx.CurrentItem.ID }
};
SPClientTemplates.TemplateManager.RegisterTemplateOverrides(overrideCtx);
})();
Reference: