autorender.js 1.0 KB

12345678910111213141516171819202122232425262728293031
  1. /**
  2. * @fileOverview auto render
  3. * @author lifesinger@gmail.com
  4. */
  5. KISSY.add('imagezoom/autorender', function(S, DOM, JSON, ImageZoom) {
  6. /**
  7. * 自动渲染 container 元素内的所有 ImageZoom 组件
  8. * 默认钩子:<div class="KS_Widget" data-widget-type="ImageZoom" data-widget-config="{...}">
  9. *
  10. */
  11. ImageZoom.autoRender = function(hook, container) {
  12. hook = '.' + (hook || 'KS_Widget');
  13. S.each(DOM.query(hook, container),function(elem) {
  14. var type = elem.getAttribute('data-widget-type'), config;
  15. if (type === 'ImageZoom') {
  16. try {
  17. config = elem.getAttribute('data-widget-config');
  18. if (config) config = config.replace(/'/g, '"');
  19. new ImageZoom(elem, JSON.parse(config));
  20. }
  21. catch(ex) {
  22. S.log('ImageZoom.autoRender: ' + ex, 'warn');
  23. }
  24. }
  25. });
  26. };
  27. }, { requires:["dom","json","imagezoom/base"] });