Coolite AjaxEvents、Listeners学习笔记
1.AjaxEvents
<AjaxEvents>
<Click OnEvent="Select">
<ExtraParams>
<ext:Parameter Name="Id" Value="node.id" Mode="Raw">
</ext:Parameter>
<ext:Parameter Name="Name" Value="node.text" Mode="Raw">
</ext:Parameter>
</ExtraParams>
</Click>
</AjaxEvents>
2.Listeners
<Listeners>
<Click Handler="alert(node.attributes.hrefTarget);" Fn="" />
</Listeners>
Handler与Fn以及OnEvent的区别?
1.Fn(优先级高于Handler,当两则共同存在时则Handler就不再起作用了。)
The raw JavaScript function to be called when this Listener fires.
<Click Fn="Function_Name" />
此处只写函数名,函数体写在Head当中。
2.Handler
The JavaScript logic to be called when this Listener fires. The Handler will be automatically wrapped in a proper function(){} template and passed the correct arguments for this event.
<Click Handler="alert(node.attributes.hrefTarget);" />
此处不能写函数名,只能写一段JS代码。
3.OnEvent(用于写在.cs文件里面的后台代码)
<Click OnEvent="Select">
<ExtraParams>
<ext:Parameter Name="Id" Value="node.id" Mode="Raw">
</ext:Parameter>
<ext:Parameter Name="Name" Value="node.text" Mode="Raw">
</ext:Parameter>
</ExtraParams>
</Click>
/// <summary>
/// 点击树所触发的事件
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
public void Select(object sender, AjaxEventArgs e)
{
//Ext.Msg.Alert("当前选中值", sender.ToString()).Show();
string text = "";
foreach (Coolite.Ext.Web.Parameter item in e.ExtraParams)
{
text += item.Name+" : "+ item.Value+"<br/>";
}
Ext.Msg.Alert("当前选中值", text).Show();
}
Handler与Fn以及OnEvent的转换方式?
<Listeners>
<BeforeLoad Fn="nodeLoad" />
</Listeners>
<script type="text/javascript">
function nodeLoad(node) {
Coolite.AjaxMethods.NodeLoad(node.id, {
success: function(result) {
var data = eval("(" + result + ")");
node.loadNodes(data);
},
failure: function(errorMsg) {
Ext.Msg.alert('Failure', errorMsg);
}
});
}
</script>
[AjaxMethod]
public static string NodeLoad(string nodeID)
{
Coolite.Ext.Web.TreeNodeCollection nodes = new Coolite.Ext.Web.TreeNodeCollection();
if (!string.IsNullOrEmpty(nodeID))
{
for (int i = 1; i < 6; i++)
{
AsyncTreeNode asyncNode = new AsyncTreeNode();
asyncNode.Text = nodeID + i;
asyncNode.NodeID = nodeID + i;
nodes.Add(asyncNode);
}
for (int i = 6; i < 11; i++)
{
Coolite.Ext.Web.TreeNode treeNode = new Coolite.Ext.Web.TreeNode();
treeNode.Text = nodeID + i;
treeNode.NodeID = nodeID + i;
treeNode.Leaf = true;
nodes.Add(treeNode);
}
}
return nodes.ToJson();
}
原文:http://hi.baidu.com/38608338/blog/item/8f77a6fd9e6c10f4fd037f76.html
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 25岁的心里话
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 按钮权限的设计及实现