ECB について質問があります。Sharepoint 2013 で、JSLink を使用してビューで編集コントロール ブロック (ECB) を作成する方法。
- JSLink を使ってデフォルトのビューを変更したのですが、「View item」、「New item」で ECB のコンテキスト メニューを表示できません... XSLT やカスタム アクションを使用したくありません。私の雇用主によると、それを行うには JSLink を使用する必要があります。
- その他の Web パーツを使用せずに、FeatureReceiver.cs の View の JSLink を更新します。私のビューは問題ありませんが、ECB がありません。
これが私のカスタムビューの写真です:
SP2013 の標準ビュー:
これは私のJavaScriptコードです:
(function () {
var itemCtx = {};
itemCtx.Templates = {};
itemCtx.Templates.Item = ItemOverrideFun;
itemCtx.BaseViewID = 1;
itemCtx.ListTemplateType = 104;
itemCtx.OnPostRender = [];
itemCtx.OnPostRender.push(function () {
$(document).ready(function () {
// use this method to extend ECB on common lists...
function Custom_AddListMenuItems(m, ctx) {
// Adding a simple command to the ECB
CAMOpt(m, 'Go to', 'javascript:STSNavigate("http://www.abc.com");return false;');
// Adding a separator to the ECB
CAMSep(m);
}
// use this method to extend ECB on libraries...
function Custom_AddDocLibMenuItems(m, ctx) {}
});
});
SPClientTemplates.TemplateManager.RegisterTemplateOverrides(itemCtx);
})();
function ItemOverrideFun(ctx) {
var id = ctx.CurrentItem["ID"];
var _announcementTitle = ctx.CurrentItem["Title"];
var _announcementDesc = ctx.CurrentItem["Content"];
var createBy = ctx.CurrentItem["Author"][0].title;
var modified = ctx.CurrentItem["Modified"];
var att = ctx.CurrentItem["Attachments"];
var attImg = "";
if (att == true) {
attImg = attImg + "<img src='/../../_layouts/15/images/attach.gif' /> ";
}
return "<tr><td></td><td vAlign='top' style='width:20px;padding-left:8px;'>" + attImg + "</td><td colspan='2' style='padding-left:40px;'><img style='cursor:pointer' onclick='Expand(" + id + ");' id='imgId" + id + "' src='" + L_Menu_BaseUrl + "/Images/minus.gif' /><span style='padding-left:5px'><a style='cursor:pointer;font-size:1em' href='" + L_Menu_BaseUrl + "/Lists/Bulletin%20Board/DispForm.aspx?ID=" + id + "'>" + _announcementTitle + "</a></span><div id='sh" + id + "' style='padding-left:15px;'>" + _announcementDesc + "</div></td><td>" + createBy + "</td><td>" + modified + "</td></tr>";
}
function Expand(id) {
var dsStatus = document.getElementById('sh' + id).style.display;
var url = L_Menu_BaseUrl;
if (dsStatus == 'none') {
jQuery("#imgId" + id).attr('src', url + '/Images/minus.gif');
$('#sh' + id).show();
}
else {
jQuery("#imgId" + id).attr('src', url + '/images/plus.gif');
$('#sh' + id).hide();
}
}
ECBの構造体HTMLとは?欠落している ECB を返しましたが、どうすればその問題を解決できますか?