免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 5416 | 回复: 2
打印 上一主题 下一主题

一个加载css文件的jquery插件 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-03-30 13:50 |只看该作者 |倒序浏览
首发phpx了 为的是解决在ie下无法通过js实时加载css文件的问题
执行速度不要有什么期待 毕竟是通过jquery的选择器来执行 大家看看有没有bug 发现请跟帖告知下
  1. /**
  2. * 为当前整篇文档应用CSS文件样式
  3. *
  4. * @author  Sanders Yao
  5. * @example JQuery.getCSS('CSSFilePath');
  6. * @example JQuery.getCSS('CSSFilePath', function (css) {
  7. *              //do something after all style applied
  8. *          });
  9. * @example JQuery.getCSS('CSSFilePath', {
  10. *              beforeApp           : function (css) {
  11. *                  //do something before all style apply
  12. *              }
  13. *              beforeSelectorApp   : function (selector, cssObject) {
  14. *                  //do something before a style apply
  15. *              }
  16. *              afterSelectorApp    : function (selector, cssObject) {
  17. *                  //do something after a style applied
  18. *              }
  19. *              afterApp            : function (css) {
  20. *                  //do something after all style applied
  21. *              }
  22. *          });
  23. */
  24. $.extend({
  25.     getCSS  : function (url, option) {
  26.         $.get(url, function (css) {
  27.             var clip    = css.match(/[^{]+\{[^}]+?\}/g);

  28.             if ('object' == typeof option && 'function' == typeof option.beforeApp) {
  29.                 if (false === option.beforeApp(css)) {
  30.                     return  null;
  31.                 }
  32.             }
  33.             for(var i = 0;i < clip.length;i ++) {
  34.                 //删除注释
  35.                 var styleCode   = clip[i].replace(/\/\*(.|\s)*?\*\//g, '');
  36.                 //获取选择器
  37.                 var selector    = styleCode.replace(/^([^{]+)(.|\s)+$/g, "$1").replace(/(^[^;]*;\s*|^\s+|\s+$)/g, '');
  38.                 //获取样式定义
  39.                 var attrList    = styleCode.replace(/^[^{]+\{([^}]+)\}[^}]*$/g, "$1").split(';');
  40.                 var cssObject   = {};
  41.                 for (var j = 0;j < attrList.length;j ++) {
  42.                     var attr    = attrList[j].split(':');
  43.                     if (2 == attr.length) {
  44.                         var tmpVarName  = attr[0].replace(/(^\s+|\s+$)/g, '');
  45.                         var varName     = '';
  46.                         for (var k = 0;k < tmpVarName.length;k ++) {
  47.                             if ('-' == tmpVarName.charAt(k)) {
  48.                                 ++ k;
  49.                                 varName += tmpVarName.charAt(k).toUpperCase();
  50.                             } else {
  51.                                 varName += tmpVarName.charAt(k);
  52.                             }
  53.                         }
  54.                         cssObject[varName]  = attr[1].replace(/(^\s+|\s+$)/g, '');
  55.                     }
  56.                 }
  57.                 if ('object' == typeof option && 'function' == typeof option.beforeSelectorApp) {
  58.                     if (false === option.beforeSelectorApp(selector, cssObject)) {
  59.                         continue;
  60.                     }
  61.                 }
  62.                 $(selector).css(cssObject);
  63.                 if ('object' == typeof option && 'function' == typeof option.afterSelectorApp) {
  64.                     option.afterSelectorApp(selector, cssObject);
  65.                 }
  66.             }
  67.             if ('function' == typeof option) {
  68.                 option(css);
  69.             }
  70.             if ('object' == typeof option && 'function' == typeof option.afterApp) {
  71.                 option.afterApp(css);
  72.             }
  73.         });
  74.     }
  75. });
复制代码

论坛徽章:
0
2 [报告]
发表于 2010-05-22 22:01 |只看该作者
  1. JQuery.getCSS('CSSFilePath', {

  2.               beforeApp           : function (css) {

  3.                   //do something before all style apply

  4.               }

  5.               beforeSelectorApp   : function (selector, cssObject) {

  6.                   //do something before a style apply

  7.               }

  8.               afterSelectorApp    : function (selector, cssObject) {

  9.                   //do something after a style applied

  10.               }

  11.               afterApp            : function (css) {

  12.                   //do something after all style applied

  13.               }

复制代码

论坛徽章:
0
3 [报告]
发表于 2010-05-26 12:59 |只看该作者
帮顶...
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP