2015-03-27 4 views
0

Я боюсь в течение 2 дней на этом, я пытаюсь вызвать функцию imagesLoaded (которая правильно импортирована в области скриптов), но при вызове изнутри компонента prop, я получаю сообщение об ошибке что он неопределен.функции undefind внутри объекта реакции

мой код:

var MasonryContainer = React.createClass({ 

    imagesLoadedFunc: function() { //omitting the imageloaded call here fix everything 
        this.imagesloaded(); 
        this.refs[reference].getDOMNode().imagesLoaded(function() { 
        this.masonry.layout() 
        }); 

    }, 
    componentDidMount: function() { 
       if (!isBrowser) return; 
       this.initializeMasonry(); 
       this.performLayout(); 
       this.imagesLoadedFunc(); 
      }, 

    componentDidUpdate: function() { 
       if (!isBrowser) return; 

       this.performLayout(); 
       this.imagesLoadedFunc(this); 
      }, 

      domChildren: [], 

    initializeMasonry: function(force) { 
     if (!this.masonry || force) { 
      this.masonry = new Masonry(this.refs[reference].getDOMNode(), options); 
      this.domChildren = this.getNewDomChildren(); 
     } 
    }, 

    getNewDomChildren: function() { 
     var node = this.refs[reference].getDOMNode(); 
     var children = options.itemSelector ? node.querySelectorAll(options.itemSelector) : node.children; 

     return Array.prototype.slice.call(children); 
    }, 

    diffDomChildren: function() { 
     var oldChildren = this.domChildren; 
     var newChildren = this.getNewDomChildren(); 
     var removed = oldChildren.filter(function(oldChild) { 
      return !~newChildren.indexOf(oldChild); 
     }); 

     var added = newChildren.filter(function(newChild) { 
      return !~oldChildren.indexOf(newChild); 
     }); 

     var moved = []; 

     if (removed.length === 0) { 
      moved = oldChildren.filter(function(child, index) { 
       return index !== newChildren.indexOf(child); 
      }); 
     } 
     this.domChildren = newChildren; 
     return { 
      old: oldChildren, 
      'new': newChildren, // fix for ie8 
      removed: removed, 
      added: added, 
      moved: moved 
     }; 
    }, 

    performLayout: function() { 
     var diff = this.diffDomChildren(); 

     if (diff.removed.length > 0) { 
      this.masonry.remove(diff.removed); 
      this.masonry.reloadItems(); 
     } 

     if (diff.added.length > 0) { 
      this.masonry.appended(diff.added); 
     } 

     if (diff.moved.length > 0) { 
      this.masonry.reloadItems(); 
     } 

     this.masonry.layout(); 
    }, 


    componentWillReceiveProps: function() { 
     setTimeout(function() { 
      this.masonry.reloadItems(); 
      this.forceUpdate(); 
     }.bind(this), 0); 
    }, 

    render: function() { 
     return (
      <div className="content" ref="masonryContainer"> 
       <div className='Item'> 
        <img src="/img/gallery/3.jpg"></img> 
       </div> 
       <div className='Item'> 
        <img src="/img/gallery/11.jpg"></img> 
       </div> 
       <div className='Item'> 
        <img src="/img/gallery/12.jpg"></img> 
       </div> 
       <div className='Item'> 
        <img src="/img/gallery/12.jpg"></img> 
       </div> 
       <img src="/img/gallery/4.jpg"></img> 
       <img src="/img/gallery/5.jpg"></img> 
       <img src="/img/gallery/6.jpg"></img> 
       <img src="/img/gallery/7.jpg"></img> 
       <img src="/img/gallery/8.jpg"></img> 
       <img src="/img/gallery/9.jpg"></img> 
      </div> 
     ); 
    } 
}); 
    React.render(
    <MasonryContainer/>, document.getElementById('reactbody') 
    ) 
</script> 

, если я называю imageloaded конструктор за пределами среагировать компонента, она работает. любая идея, что мне не хватает?

спасибо!

ответ

1

Ваше призвание imagesloaded с помощью этого

this.imagesloaded(); 

Однако imagesloaded не является частью компонента, ни стандарт в React. Таким образом, this.imagesloaded не определен, поскольку он никогда не был объявлен. Попробуйте удалить «эту» часть инструкции.

imagesLoadedFunc: function() { 
    imagesloaded(); 
    //the rest of the method 
}, 
+0

эй, спасибо за вашу помощь. все еще получил эту ошибку, см. Ответ ниже – avieln