在页面编辑器中编辑时,我使用了具有图像字段类型功能区的自定义图像组件。
在核心数据库中,我需要隐藏/禁用 3 个用于图像的 webedit 按钮:
路径:/sitecore/system/Field types/Simple Types/Image/WebEdit Buttons/
按钮: 1. 选择图像 2. 图像属性 3. 清除图像
另外,我知道这可以通过覆盖Querystate()方法来实现,但我不确定它的实现,因为我是 CommandState 处理的新手。
而不是通过 QueryState,我正在尝试这个
我已将图像的属性“ DisableEdit ”设置为:
<myImage:PictureFillImage Field="<%# MyImage.Constants.FieldNames.Image %>" DisableEdit="true" ID="UIImage" runat="server"/>
我正在使用自定义类:
public class PictureFillImage : Sitecore.Web.UI.WebControls.FieldControl
我正在尝试禁用图像的网络编辑:
public bool DisableEdit { get; set; }
private Sitecore.Web.UI.WebControls.Image _smlImage;
private Sitecore.Data.Fields.ImageField _smlImageField;
private Sitecore.Web.UI.WebControls.FieldControl _fieldControl;
protected override void OnLoad(EventArgs e)
{
this.DataBind();
}
public override void DataBind()
{
// base.OnLoad(e);
this.Item = this.GetItem();
if ((this.Item != null) && (this.Field != null))
{
Sitecore.Data.Fields.Field field = this.Item.Fields[this.Field];
if (field != null)
{
this._smlImageField = (Sitecore.Data.Fields.ImageField)field;
this._smlImage = new Sitecore.Web.UI.WebControls.Image();
this._smlImage.Field = this.Field;
this._fieldControl = this._smlImage as Sitecore.Web.UI.WebControls.FieldControl;
this._smlImage.ID = this.ID;
this._smlImage.CssClass = this.CssClass;
this._smlImage.Parameters = "all=all";
this._fieldControl.Item = this.Item;
this._smlImage.DisableWebEditing = DisableEdit;
this._fieldControl.DisableWebEditing = DisableEdit;
}
}
base.DataBind();
}
我希望代码会隐藏页面编辑器的浮动功能区中出现的三个按钮:“选择图像”、“图像属性”和“清除图像”,但我得到了否定的结果。
请帮忙。