来自代码的umbraco数据类型和文本值

时间:2010-11-29 15:46:40

标签: umbraco

我正在尝试从API中获取下拉列表的文本值,我正在认真努力。

这就是我现在所拥有的:

Document doc = new Document(Node.GetCurrent().Id);

doc.GetProperty("fieldPropertyName").Value;

这将返回prevalue的id的字符串表示形式。

我想要的是该前值的文本。

提前感谢您的帮助。

3 个答案:

答案 0 :(得分:4)

使用库函数...

var stringValue = umbraco.library.GetPreValueAsString(Convert.ToInt32(doc.GetProperty("fieldName").Value));

答案 1 :(得分:0)

请原谅这在VB中。

这是我正在开发的语言。(我希望如何使用C#)

Imports System.Runtime.CompilerServices
Imports umbraco.cms.businesslogic.web
Imports umbraco.cms.businesslogic.datatype

Module UmbracoExtensionHelper


    <Extension()>
    Public Function GetCustomPropertyValueFromPreValues(ByVal doc As Document, ByVal propertyName As String)
        Dim returnValue As String = ""
        Dim objProperty As umbraco.cms.businesslogic.property.Property = doc.getProperty(propertyName)

        If objProperty IsNot Nothing Then
            Dim objPreValues = PreValues.GetPreValues(objProperty.PropertyType.DataTypeDefinition.Id)
            If objPreValues IsNot Nothing Then

                ''run through the ids of the datatypes and the value of the property
                For Each entry As DictionaryEntry In objPreValues
                    Dim currentPreValue As PreValue = CType(entry.Value, PreValue)
                    If currentPreValue.Id.ToString().ToLower() = objProperty.Value.ToString().ToLower() Then
                        returnValue = currentPreValue.Value.ToLower()
                        Exit For
                    End If
                Next

            End If
        End If

        Return returnValue
    End Function




End Module

答案 2 :(得分:0)

使用以下代码

aspx页面

 <asp:DropDownList ID="ddlLocation" ClientIDMode="Static" runat="server" AutoPostBack="true" CssClass="selectbox" OnSelectedIndexChanged="ddlLocation_SelectedIndexChanged" />

背后的代码

  var regionItems = regionFolder.Children;
            if (regionItems.Count > 0) {
                foreach (Node region in regionItems) {
                    if (region.GetProperty(FieldName.REGIONNAME) != null && !string.IsNullOrEmpty(region.GetProperty(FieldName.REGIONNAME).Value)) {
                        ddlLocation.Items.Add(new ListItem(region.GetProperty(FieldName.REGIONNAME).Value, region.Id.ToString()));
                    }
                }
            }
            //ddlLocation.Items.Insert(0, "Choose");
            ddlLocation.Items.Insert(0, new ListItem("Choose", "0"));

此处REGIONNAME =我们的字段名称