1

我正在尝试显示一个包含我在后面的代码中创建的详细信息的列表。但是我在控制台中变得不确定。为什么会这样?

CS:

public partial class WebForm1 : System.Web.UI.Page
{
    public List<Person> persons { get; set; }

    protected void Page_Load(object sender, EventArgs e)
    {
        Person p1 = new Person() { name = "Tom" };
        Person p2 = new Person() { name = "Ed" };
        List<Person> lijst = new List<Person>();
        lijst.Add(p1);
        lijst.Add(p2);
        persons = lijst;
    }
}

public class Person
{
    public string name { get; set; }
}

aspx:

<script>
    var persons = '<%= persons%>'
    var length = persons.length;

    for (var i = 0; i < length; i++) {
        person = persons[i];

        console.log(person.name);
    }
</script>
4

2 回答 2

1

问题是 javascript 不知道您的 C# 类及其属性。您可能需要将其转换或序列化为已知类型,如字符串、xml 或 json 等。

试试下面的东西

您可以让方法从类属性返回逗号分隔的人名

    public string GetPersonNames
    {
        get
        {
            return string.Join(",", persons.Select(p => p.name));
        }
    }

在您的 aspx 中,您可以获取人名并按'

<script>
        var persons = '<%= GetPersonNames%>';
</script>

或者试试下面

<script type="text/javascript">
    var persons = '<%= new System.Web.Script.Serialization.JavaScriptSerializer().Serialize(persons)%>';
    persons = JSON.parse(persons);
    var length = persons.length;
    alert(length);
    for (var i = 0; i < length; i++) {
        var person = persons[i];
        alert(person.name);
    }
</script>
于 2013-06-14T03:22:45.590 回答
0

试试这个,在 .cs 中编码

 Person p1 = new Person() { name = "Tom" };
        Person p2 = new Person() { name = "Ed" };
        List<Person> lijst = new List<Person>();
        lijst.Add(p1);
        lijst.Add(p2);
        persons = new System.Web.Script.Serialization.JavaScriptSerializer().Serialize(lijst);

aspx中的javascript

var persons = eval('<%= persons%>');
    //this will show "Tom"
    alert(persons[0].name);
于 2013-06-14T03:14:21.397 回答