Это - моя таблица данных
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 файлах.
После добавления файлов 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
с одним столбцом. Обратите внимание на атрибут meta: resourcekey = "Grid"
в BoundField. Теперь добавьте в свое веб-приложение специальную папку App_LocalResources и внутри нее файл ресурсов с именем Default.aspx.resx
при условии, что веб-страница называется Default.aspx
. Внутри вы можете добавить следующий строковый ресурс:
Grid.HeaderText | Some value
Значение по умолчанию HeaderText
, указанное в разметке, будет заменено значением в файле ресурсов, если оно присутствует.