开发者

Binding a jQuery event to code created in ASPX code-behind?

开发者 https://www.devze.com 2023-03-02 23:12 出处:网络
For reasons out of my control I have both client-side JavaScript that builds up a row of an HTML table and similar code in the code-behind page that triggers after a button event.On the client-side, t

For reasons out of my control I have both client-side JavaScript that builds up a row of an HTML table and similar code in the code-behind page that triggers after a button event. On the client-side, there is an extra method that is called after the rows are created that unobtrusively and dynamically binds several live events to each input in the new row.

I need to get that same functionality from the row(s) created in the code-behind event handler. I tried simply calling the same method via ClientScript.RegisterClientScriptBlock and ClientScript.RegisterStartupScript but neither of them worked and no events trigger on the code-behind row (but they function as expec开发者_StackOverflowted if I then add a client-side row).

Any idea how to handle this? Should I call the client-side binding code elsewhere on the page rather than in the client-side creation method, so it will trigger on the code-behind? Or is there another way to call it from the code-behind?


Create a startup script that parses the rows in bulk during page initialization as in:

$("table").find("tr").live(..);

So from the server-side, you need to render a script that processes the table in bulk, and then manage the client-side interactions in a singular fashion.

You should be able to render something out like this; please post some code if you can't.

HTH.


If you use live and the rows all share a common class then it shouldn't matter how they are added, the event should apply to them. Simply run it once on page load and that's it.

0

精彩评论

暂无评论...
验证码 换一张
取 消