EasyUI学习总结(四)——parser源码分析

  parser模块是easyloader第一个加载的模块,它的主要作用,就是扫描页面上easyui开头的class标签,然后初始化成easyui控件。

 1     /**
 2      * parser模块主要是解析页面中easyui的控件
 3      */
 4     $.parser = {
 5         // 是否自动解析
 6         auto: true,
 7 
 8         // 可以被解析的控件
 9         plugins:['linkbutton','menu','menubutton','splitbutton','layout',
10                  'tree','window','dialog','datagrid',
11                  'combobox','combotree','numberbox','validatebox',
12                  'calendar','datebox','panel','tabs','accordion'
13         ],
14 
15         // 解析函数
16         parse: function(context){
17             if ($.parser.auto){
18                 for(var i=0; i<$.parser.plugins.length; i++){
19                     (function(){
20                         // 控件名
21                         var name = $.parser.plugins[i];
22                         // 查找class为easyui-控件名的jq对象,例如,easyui-layout
23                         var r = $('.easyui-' + name, context);
24 
25                         if (r.length){
26                             // 如果有这个对象,那么判断它有没有初始化函数
27                             if (r[name]){
28                                 // 如果有直接调用
29                                 r[name]();
30                             } else if (window.easyloader){
31                                 // 如果没有用easyloader把模块的js文件载入进来,再调用
32                                 easyloader.load(name, function(){
33                                     r[name]();
34                                 })
35                             }
36                         }
37                     })();
38                 }
39             }
40         }
41     };
42 
43     // 调用parse方法,实际上easyloader中已经调用了,我估计这个是给不是easyloader加载时使用的
44     $(function(){
45         $.parser.parse();
46     });
47 })(jQuery);

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值