如何本地化DataTable列名

5

这是我的数据表

public static DataTable GetTableForApproval()
{
    using (var connection = Utils.Database.GetConnection())
    using (var command = new SqlCommand("SELECT [UserID], [Username], " +
           "[Email], [Role], [Date] FROM [Users] WHERE [Role] = @role",
            connection))
    {
        command.Parameters.AddWithValue("@role", "Waiting");
        using (var reader = command.ExecuteReader())
        {
            var table = new DataTable();

            table.Columns.Add("UserID", typeof(int));
            table.Columns.Add("Name", typeof(string));
            table.Columns.Add("Email", typeof(string));
            table.Columns.Add("Role", typeof(string));
            table.Columns.Add("Registration date", typeof(DateTime));

            if (reader != null)
            {
                while (reader.Read())
                {
                    table.Rows.Add((int)reader["UserID"], 
                       (string)reader["Username"], (string)reader["Email"],
                       (string)reader["Role"], (DateTime)reader["Date"]);
                }
            }
            return table;
        }
    }
}    

我希望能本地化列名,你能告诉我如何实现吗?我的.aspx页面已经本地化了,但是我不知道如何本地化.cs文件中的文本。


为什么要本地化列名?实际上你不需要。你需要本地化显示给用户的文本。 - John Saunders
因为我希望列名以用户能够理解的语言书写。 - Ivan Stoyanov
你能告诉我如何从数据库中本地化字符串吗? - Ivan Stoyanov
1个回答

3

一旦你将resx文件添加到你的项目中,Visual Studio会生成强类型类,使你可以访问它们。例如,如果你将Messages.resx添加到你的项目中,将会创建一个名为Messages的静态类:

table.Columns.Add(Messages.UserId, typeof(int));

其中UserId是您添加的字符串资源。

更好的解决方案是本地化用户界面而不是DataTable的列名称。以下是一个示例:

<%@ Page Language="C#" AutoEventWireup="true"  %>
<script type="text/C#" runat="server">
    protected void Page_Load(object sender, EventArgs e)
    {
        if (!IsPostBack)
        {
            var table = new System.Data.DataTable();
            table.Columns.Add("UserID", typeof(int));
            for (int i = 0; i < 10; i++)
            {
                table.Rows.Add(i);
            }
            grdTest.DataSource = table;
            grdTest.DataBind();
        }
    }
</script>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>
        <asp:GridView ID="grdTest" runat="server" AutoGenerateColumns="false">
            <Columns>
                <asp:BoundField DataField="UserID" 
                    HeaderText="default value" 
                    meta:resourcekey="Grid" />
            </Columns>
        </asp:GridView>
    </div>
    </form>
</body>
</html>

页面上有一个GridView,它绑定到一个只有一列的DataTable。请注意BoundField上的meta:resourcekey="Grid"属性。现在将特殊的App_LocalResources文件夹添加到您的Web应用程序中,并在其中添加一个名为Default.aspx.resx的资源文件,假设网页名称为Default.aspx。在里面,您可以添加以下字符串资源:

Grid.HeaderText  |  Some value

在标记中给出的HeaderText的默认值将被替换为资源文件中提供的值(如果存在)。

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接